/* * Copyright (c) 2007, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ #include #include #include #include "jnihelper.h" extern "C" { #define BOOL 0 #define BYTE 1 #define CHAR 2 #define SHORT 3 #define INT 4 #define LONG 5 #define FLOAT 6 #define DOUBLE 7 JNIEXPORT jobjectArray JNICALL Java_nsk_stress_jni_JNIter003_jniInitArrays (JNIEnv *env, jobject jobj, jint size) { jarray *arrayArray; jboolean *boolBuf; jbyte *byteBuf; jchar *charBuf; jshort *shortBuf; jint *intBuf; jlong *longBuf; jfloat *floatBuf; jdouble *doubleBuf; jobjectArray objectsArray; int i; int SIZE=size; const char *classname="java/lang/Object"; jclass clazz = env->FindClass(classname); CE objectsArray = env->NewObjectArray(8,clazz, env->AllocObject(clazz)); arrayArray=(jarray *)malloc(8*sizeof(jarray)); CE arrayArray[BOOL]=env->NewBooleanArray(SIZE); CE arrayArray[BYTE]=env->NewByteArray(SIZE); CE arrayArray[CHAR]=env->NewCharArray(SIZE); CE arrayArray[SHORT]=env->NewShortArray(SIZE); CE arrayArray[INT]=env->NewIntArray(SIZE); CE arrayArray[LONG]=env->NewLongArray(SIZE); CE arrayArray[FLOAT]=env->NewFloatArray(SIZE); CE arrayArray[DOUBLE]=env->NewDoubleArray(SIZE); CE for (i=0;i<8;i++) { env->SetObjectArrayElement(objectsArray,i,arrayArray[i]); CE } boolBuf=(jboolean *)malloc(SIZE*sizeof(jboolean)); byteBuf=(jbyte *)malloc(SIZE*sizeof(jbyte)); charBuf=(jchar *)malloc(SIZE*sizeof(jchar)); shortBuf=(jshort *)malloc(SIZE*sizeof(jshort)); intBuf=(jint *)malloc(SIZE*sizeof(jint)); longBuf=(jlong *)malloc(SIZE*sizeof(jlong)); floatBuf=(jfloat *)malloc(SIZE*sizeof(jfloat)); doubleBuf=(jdouble *)malloc(SIZE*sizeof(jdouble)); for (i=0;iSetBooleanArrayRegion((jbooleanArray) arrayArray[BOOL],0,i,boolBuf); CE env->SetByteArrayRegion((jbyteArray) arrayArray[BYTE],0,i,byteBuf); CE env->SetCharArrayRegion((jcharArray) arrayArray[CHAR],0,i,charBuf); CE env->SetShortArrayRegion((jshortArray) arrayArray[SHORT],0,i,shortBuf); CE env->SetIntArrayRegion((jintArray) arrayArray[INT],0,i,intBuf); CE env->SetLongArrayRegion((jlongArray) arrayArray[LONG],0,i,longBuf); CE env->SetFloatArrayRegion((jfloatArray) arrayArray[FLOAT],0,i,floatBuf); CE env->SetDoubleArrayRegion((jdoubleArray) arrayArray[DOUBLE],0,i,doubleBuf); CE free(doubleBuf); free(floatBuf); free(longBuf); free(intBuf); free(shortBuf); free(byteBuf); free(charBuf); free(boolBuf); free(arrayArray); return objectsArray; } JNIEXPORT jboolean JNICALL Java_nsk_stress_jni_JNIter003_jniBodyChangeArray (JNIEnv *env, jobject jobj, jobjectArray orig, jobjectArray clone, jint limit) { #define SWAP(param1, param2) tmparr=param2; param2=param1; param1=tmparr; #define SIZE(type) env->GetArrayLength(arrayClone[type]) static volatile long count=0; jarray *arrayOrig, *arrayClone; jboolean *boolOrig, *boolClone; jbyte *byteOrig, *byteClone; jchar *charOrig, *charClone; jshort *shortOrig, *shortClone; jint *intOrig, *intClone; jlong *longOrig, *longClone; jfloat *floatOrig, *floatClone; jdouble *doubleOrig, *doubleClone; int i; if ((orig == NULL) || (clone == NULL)) { fprintf(stderr,"JNI received a NULL array from Java\n"); return JNI_FALSE; } if (count == limit) { jclass clazz; const char *classname = "nsk/stress/jni/JNIter003"; const char *setdone = "halt"; const char *setdonesig = "()V"; jmethodID jmethod; fprintf(stderr, "Count and limit are: %ld\t%d cons.\n", count, limit); clazz=env->FindClass(classname); CE jmethod=env->GetMethodID(clazz, setdone, setdonesig); CE env->CallVoidMethod(jobj, jmethod); CE return JNI_TRUE; } env->MonitorEnter(jobj); CE ++count; env->MonitorExit(jobj); CE arrayOrig=(jarray *)malloc(8*sizeof(jarray)); arrayClone=(jarray *)malloc(8*sizeof(jarray)); for (i=0;i<8;i++) { arrayOrig[i]=(jarray) env->GetObjectArrayElement(orig,i); CE arrayClone[i]=(jarray) env->GetObjectArrayElement(clone,i); CE } /* Take the elements from Java arrays into native buffers */ /* Use GetArrayElements */ boolOrig = env->GetBooleanArrayElements((jbooleanArray) arrayOrig[BOOL],0); CE byteOrig = env->GetByteArrayElements((jbyteArray) arrayOrig[BYTE],0); CE charOrig = env->GetCharArrayElements((jcharArray) arrayOrig[CHAR],0); CE shortOrig = env->GetShortArrayElements((jshortArray) arrayOrig[SHORT],0); CE intOrig = env->GetIntArrayElements((jintArray) arrayOrig[INT],0); CE longOrig = env->GetLongArrayElements((jlongArray) arrayOrig[LONG],0); CE floatOrig = env->GetFloatArrayElements((jfloatArray) arrayOrig[FLOAT],0); CE doubleOrig = env->GetDoubleArrayElements((jdoubleArray) arrayOrig[DOUBLE],0); CE /* Alloc some memory for cloned arrays buffers */ boolClone=(jboolean *)malloc(SIZE(BOOL)*sizeof(jboolean)); byteClone=(jbyte *)malloc(SIZE(BYTE)*sizeof(jbyte)); charClone=(jchar *)malloc(SIZE(CHAR)*sizeof(jchar)); shortClone=(jshort *)malloc(SIZE(SHORT)*sizeof(jshort)); intClone=(jint *)malloc(SIZE(INT)*sizeof(jint)); longClone=(jlong *)malloc(SIZE(LONG)*sizeof(jlong)); floatClone=(jfloat *)malloc(SIZE(FLOAT)*sizeof(jfloat)); doubleClone=(jdouble *)malloc(SIZE(DOUBLE)*sizeof(jdouble)); /* Take the elements from cloned Java arrays into native buffers */ /* Use GetArrayRegion */ env->GetBooleanArrayRegion((jbooleanArray) arrayClone[BOOL],0,SIZE(BOOL),boolClone); CE env->GetByteArrayRegion((jbyteArray) arrayClone[BYTE],0,SIZE(BYTE),byteClone); CE env->GetCharArrayRegion((jcharArray) arrayClone[CHAR],0,SIZE(CHAR),charClone); CE env->GetShortArrayRegion((jshortArray) arrayClone[SHORT],0,SIZE(SHORT),shortClone); CE env->GetIntArrayRegion((jintArray) arrayClone[INT],0,SIZE(INT),intClone); CE env->GetLongArrayRegion((jlongArray) arrayClone[LONG],0,SIZE(LONG),longClone); CE env->GetFloatArrayRegion((jfloatArray) arrayClone[FLOAT],0,SIZE(FLOAT),floatClone); CE env->GetDoubleArrayRegion((jdoubleArray) arrayClone[DOUBLE],0,SIZE(DOUBLE),doubleClone); CE /* In this code section I should make some changes for elements into both */ /* (original and cloned) arrays and than copied new values back to Java */ /* Can't change the pointer into the Java structure. It's illegal JNI. SWAP(boolOrig,boolClone) SWAP(byteOrig,byteClone) SWAP(charOrig,charClone) SWAP(shortOrig,shortClone) SWAP(intOrig,intClone) SWAP(longOrig,longClone) SWAP(floatOrig,floatClone) SWAP(doubleOrig,doubleClone) */ /* Coping new values of elements back to Java and releasing native buffers */ /* Use SetArrayRegion */ /* Use Orig pointers to get the original effect of the test. env->SetBooleanArrayRegion(arrayClone[BOOL],0,SIZE(BOOL),boolClone); env->SetByteArrayRegion(arrayClone[BYTE],0,SIZE(BYTE),byteClone); env->SetCharArrayRegion(arrayClone[CHAR],0,SIZE(CHAR),charClone); env->SetShortArrayRegion(arrayClone[SHORT],0,SIZE(SHORT),shortClone); env->SetIntArrayRegion(arrayClone[INT],0,SIZE(INT),intClone); env->SetLongArrayRegion(arrayClone[LONG],0,SIZE(LONG),longClone); env->SetFloatArrayRegion(arrayClone[FLOAT],0,SIZE(FLOAT),floatClone); env->SetDoubleArrayRegion(arrayClone[DOUBLE],0,SIZE(DOUBLE),doubleClone); */ env->SetBooleanArrayRegion((jbooleanArray) arrayClone[BOOL],0,SIZE(BOOL),boolOrig); CE env->SetByteArrayRegion((jbyteArray) arrayClone[BYTE],0,SIZE(BYTE),byteOrig); CE env->SetCharArrayRegion((jcharArray) arrayClone[CHAR],0,SIZE(CHAR),charOrig); CE env->SetShortArrayRegion((jshortArray) arrayClone[SHORT],0,SIZE(SHORT),shortOrig); CE env->SetIntArrayRegion((jintArray) arrayClone[INT],0,SIZE(INT),intOrig); CE env->SetLongArrayRegion((jlongArray) arrayClone[LONG],0,SIZE(LONG),longOrig); CE env->SetFloatArrayRegion((jfloatArray) arrayClone[FLOAT],0,SIZE(FLOAT),floatOrig); CE env->SetDoubleArrayRegion((jdoubleArray) arrayClone[DOUBLE],0,SIZE(DOUBLE),doubleOrig); CE /* Use ReleaseArrayElements */ env->ReleaseDoubleArrayElements((jdoubleArray) arrayOrig[DOUBLE],doubleOrig,0); CE env->ReleaseFloatArrayElements((jfloatArray) arrayOrig[FLOAT],floatOrig,0); CE env->ReleaseLongArrayElements((jlongArray) arrayOrig[LONG],longOrig,0); CE env->ReleaseIntArrayElements((jintArray) arrayOrig[INT],intOrig,0); CE env->ReleaseShortArrayElements((jshortArray) arrayOrig[SHORT],shortOrig,0); CE env->ReleaseCharArrayElements((jcharArray) arrayOrig[CHAR],charOrig,0); CE env->ReleaseByteArrayElements((jbyteArray) arrayOrig[BYTE],byteOrig,0); CE env->ReleaseBooleanArrayElements((jbooleanArray) arrayOrig[BOOL],boolOrig,0); CE free(arrayOrig); free(doubleClone); free(floatClone); free(longClone); free(intClone); free(shortClone); free(byteClone); free(charClone); free(boolClone); free(arrayClone); return JNI_TRUE; } }