/* * Copyright (c) 2003, 2012, 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. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * 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 "jvm.h" #include "management.h" #include "sun_management_VMManagementImpl.h" #define MAX_VERSION_LEN 20 JNIEXPORT jstring JNICALL Java_sun_management_VMManagementImpl_getVersion0 (JNIEnv *env, jclass dummy) { char buf[MAX_VERSION_LEN]; jstring version_string = NULL; unsigned int major = ((unsigned int) jmm_version & 0x0FFF0000) >> 16; unsigned int minor = ((unsigned int) jmm_version & 0xFF00) >> 8; // for internal use unsigned int micro = (unsigned int) jmm_version & 0xFF; sprintf(buf, "%d.%d", major, minor); version_string = (*env)->NewStringUTF(env, buf); return version_string; } static void setStaticBooleanField (JNIEnv* env, jclass cls, const char* name, jboolean value) { jfieldID fid; fid = (*env)->GetStaticFieldID(env, cls, name, "Z"); if (fid != 0) { (*env)->SetStaticBooleanField(env, cls, fid, value); } } JNIEXPORT void JNICALL Java_sun_management_VMManagementImpl_initOptionalSupportFields (JNIEnv *env, jclass cls) { jmmOptionalSupport mos; jint ret = jmm_interface->GetOptionalSupport(env, &mos); jboolean value; value = mos.isCompilationTimeMonitoringSupported; setStaticBooleanField(env, cls, "compTimeMonitoringSupport", value); value = mos.isThreadContentionMonitoringSupported; setStaticBooleanField(env, cls, "threadContentionMonitoringSupport", value); value = mos.isCurrentThreadCpuTimeSupported; setStaticBooleanField(env, cls, "currentThreadCpuTimeSupport", value); value = mos.isOtherThreadCpuTimeSupported; setStaticBooleanField(env, cls, "otherThreadCpuTimeSupport", value); value = mos.isBootClassPathSupported; setStaticBooleanField(env, cls, "bootClassPathSupport", value); if (jmm_version >= JMM_VERSION_1_1) { value = mos.isObjectMonitorUsageSupported; setStaticBooleanField(env, cls, "objectMonitorUsageSupport", value); value = mos.isSynchronizerUsageSupported; setStaticBooleanField(env, cls, "synchronizerUsageSupport", value); } else { setStaticBooleanField(env, cls, "objectMonitorUsageSupport", JNI_FALSE); setStaticBooleanField(env, cls, "synchronizerUsageSupport", JNI_FALSE); } value = mos.isThreadAllocatedMemorySupported; setStaticBooleanField(env, cls, "threadAllocatedMemorySupport", value); value = mos.isRemoteDiagnosticCommandsSupported; setStaticBooleanField(env, cls, "remoteDiagnosticCommandsSupport", value); if ((jmm_version > JMM_VERSION_1_2) || (jmm_version == JMM_VERSION_1_2 && ((jmm_version&0xFF) >= 1))) { setStaticBooleanField(env, cls, "gcNotificationSupport", JNI_TRUE); } else { setStaticBooleanField(env, cls, "gcNotificationSupport", JNI_FALSE); } } JNIEXPORT jobjectArray JNICALL Java_sun_management_VMManagementImpl_getVmArguments0 (JNIEnv *env, jobject dummy) { return jmm_interface->GetInputArgumentArray(env); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getTotalClassCount (JNIEnv *env, jobject dummy) { /* JMM_CLASS_LOADED_COUNT is the total number of classes loaded */ jlong count = jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_LOADED_COUNT); return count; } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getUnloadedClassCount (JNIEnv *env, jobject dummy) { /* JMM_CLASS_UNLOADED_COUNT is the total number of classes unloaded */ jlong count = jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_UNLOADED_COUNT); return count; } JNIEXPORT jboolean JNICALL Java_sun_management_VMManagementImpl_getVerboseGC (JNIEnv *env, jobject dummy) { return jmm_interface->GetBoolAttribute(env, JMM_VERBOSE_GC); } JNIEXPORT jboolean JNICALL Java_sun_management_VMManagementImpl_getVerboseClass (JNIEnv *env, jobject dummy) { return jmm_interface->GetBoolAttribute(env, JMM_VERBOSE_CLASS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getTotalThreadCount (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_THREAD_TOTAL_COUNT); } JNIEXPORT jint JNICALL Java_sun_management_VMManagementImpl_getLiveThreadCount (JNIEnv *env, jobject dummy) { jlong count = jmm_interface->GetLongAttribute(env, NULL, JMM_THREAD_LIVE_COUNT); return (jint) count; } JNIEXPORT jint JNICALL Java_sun_management_VMManagementImpl_getPeakThreadCount (JNIEnv *env, jobject dummy) { jlong count = jmm_interface->GetLongAttribute(env, NULL, JMM_THREAD_PEAK_COUNT); return (jint) count; } JNIEXPORT jint JNICALL Java_sun_management_VMManagementImpl_getDaemonThreadCount (JNIEnv *env, jobject dummy) { jlong count = jmm_interface->GetLongAttribute(env, NULL, JMM_THREAD_DAEMON_COUNT); return (jint) count; } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getTotalCompileTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_COMPILE_TOTAL_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getStartupTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_JVM_INIT_DONE_TIME_MS); } JNIEXPORT jboolean JNICALL Java_sun_management_VMManagementImpl_isThreadContentionMonitoringEnabled (JNIEnv *env, jobject dummy) { return jmm_interface->GetBoolAttribute(env, JMM_THREAD_CONTENTION_MONITORING); } JNIEXPORT jboolean JNICALL Java_sun_management_VMManagementImpl_isThreadCpuTimeEnabled (JNIEnv *env, jobject dummy) { return jmm_interface->GetBoolAttribute(env, JMM_THREAD_CPU_TIME); } JNIEXPORT jboolean JNICALL Java_sun_management_VMManagementImpl_isThreadAllocatedMemoryEnabled (JNIEnv *env, jobject dummy) { return jmm_interface->GetBoolAttribute(env, JMM_THREAD_ALLOCATED_MEMORY); } JNIEXPORT jint JNICALL Java_sun_management_VMManagementImpl_getProcessId (JNIEnv *env, jobject dummy) { jlong pid = jmm_interface->GetLongAttribute(env, NULL, JMM_OS_PROCESS_ID); return (jint) pid; } JNIEXPORT jint JNICALL Java_sun_management_VMManagementImpl_getAvailableProcessors (JNIEnv *env, jobject dummy) { return JVM_ActiveProcessorCount(); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getSafepointCount (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_SAFEPOINT_COUNT); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getTotalSafepointTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_TOTAL_STOPPED_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getSafepointSyncTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_TOTAL_SAFEPOINTSYNC_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getTotalApplicationNonStoppedTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_TOTAL_APP_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getLoadedClassSize (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_LOADED_BYTES); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getUnloadedClassSize (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_UNLOADED_BYTES); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getClassLoadingTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_TOTAL_CLASSLOAD_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getMethodDataSize (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_METHOD_DATA_SIZE_BYTES); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getInitializedClassCount (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_INIT_TOTAL_COUNT); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getClassInitializationTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_INIT_TOTAL_TIME_MS); } JNIEXPORT jlong JNICALL Java_sun_management_VMManagementImpl_getClassVerificationTime (JNIEnv *env, jobject dummy) { return jmm_interface->GetLongAttribute(env, NULL, JMM_CLASS_VERIFY_TOTAL_TIME_MS); } JNIEXPORT jobjectArray JNICALL Java_sun_management_VMManagementImpl_getDiagnosticCommands (JNIEnv *env, jobject dummy) { jmmOptionalSupport mos; jint ret = jmm_interface->GetOptionalSupport(env, &mos); jboolean rdcmd_support = mos.isRemoteDiagnosticCommandsSupported; if (rdcmd_support) { return jmm_interface->GetDiagnosticCommands(env); } JNU_ThrowByName(env, "java/lang/UnsupportedOperationException", "JMX interface to diagnostic commands is not supported by this VM"); } jobject getDiagnosticCommandArgumentInfoArray(JNIEnv *env, jstring command, int num_arg) { int i; jobject obj; jobjectArray result; dcmdArgInfo* dcmd_arg_info_array; jclass dcmdArgInfoCls; jclass arraysCls; jmethodID mid; jobject resultList; dcmd_arg_info_array = (dcmdArgInfo*) malloc(num_arg * sizeof(dcmdArgInfo)); if (dcmd_arg_info_array == NULL) { return NULL; } jmm_interface->GetDiagnosticCommandArgumentsInfo(env, command, dcmd_arg_info_array); dcmdArgInfoCls = (*env)->FindClass(env, "sun/management/DiagnosticCommandArgumentInfo"); result = (*env)->NewObjectArray(env, num_arg, dcmdArgInfoCls, NULL); if (result == NULL) { free(dcmd_arg_info_array); return NULL; } for (i=0; iNewStringUTF(env,dcmd_arg_info_array[i].name), (*env)->NewStringUTF(env,dcmd_arg_info_array[i].description), (*env)->NewStringUTF(env,dcmd_arg_info_array[i].type), dcmd_arg_info_array[i].default_string == NULL ? NULL: (*env)->NewStringUTF(env, dcmd_arg_info_array[i].default_string), dcmd_arg_info_array[i].mandatory, dcmd_arg_info_array[i].option, dcmd_arg_info_array[i].multiple, dcmd_arg_info_array[i].position); if (obj == NULL) { free(dcmd_arg_info_array); return NULL; } (*env)->SetObjectArrayElement(env, result, i, obj); } free(dcmd_arg_info_array); arraysCls = (*env)->FindClass(env, "java/util/Arrays"); mid = (*env)->GetStaticMethodID(env, arraysCls, "asList", "([Ljava/lang/Object;)Ljava/util/List;"); resultList = (*env)->CallStaticObjectMethod(env, arraysCls, mid, result); return resultList; } /* Throws IllegalArgumentException if at least one the diagnostic command * passed in argument is not supported by the JVM */ JNIEXPORT jobjectArray JNICALL Java_sun_management_VMManagementImpl_getDiagnosticCommandInfo (JNIEnv *env, jobject dummy, jobjectArray commands) { int i; jclass dcmdInfoCls; jobject result; jobjectArray args; jobject obj; jmmOptionalSupport mos; jint ret = jmm_interface->GetOptionalSupport(env, &mos); jboolean rdcmd_support = mos.isRemoteDiagnosticCommandsSupported; jsize num_commands; dcmdInfo* dcmd_info_array; if (rdcmd_support) { if (commands == NULL) { JNU_ThrowNullPointerException(env, "Invalid String Array"); return NULL; } num_commands = (*env)->GetArrayLength(env, commands); dcmd_info_array = (dcmdInfo*) malloc(num_commands * sizeof(dcmdInfo)); if (dcmd_info_array == NULL) { JNU_ThrowOutOfMemoryError(env, NULL); } jmm_interface->GetDiagnosticCommandInfo(env, commands, dcmd_info_array); dcmdInfoCls = (*env)->FindClass(env, "sun/management/DiagnosticCommandInfo"); result = (*env)->NewObjectArray(env, num_commands, dcmdInfoCls, NULL); if (result == NULL) { free(dcmd_info_array); JNU_ThrowOutOfMemoryError(env, 0); } for (i=0; iGetObjectArrayElement(env,commands,i), dcmd_info_array[i].num_arguments); if (args == NULL) { free(dcmd_info_array); JNU_ThrowOutOfMemoryError(env, 0); } obj = JNU_NewObjectByName(env, "sun/management/DiagnosticCommandInfo", "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZLjava/util/List;)V", (*env)->NewStringUTF(env,dcmd_info_array[i].name), (*env)->NewStringUTF(env,dcmd_info_array[i].description), (*env)->NewStringUTF(env,dcmd_info_array[i].impact), dcmd_info_array[i].permission_class==NULL?NULL:(*env)->NewStringUTF(env,dcmd_info_array[i].permission_class), dcmd_info_array[i].permission_name==NULL?NULL:(*env)->NewStringUTF(env,dcmd_info_array[i].permission_name), dcmd_info_array[i].permission_action==NULL?NULL:(*env)->NewStringUTF(env,dcmd_info_array[i].permission_action), dcmd_info_array[i].enabled, args); if (obj == NULL) { free(dcmd_info_array); JNU_ThrowOutOfMemoryError(env, 0); } (*env)->SetObjectArrayElement(env, result, i, obj); } free(dcmd_info_array); return result; } JNU_ThrowByName(env, "java/lang/UnsupportedOperationException", "JMX interface to diagnostic commands is not supported by this VM"); } /* Throws IllegalArgumentException if the diagnostic command * passed in argument is not supported by the JVM */ JNIEXPORT jstring JNICALL Java_sun_management_VMManagementImpl_executeDiagnosticCommand (JNIEnv *env, jobject dummy, jstring command) { jmmOptionalSupport mos; jint ret = jmm_interface->GetOptionalSupport(env, &mos); jboolean rdcmd_support = mos.isRemoteDiagnosticCommandsSupported; if (rdcmd_support) { return jmm_interface->ExecuteDiagnosticCommand(env, command); } JNU_ThrowByName(env, "java/lang/UnsupportedOperationException", "JMX interface to diagnostic commands is not supported by this VM"); }