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 + -
显示快捷键?