dmfieldrw32test.c

来自「This is a resource based on j2me embedde」· C语言 代码 · 共 198 行

C
198
字号
/* * @(#)DMFieldRW32Test.c	1.9 06/10/10 * * Copyright  1990-2008 Sun Microsystems, Inc. All Rights Reserved.   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER   *    * This program 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 program 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 at /legal/license.txt).    *    * 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 Sun Microsystems, Inc., 4150 Network Circle, Santa   * Clara, CA 95054 or visit www.sun.com if you need additional   * information or have any questions.  * */#include "javavm/export/jvm.h"#include "javavm/export/jni.h"#include "native/common/jni_util.h"#include "javavm/include/interpreter.h"#include "javavm/include/gc_common.h"#include "javavm/include/porting/threads.h"#include "javavm/include/porting/time.h"#include "javavm/include/porting/int.h"#include "javavm/include/porting/doubleword.h"#include "javavm/include/clib.h"#include "javavm/include/indirectmem.h"#include "javavm/include/directmem.h"#include "javavm/include/globalroots.h"#include "javavm/include/localroots.h"#include "javavm/include/preloader.h"#include "javavm/include/common_exceptions.h"#include "generated/offsets/java_lang_Class.h"#include "generated/offsets/java_lang_Thread.h"#include "generated/offsets/java_lang_Throwable.h"#include "generated/jni/java_lang_reflect_Modifier.h"#include <stdio.h>#include "DMFieldRW32Test.h"JNIEXPORT jintArray JNICALL Java_DMFieldRW32Test_nGetValues (JNIEnv *env, jobject obj) {   jint i, j, count = 0;   jint numFields = 0;   jintArray intArray;   jobject lock;   jfieldID iFid, oFid;   jclass gcClazz, testClazz;   CVMJavaVal32 var;   CVMClassBlock *cb;   CVMExecEnv *ee;   ee = CVMjniEnv2ExecEnv(env);   gcClazz = (*env)->FindClass(env, "GcThread");   iFid = (*env)->GetStaticFieldID(env, gcClazz, "gcCalled", "I");   testClazz = (*env)->GetObjectClass(env, obj);   oFid = (*env)->GetStaticFieldID(env, testClazz, "lock", "Ljava/lang/Object;");   lock = (*env)->GetStaticObjectField(env, testClazz, oFid);   cb = CVMgcSafeClassRef2ClassBlock(ee, testClazz);   CVMD_gcUnsafeExec( ee, {      CVMFieldBlock* fb;      for(i=0; i< CVMcbFieldCount(cb); i++) {         fb = CVMcbFieldSlot(cb, i);                  if(!CVMfbIs(fb, STATIC))            ++numFields;      }   });   intArray = (*env)->NewIntArray(env, numFields);   CVMD_gcUnsafeExec( ee, {      CVMFieldBlock* fb;      int objOffset;      CVMObject *directObject = CVMID_icellDirect(ee, obj);      CVMArrayOfInt* directIntArray = (CVMArrayOfInt *)CVMID_icellDirect(ee, intArray);      CVMfbStaticField(ee, iFid).i = -1;      CVMobjectLock(ee, lock);      CVMobjectNotify(ee, lock);      CVMobjectUnlock(ee, lock);      for(i = 0; i < 10000000; i++)         ;      for(i=0, j=0; i< CVMcbFieldCount(cb); i++) {         fb = CVMcbFieldSlot(cb, i);                  if(!CVMfbIs(fb, STATIC)) {            objOffset = CVMfbOffset(fb);            CVMD_fieldRead32(directObject, objOffset, var);            if(ee->barrier == R_BARRIER_INT)               count++;            CVMD_arrayWriteInt(directIntArray, i, var.i);            ++j;         }      }      if(count == numFields)         printf("PASS: DMFieldRWIntTest:Read, Read Barrier Int was invoked.\n");      else         printf("FAIL: DMFieldRWIntTest:Read, Read Barrier Int was not invoked.\n");      if(CVMfbStaticField(ee, iFid).i == -1)	printf("PASS: DMFieldRW32Test:Read, Gc did not happen in the gc unsafe section\n");      else	printf("FAIL: DMFieldRW32Test:Read, Gc happened in the gc unsafe section\n");   });   return intArray;}JNIEXPORT void JNICALLJava_DMFieldRW32Test_nSetValues(JNIEnv *env, jobject obj,                        jint v1, jint v2, jint v3){   jint i, count = 0;   jobject lock;   jfieldID iFid, oFid;   jclass gcClazz, testClazz;   CVMClassBlock *cb;   CVMExecEnv *ee;   CVMJavaVal32 var;   ee = CVMjniEnv2ExecEnv(env);   gcClazz = (*env)->FindClass(env, "GcThread");   iFid = (*env)->GetStaticFieldID(env, gcClazz, "gcCalled", "I");   testClazz = (*env)->GetObjectClass(env, obj);   oFid = (*env)->GetStaticFieldID(env, testClazz, "lock", "Ljava/lang/Object;");   lock = (*env)->GetStaticObjectField(env, testClazz, oFid);   cb = CVMgcSafeClassRef2ClassBlock(ee, testClazz);   CVMD_gcUnsafeExec( ee, {      CVMFieldBlock* fb;      int objOffset[CVMcbFieldCount(cb)];      int numFields = 0;      CVMObject *directObject = CVMID_icellDirect(ee, obj);      CVMfbStaticField(ee, iFid).i = -1;      CVMobjectLock(ee, lock);      CVMobjectNotify(ee, lock);      CVMobjectUnlock(ee, lock);      for(i = 0; i < 10000000; i++)         ;      for(i=0; i< CVMcbFieldCount(cb); i++) {         fb = CVMcbFieldSlot(cb, i);                  if(!CVMfbIs(fb, STATIC))            objOffset[numFields++] = CVMfbOffset(fb);      }      var.i = v1;      CVMD_fieldWrite32(directObject, objOffset[0], var);      if(ee->barrier == W_BARRIER_INT)         count++;      var.i = v2;      CVMD_fieldWrite32(directObject, objOffset[1], var);      if(ee->barrier == W_BARRIER_INT)         count++;      var.i = v3;      CVMD_fieldWrite32(directObject, objOffset[2], var);      if(ee->barrier == W_BARRIER_INT)         count++;      if(count == numFields)         printf("PASS: DMFieldRWIntTest:Write, Write Barrier Int\n");      else         printf("FAIL: DMFieldRWIntTest:Write, Write Barrier Int\n");      if(CVMfbStaticField(ee, iFid).i == -1)	printf("PASS: DMFieldRW32Test:Write, Gc did not happen in the gc unsafe section\n");      else	printf("FAIL: DMFieldRW32Test:Write, Gc happened in the gc unsafe section\n");   } );}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?