aboutsummaryrefslogtreecommitdiffstats
path: root/java-c-jni
diff options
context:
space:
mode:
authorMattias Andrée <maandree@operamail.com>2013-08-10 04:40:25 +0200
committerMattias Andrée <maandree@operamail.com>2013-08-10 04:40:25 +0200
commitf3632ee82dc00fe51ea4e04bb79325c67bcdca39 (patch)
treeec12a285ef5ce9ae72bc1405ae321f3b9740817c /java-c-jni
parentm (diff)
downloadsha3sum-f3632ee82dc00fe51ea4e04bb79325c67bcdca39.tar.gz
sha3sum-f3632ee82dc00fe51ea4e04bb79325c67bcdca39.tar.bz2
sha3sum-f3632ee82dc00fe51ea4e04bb79325c67bcdca39.tar.xz
fix java-c-jni sigsegv
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to 'java-c-jni')
-rw-r--r--java-c-jni/SHA3.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/java-c-jni/SHA3.c b/java-c-jni/SHA3.c
index 666a7c6..f9dd01d 100644
--- a/java-c-jni/SHA3.c
+++ b/java-c-jni/SHA3.c
@@ -28,7 +28,7 @@
#define null 0
-#define byte jbyte
+#define byte char
#define boolean long
#define true 1
#define false 0
@@ -713,18 +713,21 @@ JNIEXPORT void JNICALL Java_SHA3_initialise(JNIEnv* env, jclass class, jint bitr
JNIEXPORT void JNICALL Java_SHA3_update(JNIEnv* env, jclass class, jbyteArray msg, jint msglen)
{
(void) class;
-
- update((*env)->GetByteArrayElements(env, msg, 0), msglen);
+ if ((msg != 0) && (msglen != 0))
+ update((byte*)((*env)->GetByteArrayElements(env, msg, 0)), msglen);
}
JNIEXPORT jbyteArray JNICALL Java_SHA3_digest(JNIEnv* env, jclass class, jbyteArray msg, jint msglen)
{
- byte* rcn;
+ jbyte* rcn;
jbyteArray rcj;
(void) class;
- rcn = digest((*env)->GetByteArrayElements(env, msg, 0), msglen);
+ if ((msg != 0) && (msglen != 0))
+ rcn = (jbyte*)digest((byte*)((*env)->GetByteArrayElements(env, msg, 0)), msglen);
+ else
+ rcn = (jbyte*)digest(0, 0);
rcj = (*env)->NewByteArray(env, (n + 7) >> 3);
(*env)->SetByteArrayRegion(env, rcj, 0, (n + 7) >> 3, rcn);
return rcj;