/* * Copyright (C) 2008 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* * java.lang.Runtime */ #include "Dalvik.h" #include "native/InternalNativePriv.h" /* * public void gc() * * Initiate a gc. */ static void Dalvik_java_lang_Runtime_gc(const u4* args, JValue* pResult) { UNUSED_PARAMETER(args); dvmCollectGarbage(false); RETURN_VOID(); } /* * private static void nativeExit(int code, boolean isExit) * * Runtime.exit() calls this after doing shutdown processing. Runtime.halt() * uses this as well. */ static void Dalvik_java_lang_Runtime_nativeExit(const u4* args, JValue* pResult) { int status = args[0]; bool isExit = (args[1] != 0); if (isExit && gDvm.exitHook != NULL) { dvmChangeStatus(NULL, THREAD_NATIVE); (*gDvm.exitHook)(status); // not expected to return dvmChangeStatus(NULL, THREAD_RUNNING); LOGW("JNI exit hook returned\n"); } LOGD("Calling exit(%d)\n", status); exit(status); } /* * static boolean nativeLoad(String filename, ClassLoader loader) * * Load the specified full path as a dynamic library filled with * JNI-compatible methods. */ static void Dalvik_java_lang_Runtime_nativeLoad(const u4* args, JValue* pResult) { StringObject* fileNameObj = (StringObject*) args[0]; Object* classLoader = (Object*) args[1]; char* fileName; int result; if (fileNameObj == NULL) RETURN_INT(false); fileName = dvmCreateCstrFromString(fileNameObj); result = dvmLoadNativeCode(fileName, classLoader); free(fileName); RETURN_INT(result); } /* * public void runFinalization(boolean forced) * * Requests that the VM runs finalizers for objects on the heap. If the * parameter forced is true, then the VM needs to ensure finalization. * Otherwise this only inspires the VM to make a best-effort attempt to * run finalizers before returning, but it's not guaranteed to actually * do anything. */ static void Dalvik_java_lang_Runtime_runFinalization(const u4* args, JValue* pResult) { bool forced = (args[0] != 0); dvmWaitForHeapWorkerIdle(); if (forced) { // TODO(Google) Need to explicitly implement this, // although dvmWaitForHeapWorkerIdle() // should usually provide the "forced" // behavior already. } RETURN_VOID(); } /* * public void maxMemory() * * Returns GC heap max memory in bytes. */ static void Dalvik_java_lang_Runtime_maxMemory(const u4* args, JValue* pResult) { unsigned int result = gDvm.heapSizeMax; RETURN_LONG(result); } /* * public void totalMemory() * * Returns GC heap total memory in bytes. */ static void Dalvik_java_lang_Runtime_totalMemory(const u4* args, JValue* pResult) { int result = dvmGetHeapDebugInfo(kVirtualHeapSize); RETURN_LONG(result); } /* * public void freeMemory() * * Returns GC heap free memory in bytes. */ static void Dalvik_java_lang_Runtime_freeMemory(const u4* args, JValue* pResult) { int result = dvmGetHeapDebugInfo(kVirtualHeapSize) - dvmGetHeapDebugInfo(kVirtualHeapAllocated); if (result < 0) { result = 0; } RETURN_LONG(result); } const DalvikNativeMethod dvm_java_lang_Runtime[] = { { "freeMemory", "()J", Dalvik_java_lang_Runtime_freeMemory }, { "gc", "()V", Dalvik_java_lang_Runtime_gc }, { "maxMemory", "()J", Dalvik_java_lang_Runtime_maxMemory }, { "nativeExit", "(IZ)V", Dalvik_java_lang_Runtime_nativeExit }, { "nativeLoad", "(Ljava/lang/String;Ljava/lang/ClassLoader;)Z", Dalvik_java_lang_Runtime_nativeLoad }, { "runFinalization", "(Z)V", Dalvik_java_lang_Runtime_runFinalization }, { "totalMemory", "()J", Dalvik_java_lang_Runtime_totalMemory }, { NULL, NULL, NULL }, };