delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2003/01/27/19:09:33

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com
Message-ID: <3E35CA76.2070007@fultondesigns.co.uk>
Date: Tue, 28 Jan 2003 00:10:30 +0000
From: William S Fulton <wsf AT fultondesigns DOT co DOT uk>
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:1.2.1) Gecko/20021130
X-Accept-Language: en, en-us
MIME-Version: 1.0
To: cygwin AT cygwin DOT com
Subject: Re: Using cygwin and JAVA/JNI

Following up from recent emails about Java/JNI using Sun's JDK I'd 
thought I'd share my experiences.

Up and until Cygwin-1.3.13 the test script below would compile and run 
as expected. The test produces a simple Java Native Interface (JNI) 
program which calls C code from a Java program using JNI. Releases since 
Cygwin-1.3.13 have resulted in calls to JNI code in a DLL being erratic; 
some Cygwin versions produce a core dump, others result in a non-zero 
program exit code and no error message when calling JNI functions. The 
output below is using Cygwin-1.3.19.

The results are independent of the gcc compiler, I've examined gcc 
2.95-3, gcc-2 2.95.3-10 and gcc 3.2 20020927 and intermediate versions. 
If the dll that these compilers produce is run under Cygwin-1.3.13 and 
earlier versions, the program will work. I've been watching each release 
since then and each produces different ways of failing, but none have 
worked with all the tests I use (SWIG's Java test-suite), unlike pre 
1.3.13. I've used many versions since Cygwin-1.3.3.

If the code is built using -mno-cygwin, the problem also goes away. So 
it looks like it is more recent versions of the Cygwin dll at fault.

If anyone has had any luck with GCJ and JNI on Cygwin I'd appreciate 
info as my experiments and mailing list search has been fruitless.

Cheers
William

------------------- test script: java_cygwin_test ---------------------
Requires JDK to be set to the Sun Java 2 SDK (JDK) installation
-----------------------------------------------------------------------

#! /bin/sh

set -x

#Set path to Sun J2 SDK (JDK)
JDK=c:/j2sdk1.4.1

cat > example.c << 'END'
#if defined(__GNUC__)
     typedef long long __int64; /*For gcc on Windows */
#endif
#include <jni.h>
JNIEXPORT jint JNICALL Java_exampleJNI_timesTwo(JNIEnv *jenv, jclass 
jcls, jint num) {
     return num*2;
}
END

cat > main.java << 'END'
public class main {

   static {
     try {
	System.loadLibrary("example");
     } catch (UnsatisfiedLinkError e) {
       System.err.println("Native code library failed to load.\n" + e);
       System.exit(1);
     }
   }

   public static void main(String argv[]) {
     System.out.println("Java program started");
     int answer = exampleJNI.timesTwo(7);
     System.out.println( "7*2 = " + answer);
   }
}
END

cat > exampleJNI.java << 'END'
class exampleJNI {
   public final static native int timesTwo(int num);
}
END

# Recent versions of Cygwin will not work unless using -mno-cygwin
gcc -c -mno-cygwin  example.c -I$JDK/include -I$JDK/include/win32
gcc -shared example.o -Wl,--add-stdcall-alias -mno-cygwin -o example.dll
#gcc -c example.c  -I$JDK/include -I$JDK/include/win32
#gcc -shared example.o -Wl,--add-stdcall-alias -o example.dll

$JDK/bin/javac *.java
$JDK/bin/java main || echo Java program FAILED


------------------ Results showing working using -mno-cygwin -----

$ ./java_cygwin_test
+ JDK=c:/j2sdk1.4.1
+ cat
+ cat
+ cat
+ gcc -c -mno-cygwin example.c -Ic:/j2sdk1.4.1/include 
-Ic:/j2sdk1.4.1/include/w
in32
+ gcc -shared example.o -Wl,--add-stdcall-alias -mno-cygwin -o example.dll
+ c:/j2sdk1.4.1/bin/javac exampleJNI.java main.java
+ c:/j2sdk1.4.1/bin/java main
Java program started
7*2 = 14

----------- Results showing not working using the Cygwin 1.3.19 DLL
$ ./java_cygwin_test
+ JDK=c:/j2sdk1.4.1
+ cat
+ cat
+ cat
+ gcc -c example.c -Ic:/j2sdk1.4.1/include -Ic:/j2sdk1.4.1/include/win32
+ gcc -shared example.o -Wl,--add-stdcall-alias -o example.dll
+ c:/j2sdk1.4.1/bin/javac exampleJNI.java main.java
+ c:/j2sdk1.4.1/bin/java main
+ echo Java program FAILED
Java program FAILED



--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Bug reporting:         http://cygwin.com/bugs.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019