android_util_Process.cpp revision 422dd00fa31b6e9f12993eba44d4ae6ed8285882
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* //device/libs/android_runtime/android_util_Process.cpp 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** Copyright 2006, The Android Open Source Project 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** Licensed under the Apache License, Version 2.0 (the "License"); 669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** you may not use this file except in compliance with the License. 769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** You may obtain a copy of the License at 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** http://www.apache.org/licenses/LICENSE-2.0 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** 1169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** Unless required by applicable law or agreed to in writing, software 1269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** distributed under the License is distributed on an "AS IS" BASIS, 1369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes** See the License for the specific language governing permissions and 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project** limitations under the License. 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project*/ 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#define LOG_TAG "Process" 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 20cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen// To make sure cpu_set_t is included from sched.h 21cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen#define _GNU_SOURCE 1 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <utils/Log.h> 230795272aa226f4e965968a03daddc53ce30b7cdaMathias Agopian#include <binder/IPCThreadState.h> 240795272aa226f4e965968a03daddc53ce30b7cdaMathias Agopian#include <binder/IServiceManager.h> 25f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten#include <cutils/sched_policy.h> 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <utils/String8.h> 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <utils/Vector.h> 280769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross#include <processgroup/processgroup.h> 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 30ed6b9dff563c5e22f040ff37e12c0d771e0478aeAndreas Gampe#include "core_jni_helpers.h" 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include "android_util_Binder.h" 332279b2534272282a5b5152723235da397e49195cSteven Moreland#include <nativehelper/JNIHelp.h> 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <dirent.h> 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <fcntl.h> 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <grp.h> 38c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn#include <inttypes.h> 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <pwd.h> 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project#include <signal.h> 41c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn#include <sys/errno.h> 42c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn#include <sys/resource.h> 43c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn#include <sys/stat.h> 44c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn#include <sys/types.h> 456af763bec7c3f4d50fee8dd0046409bb8a7fe8f6Glenn Kasten#include <unistd.h> 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 47160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#define GUARD_THREAD_PRIORITY 0 48a5109a878eeff22e32ee5ce1b1cd15e8daad5234San Mehat 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectusing namespace android; 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 510f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampestatic const bool kDebugPolicy = false; 520f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampestatic const bool kDebugProc = false; 530f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe 54160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#if GUARD_THREAD_PRIORITY 55160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher TateMutex gKeyCreateMutex; 56160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tatestatic pthread_key_t gBgKey = -1; 57160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#endif 58160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate 59f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten// For both of these, err should be in the errno range (positive), not a status_t (negative) 604c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunkstatic void signalExceptionForError(JNIEnv* env, int err, int tid) { 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project switch (err) { 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case EINVAL: 634c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk jniThrowExceptionFmt(env, "java/lang/IllegalArgumentException", 644c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk "Invalid argument: %d", tid); 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case ESRCH: 674c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk jniThrowExceptionFmt(env, "java/lang/IllegalArgumentException", 684c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk "Given thread %d does not exist", tid); 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project case EPERM: 714c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk jniThrowExceptionFmt(env, "java/lang/SecurityException", 724c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk "No permission to modify given thread %d", tid); 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project default: 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jniThrowException(env, "java/lang/RuntimeException", "Unknown error"); 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 804c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunkstatic void signalExceptionForPriorityError(JNIEnv* env, int err, int tid) { 81e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat switch (err) { 824c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk case EACCES: 834c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk jniThrowExceptionFmt(env, "java/lang/SecurityException", 844c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk "No permission to set the priority of %d", tid); 85e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat break; 864c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk default: 874c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForError(env, err, tid); 88e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat break; 894c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk } 904c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk 914c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk} 924c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk 934c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunkstatic void signalExceptionForGroupError(JNIEnv* env, int err, int tid) { 944c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk switch (err) { 95e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat case EACCES: 964c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk jniThrowExceptionFmt(env, "java/lang/SecurityException", 974c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk "No permission to set the group of %d", tid); 98e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat break; 99e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat default: 1004c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForError(env, err, tid); 101e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat break; 102e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat } 103e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat} 104e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectjint android_os_Process_getUidForName(JNIEnv* env, jobject clazz, jstring name) 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (name == NULL) { 10869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jchar* str16 = env->GetStringCritical(name, 0); 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String8 name8; 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str16) { 1156698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert name8 = String8(reinterpret_cast<const char16_t*>(str16), 1166698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert env->GetStringLength(name)); 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringCritical(name, str16); 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const size_t N = name8.size(); 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (N > 0) { 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* str = name8.string(); 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (size_t i=0; i<N; i++) { 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str[i] < '0' || str[i] > '9') { 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project struct passwd* pwd = getpwnam(str); 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (pwd == NULL) { 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pwd->pw_uid; 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return atoi(str); 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectjint android_os_Process_getGidForName(JNIEnv* env, jobject clazz, jstring name) 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (name == NULL) { 14069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 14369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jchar* str16 = env->GetStringCritical(name, 0); 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String8 name8; 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str16) { 1476698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert name8 = String8(reinterpret_cast<const char16_t*>(str16), 1486698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert env->GetStringLength(name)); 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringCritical(name, str16); 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const size_t N = name8.size(); 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (N > 0) { 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* str = name8.string(); 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (size_t i=0; i<N; i++) { 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str[i] < '0' || str[i] > '9') { 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project struct group* grp = getgrnam(str); 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (grp == NULL) { 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return grp->gr_gid; 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return atoi(str); 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 169f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kastenvoid android_os_Process_setThreadGroup(JNIEnv* env, jobject clazz, int tid, jint grp) 170e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat{ 171c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn ALOGV("%s tid=%d grp=%" PRId32, __func__, tid, grp); 172f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten SchedPolicy sp = (SchedPolicy) grp; 173f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten int res = set_sched_policy(tid, sp); 174887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn if (res != NO_ERROR) { 1754c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, -res, tid); 176e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat } 177e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat} 178e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat 1792d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandesvoid android_os_Process_setThreadGroupAndCpuset(JNIEnv* env, jobject clazz, int tid, jint grp) 1802d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes{ 1812d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes ALOGV("%s tid=%d grp=%" PRId32, __func__, tid, grp); 1822d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes SchedPolicy sp = (SchedPolicy) grp; 1832d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes int res = set_sched_policy(tid, sp); 1842d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes 1852d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes if (res != NO_ERROR) { 1862d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes signalExceptionForGroupError(env, -res, tid); 1872d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes } 1882d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes 1892d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes res = set_cpuset_policy(tid, sp); 1902d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes if (res != NO_ERROR) { 1912d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes signalExceptionForGroupError(env, -res, tid); 1922d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes } 1932d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes} 1942d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes 19569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughesvoid android_os_Process_setProcessGroup(JNIEnv* env, jobject clazz, int pid, jint grp) 1963e458241d9930465a20a861ecb42744355d48e48San Mehat{ 197c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn ALOGV("%s pid=%d grp=%" PRId32, __func__, pid, grp); 1983e458241d9930465a20a861ecb42744355d48e48San Mehat DIR *d; 1993e458241d9930465a20a861ecb42744355d48e48San Mehat char proc_path[255]; 2003e458241d9930465a20a861ecb42744355d48e48San Mehat struct dirent *de; 2013e458241d9930465a20a861ecb42744355d48e48San Mehat 202f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten if ((grp == SP_FOREGROUND) || (grp > SP_MAX)) { 2034c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, EINVAL, pid); 2043e458241d9930465a20a861ecb42744355d48e48San Mehat return; 2053e458241d9930465a20a861ecb42744355d48e48San Mehat } 2063e458241d9930465a20a861ecb42744355d48e48San Mehat 207f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten bool isDefault = false; 208f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten if (grp < 0) { 209f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten grp = SP_FOREGROUND; 210f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten isDefault = true; 211f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten } 212f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten SchedPolicy sp = (SchedPolicy) grp; 213f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten 2140f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (kDebugPolicy) { 2150f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe char cmdline[32]; 2160f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe int fd; 217a5109a878eeff22e32ee5ce1b1cd15e8daad5234San Mehat 2180f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe strcpy(cmdline, "unknown"); 219a5109a878eeff22e32ee5ce1b1cd15e8daad5234San Mehat 2200f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe sprintf(proc_path, "/proc/%d/cmdline", pid); 221422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich fd = open(proc_path, O_RDONLY | O_CLOEXEC); 2220f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (fd >= 0) { 2230f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe int rc = read(fd, cmdline, sizeof(cmdline)-1); 2240f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe cmdline[rc] = 0; 2250f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe close(fd); 2260f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } 22769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 2280f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (sp == SP_BACKGROUND) { 2290f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe ALOGD("setProcessGroup: vvv pid %d (%s)", pid, cmdline); 2300f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } else { 2310f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe ALOGD("setProcessGroup: ^^^ pid %d (%s)", pid, cmdline); 2320f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } 233a5109a878eeff22e32ee5ce1b1cd15e8daad5234San Mehat } 2340f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe 2353e458241d9930465a20a861ecb42744355d48e48San Mehat sprintf(proc_path, "/proc/%d/task", pid); 2363e458241d9930465a20a861ecb42744355d48e48San Mehat if (!(d = opendir(proc_path))) { 2371fd0ec738b0a2b97cc28701aa37b1a9869afc684San Mehat // If the process exited on us, don't generate an exception 2381fd0ec738b0a2b97cc28701aa37b1a9869afc684San Mehat if (errno != ENOENT) 2394c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, errno, pid); 2403e458241d9930465a20a861ecb42744355d48e48San Mehat return; 2413e458241d9930465a20a861ecb42744355d48e48San Mehat } 2423e458241d9930465a20a861ecb42744355d48e48San Mehat 2433e458241d9930465a20a861ecb42744355d48e48San Mehat while ((de = readdir(d))) { 2447e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat int t_pid; 2457e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat int t_pri; 2467e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat 2473e458241d9930465a20a861ecb42744355d48e48San Mehat if (de->d_name[0] == '.') 2483e458241d9930465a20a861ecb42744355d48e48San Mehat continue; 2497e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat t_pid = atoi(de->d_name); 2507e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat 2517e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat if (!t_pid) { 2523762c311729fe9f3af085c14c5c1fb471d994c03Steve Block ALOGE("Error getting pid for '%s'\n", de->d_name); 2537e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat continue; 2547e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat } 2551fd0ec738b0a2b97cc28701aa37b1a9869afc684San Mehat 25607b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten t_pri = getpriority(PRIO_PROCESS, t_pid); 25707b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten 25807b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten if (t_pri <= ANDROID_PRIORITY_AUDIO) { 25920375fe124b4bc54a2380396fd798f93fcdb3135Tim Murray int scheduler = sched_getscheduler(t_pid) & ~SCHED_RESET_ON_FORK; 26007b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten if ((scheduler == SCHED_FIFO) || (scheduler == SCHED_RR)) { 2619e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray // This task wants to stay in its current audio group so it can keep its budget 2629e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray // don't update its cpuset or cgroup 26307b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten continue; 26407b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten } 26507b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten } 2667e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat 26707b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten if (isDefault) { 268f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten if (t_pri >= ANDROID_PRIORITY_BACKGROUND) { 269f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten // This task wants to stay at background 2709e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray // update its cpuset so it doesn't only run on bg core(s) 271d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if (cpusets_enabled()) { 272d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen int err = set_cpuset_policy(t_pid, sp); 273d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if (err != NO_ERROR) { 274d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen signalExceptionForGroupError(env, -err, t_pid); 275d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen break; 276d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen } 2779e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray } 278f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten continue; 279f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten } 2807e63789a0e0689d940609b1daceebc1bc08dcbefSan Mehat } 2819e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray int err; 282d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen 283d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if (cpusets_enabled()) { 284d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen // set both cpuset and cgroup for general threads 285d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen err = set_cpuset_policy(t_pid, sp); 286d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if (err != NO_ERROR) { 287d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen signalExceptionForGroupError(env, -err, t_pid); 288d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen break; 289d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen } 2909e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray } 29169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 2929e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray err = set_sched_policy(t_pid, sp); 293f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten if (err != NO_ERROR) { 2944c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, -err, t_pid); 2950a42b811aea490a9a605b75f0320101f6eafd283San Mehat break; 296242d65bf9faf1d2bc3468490e510551140e23462San Mehat } 2979e41c7479ccaedb89a89a58079570ca0ee0e3727Tim Murray 2983e458241d9930465a20a861ecb42744355d48e48San Mehat } 2993e458241d9930465a20a861ecb42744355d48e48San Mehat closedir(d); 3003e458241d9930465a20a861ecb42744355d48e48San Mehat} 3013e458241d9930465a20a861ecb42744355d48e48San Mehat 3029e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkeyjint android_os_Process_getProcessGroup(JNIEnv* env, jobject clazz, jint pid) 3039e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey{ 3049e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey SchedPolicy sp; 3059e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey if (get_sched_policy(pid, &sp) != 0) { 3064c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, errno, pid); 3079e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey } 3089e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey return (int) sp; 3099e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey} 3109e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey 311cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen/** Sample CPUset list format: 312cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * 0-3,4,6-8 313cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen */ 314cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenenstatic void parse_cpuset_cpus(char *cpus, cpu_set_t *cpu_set) { 315cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen unsigned int start, end, matched, i; 316cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen char *cpu_range = strtok(cpus, ","); 317cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen while (cpu_range != NULL) { 318cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen start = end = 0; 319cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen matched = sscanf(cpu_range, "%u-%u", &start, &end); 320cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen cpu_range = strtok(NULL, ","); 321cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (start >= CPU_SETSIZE) { 322cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen ALOGE("parse_cpuset_cpus: ignoring CPU number larger than %d.", CPU_SETSIZE); 323cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen continue; 324cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } else if (end >= CPU_SETSIZE) { 325cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen ALOGE("parse_cpuset_cpus: ignoring CPU numbers larger than %d.", CPU_SETSIZE); 326cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen end = CPU_SETSIZE - 1; 327cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 328cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (matched == 1) { 329cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen CPU_SET(start, cpu_set); 330cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } else if (matched == 2) { 331cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen for (i = start; i <= end; i++) { 332cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen CPU_SET(i, cpu_set); 333cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 334cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } else { 335cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen ALOGE("Failed to match cpus"); 336cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 337cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 338cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return; 339cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen} 340cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 341cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen/** 342cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * Stores the CPUs assigned to the cpuset corresponding to the 343cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * SchedPolicy in the passed in cpu_set. 344cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen */ 345cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenenstatic void get_cpuset_cores_for_policy(SchedPolicy policy, cpu_set_t *cpu_set) 346cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen{ 347cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen FILE *file; 348cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen const char *filename; 349cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 350cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen CPU_ZERO(cpu_set); 351cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 352cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen switch (policy) { 353cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen case SP_BACKGROUND: 354cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen filename = "/dev/cpuset/background/cpus"; 355cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen break; 356cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen case SP_FOREGROUND: 357cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen case SP_AUDIO_APP: 358cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen case SP_AUDIO_SYS: 359cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen filename = "/dev/cpuset/foreground/cpus"; 360cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen break; 361cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen case SP_TOP_APP: 362cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen filename = "/dev/cpuset/top-app/cpus"; 363cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen break; 364cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen default: 365cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen filename = NULL; 366cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 367cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 368cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (!filename) return; 369cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 370cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen file = fopen(filename, "re"); 371cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (file != NULL) { 372cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen // Parse cpus string 373cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen char *line = NULL; 374cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen size_t len = 0; 375cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen ssize_t num_read = getline(&line, &len, file); 376cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen fclose (file); 377cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (num_read > 0) { 378cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen parse_cpuset_cpus(line, cpu_set); 379cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } else { 380cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen ALOGE("Failed to read %s", filename); 381cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 382cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen free(line); 383cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 384cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return; 385cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen} 386cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 387cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 388cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen/** 389cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * Determine CPU cores exclusively assigned to the 390cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * cpuset corresponding to the SchedPolicy and store 391cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen * them in the passed in cpu_set_t 392cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen */ 393cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenenvoid get_exclusive_cpuset_cores(SchedPolicy policy, cpu_set_t *cpu_set) { 394d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if (cpusets_enabled()) { 395d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen int i; 396d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen cpu_set_t tmp_set; 397d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen get_cpuset_cores_for_policy(policy, cpu_set); 398d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen for (i = 0; i < SP_CNT; i++) { 399d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen if ((SchedPolicy) i == policy) continue; 400d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen get_cpuset_cores_for_policy((SchedPolicy)i, &tmp_set); 401d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen // First get cores exclusive to one set or the other 402d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen CPU_XOR(&tmp_set, cpu_set, &tmp_set); 403d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen // Then get the ones only in cpu_set 404d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen CPU_AND(cpu_set, cpu_set, &tmp_set); 405d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen } 406d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen } else { 407d34fac541a5a541b4207ee9cdbcc5005b5fa848cIsaac Chen CPU_ZERO(cpu_set); 408cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 409cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return; 410cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen} 411cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 412cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn CoenenjintArray android_os_Process_getExclusiveCores(JNIEnv* env, jobject clazz) { 413cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen SchedPolicy sp; 414cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen cpu_set_t cpu_set; 415cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen jintArray cpus; 416cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen int pid = getpid(); 417cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (get_sched_policy(pid, &sp) != 0) { 4184c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, errno, pid); 419cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return NULL; 420cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 421cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen get_exclusive_cpuset_cores(sp, &cpu_set); 422cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen int num_cpus = CPU_COUNT(&cpu_set); 423cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen cpus = env->NewIntArray(num_cpus); 424cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (cpus == NULL) { 425cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 426cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return NULL; 427cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 428cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 429cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen jint* cpu_elements = env->GetIntArrayElements(cpus, 0); 430cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen int count = 0; 431cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen for (int i = 0; i < CPU_SETSIZE && count < num_cpus; i++) { 432cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen if (CPU_ISSET(i, &cpu_set)) { 433cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen cpu_elements[count++] = i; 434cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 435cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen } 436cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 437cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen env->ReleaseIntArrayElements(cpus, cpu_elements, 0); 438cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen return cpus; 439cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen} 440cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen 441160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tatestatic void android_os_Process_setCanSelfBackground(JNIEnv* env, jobject clazz, jboolean bgOk) { 442160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate // Establishes the calling thread as illegal to put into the background. 443160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate // Typically used only for the system process's main looper. 444160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#if GUARD_THREAD_PRIORITY 44506451fe081d5ae79121a6f301475c7042f7f3a5dElliott Hughes ALOGV("Process.setCanSelfBackground(%d) : tid=%d", bgOk, gettid()); 446160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate { 447160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate Mutex::Autolock _l(gKeyCreateMutex); 448160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate if (gBgKey == -1) { 449160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate pthread_key_create(&gBgKey, NULL); 450160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate } 451160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate } 452160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate 453160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate // inverted: not-okay, we set a sentinel value 454160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate pthread_setspecific(gBgKey, (void*)(bgOk ? 0 : 0xbaad)); 455160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#endif 456160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate} 457160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate 4581b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharanjint android_os_Process_getThreadScheduler(JNIEnv* env, jclass clazz, 4591b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan jint tid) 4601b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan{ 4611b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan int policy = 0; 4621b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan// linux has sched_getscheduler(), others don't. 4631b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan#if defined(__linux__) 4641b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan errno = 0; 4651b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan policy = sched_getscheduler(tid); 4661b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan if (errno != 0) { 4674c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, errno, tid); 4681b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan } 4691b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan#else 4704c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, ENOSYS, tid); 4711b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan#endif 4721b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan return policy; 4731b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan} 4741b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan 4756793ac943afeb16642f477c43ddfd27e498db37bGlenn Kastenvoid android_os_Process_setThreadScheduler(JNIEnv* env, jclass clazz, 4766793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten jint tid, jint policy, jint pri) 4776793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten{ 47865b4a68669227a57696e0e7ed1e4ef8da2705d9eYabin Cui// linux has sched_setscheduler(), others don't. 47965b4a68669227a57696e0e7ed1e4ef8da2705d9eYabin Cui#if defined(__linux__) 4806793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten struct sched_param param; 4816793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten param.sched_priority = pri; 4826793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten int rc = sched_setscheduler(tid, policy, ¶m); 4836793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten if (rc) { 4844c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, errno, tid); 4856793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten } 486cc767191cfb675f744e0165608b0a4196aba2b37Glenn Kasten#else 4874c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, ENOSYS, tid); 488cc767191cfb675f744e0165608b0a4196aba2b37Glenn Kasten#endif 4896793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten} 4906793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_setThreadPriority(JNIEnv* env, jobject clazz, 4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint pid, jint pri) 4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 494160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#if GUARD_THREAD_PRIORITY 495160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate // if we're putting the current thread into the background, check the TLS 496160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate // to make sure this thread isn't guarded. If it is, raise an exception. 497160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate if (pri >= ANDROID_PRIORITY_BACKGROUND) { 49806451fe081d5ae79121a6f301475c7042f7f3a5dElliott Hughes if (pid == gettid()) { 499160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate void* bgOk = pthread_getspecific(gBgKey); 500160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate if (bgOk == ((void*)0xbaad)) { 5013762c311729fe9f3af085c14c5c1fb471d994c03Steve Block ALOGE("Thread marked fg-only put self in background!"); 502160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate jniThrowException(env, "java/lang/SecurityException", "May not put this thread into background"); 503160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate return; 504160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate } 505160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate } 506160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate } 507160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate#endif 508160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate 509887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn int rc = androidSetThreadPriority(pid, pri); 510887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn if (rc != 0) { 511887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn if (rc == INVALID_OPERATION) { 5124c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, errno, pid); 513887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn } else { 5144c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForGroupError(env, errno, pid); 515887f355f99ff83d568ef2885a4fdcaae475583dfDianne Hackborn } 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 51769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 518c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Setting priority of %" PRId32 ": %" PRId32 ", getpriority returns %d\n", 5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // pid, pri, getpriority(PRIO_PROCESS, pid)); 5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_setCallingThreadPriority(JNIEnv* env, jobject clazz, 5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint pri) 5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 52506451fe081d5ae79121a6f301475c7042f7f3a5dElliott Hughes android_os_Process_setThreadPriority(env, clazz, gettid(), pri); 5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectjint android_os_Process_getThreadPriority(JNIEnv* env, jobject clazz, 5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint pid) 5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project errno = 0; 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint pri = getpriority(PRIO_PROCESS, pid); 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (errno != 0) { 5344c0c4df7cfa0b4228ef547aa940674393cb2ab77Ruben Brunk signalExceptionForPriorityError(env, errno, pid); 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 536c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Returning priority of %" PRId32 ": %" PRId32 "\n", pid, pri); 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pri; 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5405534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchandjboolean android_os_Process_setSwappiness(JNIEnv *env, jobject clazz, 5415534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand jint pid, jboolean is_increased) 5425534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand{ 5435534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand char text[64]; 5445534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand 5455534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand if (is_increased) { 5465534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand strcpy(text, "/sys/fs/cgroup/memory/sw/tasks"); 5475534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand } else { 5485534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand strcpy(text, "/sys/fs/cgroup/memory/tasks"); 5495534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand } 5505534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand 5515534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand struct stat st; 5525534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand if (stat(text, &st) || !S_ISREG(st.st_mode)) { 5535534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand return false; 5545534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand } 5555534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand 556422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich int fd = open(text, O_WRONLY | O_CLOEXEC); 5575534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand if (fd >= 0) { 558c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn sprintf(text, "%" PRId32, pid); 5595534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand write(fd, text, strlen(text)); 5605534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand close(fd); 5615534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand } 5625534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand 5635534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand return true; 5645534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand} 5655534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand 5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_setArgV0(JNIEnv* env, jobject clazz, jstring name) 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (name == NULL) { 56969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 57269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jchar* str = env->GetStringCritical(name, 0); 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String8 name8; 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str) { 5766698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert name8 = String8(reinterpret_cast<const char16_t*>(str), 5776698749dd4d4d6513b26aa9071af290b956b68a7Dan Albert env->GetStringLength(name)); 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringCritical(name, str); 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 581342c7dcd022746c25dc202230a6a9390c403062fDmitriy Filchenko if (!name8.isEmpty()) { 582f5b6e5590e0a2c1be10bc0bd0a3b141256fdf7fdDmitriy Filchenko AndroidRuntime::getRuntime()->setArgv0(name8.string(), true /* setProcName */); 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectjint android_os_Process_setUid(JNIEnv* env, jobject clazz, jint uid) 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return setuid(uid) == 0 ? 0 : errno; 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectjint android_os_Process_setGid(JNIEnv* env, jobject clazz, jint uid) 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return setgid(uid) == 0 ? 0 : errno; 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectstatic int pid_compare(const void* v1, const void* v2) 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 598c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Compare %" PRId32 " vs %" PRId32 "\n", *((const jint*)v1), *((const jint*)v2)); 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return *((const jint*)v1) - *((const jint*)v2); 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 602c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughesstatic jlong getFreeMemoryImpl(const char* const sums[], const size_t sumsLen[], size_t num) 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 604422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich int fd = open("/proc/meminfo", O_RDONLY | O_CLOEXEC); 60569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (fd < 0) { 6078564c8da817a845353d213acd8636b76f567b234Steve Block ALOGW("Unable to open /proc/meminfo"); 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 61069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char buffer[256]; 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const int len = read(fd, buffer, sizeof(buffer)-1); 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project close(fd); 61469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (len < 0) { 6168564c8da817a845353d213acd8636b76f567b234Steve Block ALOGW("Unable to read /proc/meminfo"); 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return -1; 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer[len] = 0; 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 621c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes size_t numFound = 0; 6220bca96bcbfe559f9330a01f723c5c9cba51ec05aMarco Nelissen jlong mem = 0; 62369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* p = buffer; 62559325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn while (*p && numFound < num) { 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int i = 0; 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (sums[i]) { 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (strncmp(p, sums[i], sumsLen[i]) == 0) { 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p += sumsLen[i]; 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p == ' ') p++; 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* num = p; 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p >= '0' && *p <= '9') p++; 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p != 0) { 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *p = 0; 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p == 0) p--; 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6380bca96bcbfe559f9330a01f723c5c9cba51ec05aMarco Nelissen mem += atoll(num) * 1024; 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project numFound++; 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 64669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return numFound > 0 ? mem : -1; 6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 65059325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackbornstatic jlong android_os_Process_getFreeMemory(JNIEnv* env, jobject clazz) 65159325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn{ 65259325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn static const char* const sums[] = { "MemFree:", "Cached:", NULL }; 653c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes static const size_t sumsLen[] = { strlen("MemFree:"), strlen("Cached:"), 0 }; 65459325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn return getFreeMemoryImpl(sums, sumsLen, 2); 65559325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn} 65659325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn 65759325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackbornstatic jlong android_os_Process_getTotalMemory(JNIEnv* env, jobject clazz) 65859325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn{ 65959325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn static const char* const sums[] = { "MemTotal:", NULL }; 660c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes static const size_t sumsLen[] = { strlen("MemTotal:"), 0 }; 66159325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn return getFreeMemoryImpl(sums, sumsLen, 1); 66259325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn} 66359325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn 6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_readProcLines(JNIEnv* env, jobject clazz, jstring fileStr, 6659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jobjectArray reqFields, jlongArray outFields) 6669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 6676215d3ff4b5dfa52a5d8b9a42e343051f31066a5Steve Block //ALOGI("getMemInfo: %p %p", reqFields, outFields); 66869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (fileStr == NULL || reqFields == NULL || outFields == NULL) { 67069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 67369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* file8 = env->GetStringUTFChars(fileStr, NULL); 6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (file8 == NULL) { 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String8 file(file8); 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringUTFChars(fileStr, file8); 68069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jsize count = env->GetArrayLength(reqFields); 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (count > env->GetArrayLength(outFields)) { 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jniThrowException(env, "java/lang/IllegalArgumentException", "Array lengths differ"); 6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 68669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Vector<String8> fields; 6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int i; 68969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (i=0; i<count; i++) { 6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jobject obj = env->GetObjectArrayElement(reqFields, i); 6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (obj != NULL) { 6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* str8 = env->GetStringUTFChars((jstring)obj, NULL); 6946215d3ff4b5dfa52a5d8b9a42e343051f31066a5Steve Block //ALOGI("String at %d: %p = %s", i, obj, str8); 6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (str8 == NULL) { 69669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, "Element in reqFields"); 6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project fields.add(String8(str8)); 7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringUTFChars((jstring)obj, str8); 7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 70269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, "Element in reqFields"); 7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 70669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jlong* sizesArray = env->GetLongArrayElements(outFields, 0); 7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (sizesArray == NULL) { 7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 71169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 712c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Clearing %" PRId32 " sizes", count); 7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (i=0; i<count; i++) { 7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sizesArray[i] = 0; 7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 71669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 717422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich int fd = open(file.string(), O_RDONLY | O_CLOEXEC); 71869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (fd >= 0) { 7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const size_t BUFFER_SIZE = 2048; 7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* buffer = (char*)malloc(BUFFER_SIZE); 7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int len = read(fd, buffer, BUFFER_SIZE-1); 7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project close(fd); 72469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (len < 0) { 7268564c8da817a845353d213acd8636b76f567b234Steve Block ALOGW("Unable to read %s", file.string()); 7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project len = 0; 7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer[len] = 0; 73069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int foundCount = 0; 73269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* p = buffer; 7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p && foundCount < count) { 7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project bool skipToEol = true; 7366215d3ff4b5dfa52a5d8b9a42e343051f31066a5Steve Block //ALOGI("Parsing at: %s", p); 7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (i=0; i<count; i++) { 7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const String8& field = fields[i]; 7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (strncmp(p, field.string(), field.length()) == 0) { 7409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p += field.length(); 741add868cebaf62cffe96e79764ea0b7f2320a03ebAmith Yamasani while (*p == ' ' || *p == '\t') p++; 7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* num = p; 7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p >= '0' && *p <= '9') p++; 7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project skipToEol = *p != '\n'; 7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p != 0) { 7469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *p = 0; 7479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* end; 7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sizesArray[i] = strtoll(num, &end, 10); 751c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Field %s = %" PRId64, field.string(), sizesArray[i]); 7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project foundCount++; 7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (skipToEol) { 7579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p && *p != '\n') { 7589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 7599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p == '\n') { 7619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 7629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 76569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project free(buffer); 7679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 7688564c8da817a845353d213acd8636b76f567b234Steve Block ALOGW("Unable to open %s", file.string()); 7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 77069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7716215d3ff4b5dfa52a5d8b9a42e343051f31066a5Steve Block //ALOGI("Done!"); 7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseLongArrayElements(outFields, sizesArray, 0); 7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectjintArray android_os_Process_getPids(JNIEnv* env, jobject clazz, 7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jstring file, jintArray lastArray) 7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (file == NULL) { 77969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return NULL; 7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 78269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* file8 = env->GetStringUTFChars(file, NULL); 7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (file8 == NULL) { 7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return NULL; 7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 78869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project DIR* dirp = opendir(file8); 79069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseStringUTFChars(file, file8); 79269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if(dirp == NULL) { 7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return NULL; 7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 79669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jsize curCount = 0; 7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint* curData = NULL; 7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (lastArray != NULL) { 8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curCount = env->GetArrayLength(lastArray); 8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curData = env->GetIntArrayElements(lastArray, 0); 8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 80369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint curPos = 0; 80569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project struct dirent* entry; 8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while ((entry=readdir(dirp)) != NULL) { 8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char* p = entry->d_name; 8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (*p) { 8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p < '0' || *p > '9') break; 8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project p++; 8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (*p != 0) continue; 81469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* end; 8169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int pid = strtol(entry->d_name, &end, 10); 8176215d3ff4b5dfa52a5d8b9a42e343051f31066a5Steve Block //ALOGI("File %s pid=%d\n", entry->d_name, pid); 8189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (curPos >= curCount) { 8199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jsize newCount = (curCount == 0) ? 10 : (curCount*2); 8209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jintArray newArray = env->NewIntArray(newCount); 8219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (newArray == NULL) { 8229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project closedir(dirp); 8239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 8249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return NULL; 8259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint* newData = env->GetIntArrayElements(newArray, 0); 8279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (curData != NULL) { 8289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project memcpy(newData, curData, sizeof(jint)*curCount); 8299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseIntArrayElements(lastArray, curData, 0); 8309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project lastArray = newArray; 8329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curCount = newCount; 8339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curData = newData; 8349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 83569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curData[curPos] = pid; 8379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curPos++; 8389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 83969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project closedir(dirp); 84169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (curData != NULL && curPos > 0) { 8439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project qsort(curData, curPos, sizeof(jint), pid_compare); 8449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 84569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (curPos < curCount) { 8479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curData[curPos] = -1; 8489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project curPos++; 8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 85069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (curData != NULL) { 8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseIntArrayElements(lastArray, curData, 0); 8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 85469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return lastArray; 8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectenum { 8599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_TERM_MASK = 0xff, 8609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_ZERO_TERM = 0, 8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_SPACE_TERM = ' ', 8629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_COMBINE = 0x100, 8639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_PARENS = 0x200, 86413ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn PROC_QUOTES = 0x400, 8654de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn PROC_CHAR = 0x800, 8669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_OUT_STRING = 0x1000, 8679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_OUT_LONG = 0x2000, 8689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project PROC_OUT_FLOAT = 0x4000, 8699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}; 8709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 871c64edde69d18498fb2954f71a546357b07ab996aEvan Millarjboolean android_os_Process_parseProcLineArray(JNIEnv* env, jobject clazz, 87269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes char* buffer, jint startIndex, jint endIndex, jintArray format, 873c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jobjectArray outStrings, jlongArray outLongs, jfloatArray outFloats) 8749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 87569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jsize NF = env->GetArrayLength(format); 8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jsize NS = outStrings ? env->GetArrayLength(outStrings) : 0; 8789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jsize NL = outLongs ? env->GetArrayLength(outLongs) : 0; 8799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jsize NR = outFloats ? env->GetArrayLength(outFloats) : 0; 88069a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 8819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jint* formatData = env->GetIntArrayElements(format, 0); 8829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jlong* longsData = outLongs ? 8839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->GetLongArrayElements(outLongs, 0) : NULL; 8849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jfloat* floatsData = outFloats ? 8859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->GetFloatArrayElements(outFloats, 0) : NULL; 8869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (formatData == NULL || (NL > 0 && longsData == NULL) 8879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project || (NR > 0 && floatsData == NULL)) { 8889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (formatData != NULL) { 8899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseIntArrayElements(format, formatData, 0); 8909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (longsData != NULL) { 8929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseLongArrayElements(outLongs, longsData, 0); 8939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (floatsData != NULL) { 8959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseFloatArrayElements(outFloats, floatsData, 0); 8969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return JNI_FALSE; 8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 901c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jsize i = startIndex; 9029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jsize di = 0; 90369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jboolean res = JNI_TRUE; 90569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (jsize fi=0; fi<NF; fi++) { 90713ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn jint mode = formatData[fi]; 9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_PARENS) != 0) { 9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 9103b1e22e2898e27fe486ac4137692e0f20166e13eBernhard Rosenkränzer } else if ((mode&PROC_QUOTES) != 0) { 91113ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn if (buffer[i] == '"') { 91213ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn i++; 91313ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn } else { 91413ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn mode &= ~PROC_QUOTES; 91513ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn } 9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const char term = (char)(mode&PROC_TERM_MASK); 9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project const jsize start = i; 919c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (i >= endIndex) { 9200f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (kDebugProc) { 9210f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe ALOGW("Ran off end of data @%d", i); 9220f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } 9239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project res = JNI_FALSE; 9249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 9259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 92669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jsize end = -1; 9289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_PARENS) != 0) { 929c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes while (i < endIndex && buffer[i] != ')') { 9309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 9319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project end = i; 9339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 93413ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn } else if ((mode&PROC_QUOTES) != 0) { 93513ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn while (buffer[i] != '"' && i < endIndex) { 93613ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn i++; 93713ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn } 93813ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn end = i; 93913ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn i++; 9409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 941c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes while (i < endIndex && buffer[i] != term) { 9429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 9439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (end < 0) { 9459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project end = i; 9469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 94769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 948c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (i < endIndex) { 9499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 9509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_COMBINE) != 0) { 951c367d48c55e5a3fa0df14fd62889e4bb6b63cb01Elliott Hughes while (i < endIndex && buffer[i] == term) { 9529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project i++; 9539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 95669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 957c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn //ALOGI("Field %" PRId32 ": %" PRId32 "-%" PRId32 " dest=%" PRId32 " mode=0x%" PRIx32 "\n", i, start, end, di, mode); 95869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&(PROC_OUT_FLOAT|PROC_OUT_LONG|PROC_OUT_STRING)) != 0) { 9609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char c = buffer[end]; 9619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer[end] = 0; 9629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_OUT_FLOAT) != 0 && di < NR) { 9639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char* end; 9649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project floatsData[di] = strtof(buffer+start, &end); 9659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_OUT_LONG) != 0 && di < NL) { 9674de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn if ((mode&PROC_CHAR) != 0) { 9684de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn // Caller wants single first character returned as one long. 9694de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn longsData[di] = buffer[start]; 9704de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn } else { 9714de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn char* end; 9724de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn longsData[di] = strtoll(buffer+start, &end, 10); 9734de5a3ac6655f76b67af38712ae5aeb6d7c15938Dianne Hackborn } 9749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mode&PROC_OUT_STRING) != 0 && di < NS) { 9769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jstring str = env->NewStringUTF(buffer+start); 9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->SetObjectArrayElement(outStrings, di, str); 9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer[end] = c; 9809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project di++; 9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 98369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseIntArrayElements(format, formatData, 0); 9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (longsData != NULL) { 9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseLongArrayElements(outLongs, longsData, 0); 9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (floatsData != NULL) { 9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project env->ReleaseFloatArrayElements(outFloats, floatsData, 0); 9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 99169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return res; 9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 995c64edde69d18498fb2954f71a546357b07ab996aEvan Millarjboolean android_os_Process_parseProcLine(JNIEnv* env, jobject clazz, 99669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jbyteArray buffer, jint startIndex, jint endIndex, jintArray format, 997c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jobjectArray outStrings, jlongArray outLongs, jfloatArray outFloats) 998c64edde69d18498fb2954f71a546357b07ab996aEvan Millar{ 999c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jbyte* bufferArray = env->GetByteArrayElements(buffer, NULL); 1000c64edde69d18498fb2954f71a546357b07ab996aEvan Millar 100169a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jboolean result = android_os_Process_parseProcLineArray(env, clazz, 100269a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes (char*) bufferArray, startIndex, endIndex, format, outStrings, 1003c64edde69d18498fb2954f71a546357b07ab996aEvan Millar outLongs, outFloats); 100469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1005c64edde69d18498fb2954f71a546357b07ab996aEvan Millar env->ReleaseByteArrayElements(buffer, bufferArray, 0); 100669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1007c64edde69d18498fb2954f71a546357b07ab996aEvan Millar return result; 1008c64edde69d18498fb2954f71a546357b07ab996aEvan Millar} 1009c64edde69d18498fb2954f71a546357b07ab996aEvan Millar 1010c64edde69d18498fb2954f71a546357b07ab996aEvan Millarjboolean android_os_Process_readProcFile(JNIEnv* env, jobject clazz, 1011c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jstring file, jintArray format, jobjectArray outStrings, 1012c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jlongArray outLongs, jfloatArray outFloats) 1013c64edde69d18498fb2954f71a546357b07ab996aEvan Millar{ 1014c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (file == NULL || format == NULL) { 101569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 1016c64edde69d18498fb2954f71a546357b07ab996aEvan Millar return JNI_FALSE; 1017c64edde69d18498fb2954f71a546357b07ab996aEvan Millar } 1018c64edde69d18498fb2954f71a546357b07ab996aEvan Millar 1019c64edde69d18498fb2954f71a546357b07ab996aEvan Millar const char* file8 = env->GetStringUTFChars(file, NULL); 1020c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (file8 == NULL) { 1021c64edde69d18498fb2954f71a546357b07ab996aEvan Millar jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 1022c64edde69d18498fb2954f71a546357b07ab996aEvan Millar return JNI_FALSE; 1023c64edde69d18498fb2954f71a546357b07ab996aEvan Millar } 1024422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich int fd = open(file8, O_RDONLY | O_CLOEXEC); 102569a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1026c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (fd < 0) { 10270f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (kDebugProc) { 10280f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe ALOGW("Unable to open process file: %s\n", file8); 10290f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } 1030306af678a5f1938629e1182b46cc43f2da6e7774Dianne Hackborn env->ReleaseStringUTFChars(file, file8); 1031c64edde69d18498fb2954f71a546357b07ab996aEvan Millar return JNI_FALSE; 1032c64edde69d18498fb2954f71a546357b07ab996aEvan Millar } 1033306af678a5f1938629e1182b46cc43f2da6e7774Dianne Hackborn env->ReleaseStringUTFChars(file, file8); 103469a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1035c64edde69d18498fb2954f71a546357b07ab996aEvan Millar char buffer[256]; 1036c64edde69d18498fb2954f71a546357b07ab996aEvan Millar const int len = read(fd, buffer, sizeof(buffer)-1); 1037c64edde69d18498fb2954f71a546357b07ab996aEvan Millar close(fd); 103869a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1039c64edde69d18498fb2954f71a546357b07ab996aEvan Millar if (len < 0) { 10400f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe if (kDebugProc) { 10410f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe ALOGW("Unable to open process file: %s fd=%d\n", file8, fd); 10420f0b4919667f418b249c497f5ad3e83fdf4437e5Andreas Gampe } 1043c64edde69d18498fb2954f71a546357b07ab996aEvan Millar return JNI_FALSE; 1044c64edde69d18498fb2954f71a546357b07ab996aEvan Millar } 1045c64edde69d18498fb2954f71a546357b07ab996aEvan Millar buffer[len] = 0; 104669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 104769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes return android_os_Process_parseProcLineArray(env, clazz, buffer, 0, len, 1048c64edde69d18498fb2954f71a546357b07ab996aEvan Millar format, outStrings, outLongs, outFloats); 104969a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 1050c64edde69d18498fb2954f71a546357b07ab996aEvan Millar} 1051c64edde69d18498fb2954f71a546357b07ab996aEvan Millar 10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_setApplicationObject(JNIEnv* env, jobject clazz, 10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jobject binderObject) 10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (binderObject == NULL) { 105669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes jniThrowNullPointerException(env, NULL); 10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 10589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sp<IBinder> binder = ibinderForJavaObject(env, binderObject); 10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectvoid android_os_Process_sendSignal(JNIEnv* env, jobject clazz, jint pid, jint sig) 10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (pid > 0) { 1066c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn ALOGI("Sending signal. PID: %" PRId32 " SIG: %" PRId32, pid, sig); 10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project kill(pid, sig); 10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1071906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackbornvoid android_os_Process_sendSignalQuiet(JNIEnv* env, jobject clazz, jint pid, jint sig) 1072906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn{ 1073906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn if (pid > 0) { 1074906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn kill(pid, sig); 1075906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn } 1076906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn} 1077906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn 10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectstatic jlong android_os_Process_getElapsedCpuTime(JNIEnv* env, jobject clazz) 10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project struct timespec ts; 10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int res = clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts); 108369a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (res != 0) { 10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (jlong) 0; 108669a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes } 108769a017bc1d1649350f830dfada5c6ed5eac0b770Elliott Hughes 10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project nsecs_t when = seconds_to_nanoseconds(ts.tv_sec) + ts.tv_nsec; 10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (jlong) nanoseconds_to_milliseconds(when); 10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectstatic jlong android_os_Process_getPss(JNIEnv* env, jobject clazz, jint pid) 10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char filename[64]; 10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1096c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn snprintf(filename, sizeof(filename), "/proc/%" PRId32 "/smaps", pid); 10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project FILE * file = fopen(filename, "r"); 10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!file) { 11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (jlong) -1; 11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Tally up all of the Pss from the various maps 11049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project char line[256]; 11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jlong pss = 0; 11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (fgets(line, sizeof(line), file)) { 11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project jlong v; 1108c6a410164e1fd728cf7873493baacca7bc29548dMark Salyzyn if (sscanf(line, "Pss: %" SCNd64 " kB", &v) == 1) { 11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project pss += v; 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project fclose(file); 11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Return the Pss value in bytes, not kilobytes 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pss * 1024; 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1119f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne HackbornjintArray android_os_Process_getPidsForCommands(JNIEnv* env, jobject clazz, 1120f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jobjectArray commandNames) 1121f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn{ 1122f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (commandNames == NULL) { 1123f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jniThrowNullPointerException(env, NULL); 1124f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return NULL; 1125f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1126f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1127f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn Vector<String8> commands; 1128f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1129f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jsize count = env->GetArrayLength(commandNames); 1130f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1131f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn for (int i=0; i<count; i++) { 1132f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jobject obj = env->GetObjectArrayElement(commandNames, i); 1133f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (obj != NULL) { 1134f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn const char* str8 = env->GetStringUTFChars((jstring)obj, NULL); 1135f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (str8 == NULL) { 1136f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jniThrowNullPointerException(env, "Element in commandNames"); 1137f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return NULL; 1138f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1139f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn commands.add(String8(str8)); 1140f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn env->ReleaseStringUTFChars((jstring)obj, str8); 1141f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } else { 1142f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jniThrowNullPointerException(env, "Element in commandNames"); 1143f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return NULL; 1144f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1145f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1146f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1147f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn Vector<jint> pids; 1148f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1149f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn DIR *proc = opendir("/proc"); 1150f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (proc == NULL) { 1151f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn fprintf(stderr, "/proc: %s\n", strerror(errno)); 1152f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return NULL; 1153f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1154f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1155f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn struct dirent *d; 1156f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn while ((d = readdir(proc))) { 1157f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn int pid = atoi(d->d_name); 1158f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (pid <= 0) continue; 1159f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1160f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn char path[PATH_MAX]; 1161f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn char data[PATH_MAX]; 1162f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn snprintf(path, sizeof(path), "/proc/%d/cmdline", pid); 1163f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1164422dd00fa31b6e9f12993eba44d4ae6ed8285882Nick Kralevich int fd = open(path, O_RDONLY | O_CLOEXEC); 1165f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (fd < 0) { 1166f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn continue; 1167f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1168f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn const int len = read(fd, data, sizeof(data)-1); 1169f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn close(fd); 1170f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1171f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (len < 0) { 1172f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn continue; 1173f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1174f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn data[len] = 0; 1175f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1176f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn for (int i=0; i<len; i++) { 1177f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (data[i] == ' ') { 1178f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn data[i] = 0; 1179f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn break; 1180f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1181f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1182f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1183f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn for (size_t i=0; i<commands.size(); i++) { 1184f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (commands[i] == data) { 1185f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn pids.add(pid); 1186f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn break; 1187f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1188f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1189f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1190f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1191f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn closedir(proc); 1192f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1193f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jintArray pidArray = env->NewIntArray(pids.size()); 1194f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (pidArray == NULL) { 1195f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn jniThrowException(env, "java/lang/OutOfMemoryError", NULL); 1196f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return NULL; 1197f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1198f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1199f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn if (pids.size() > 0) { 1200f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn env->SetIntArrayRegion(pidArray, 0, pids.size(), pids.array()); 1201f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn } 1202f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 1203f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn return pidArray; 1204f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn} 1205f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn 12060769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Crossjint android_os_Process_killProcessGroup(JNIEnv* env, jobject clazz, jint uid, jint pid) 12070769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross{ 12080769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross return killProcessGroup(uid, pid, SIGKILL); 12090769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross} 12100769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross 12110769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Crossvoid android_os_Process_removeAllProcessGroups(JNIEnv* env, jobject clazz) 12120769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross{ 12130769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross return removeAllProcessGroups(); 12140769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross} 12150769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross 12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectstatic const JNINativeMethod methods[] = { 12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getUidForName", "(Ljava/lang/String;)I", (void*)android_os_Process_getUidForName}, 12189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getGidForName", "(Ljava/lang/String;)I", (void*)android_os_Process_getGidForName}, 12199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"setThreadPriority", "(II)V", (void*)android_os_Process_setThreadPriority}, 12206793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten {"setThreadScheduler", "(III)V", (void*)android_os_Process_setThreadScheduler}, 1221160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate {"setCanSelfBackground", "(Z)V", (void*)android_os_Process_setCanSelfBackground}, 12229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"setThreadPriority", "(I)V", (void*)android_os_Process_setCallingThreadPriority}, 12239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getThreadPriority", "(I)I", (void*)android_os_Process_getThreadPriority}, 12241b15d13243d7e7f672713f21f0c46d88c3c067a2Srinath Sridharan {"getThreadScheduler", "(I)I", (void*)android_os_Process_getThreadScheduler}, 1225e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat {"setThreadGroup", "(II)V", (void*)android_os_Process_setThreadGroup}, 12262d314e15c9f0b2efc817b6111d808248a546f48cJoel Fernandes {"setThreadGroupAndCpuset", "(II)V", (void*)android_os_Process_setThreadGroupAndCpuset}, 12279e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey {"setProcessGroup", "(II)V", (void*)android_os_Process_setProcessGroup}, 12289e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey {"getProcessGroup", "(I)I", (void*)android_os_Process_getProcessGroup}, 1229cd4bdf3eb91c1cc2757d32a86fc90745d0dff990Martijn Coenen {"getExclusiveCores", "()[I", (void*)android_os_Process_getExclusiveCores}, 12305534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand {"setSwappiness", "(IZ)Z", (void*)android_os_Process_setSwappiness}, 12319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"setArgV0", "(Ljava/lang/String;)V", (void*)android_os_Process_setArgV0}, 12329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"setUid", "(I)I", (void*)android_os_Process_setUid}, 12339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"setGid", "(I)I", (void*)android_os_Process_setGid}, 12349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"sendSignal", "(II)V", (void*)android_os_Process_sendSignal}, 1235906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn {"sendSignalQuiet", "(II)V", (void*)android_os_Process_sendSignalQuiet}, 12360bca96bcbfe559f9330a01f723c5c9cba51ec05aMarco Nelissen {"getFreeMemory", "()J", (void*)android_os_Process_getFreeMemory}, 123759325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn {"getTotalMemory", "()J", (void*)android_os_Process_getTotalMemory}, 12389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"readProcLines", "(Ljava/lang/String;[Ljava/lang/String;[J)V", (void*)android_os_Process_readProcLines}, 12399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getPids", "(Ljava/lang/String;[I)[I", (void*)android_os_Process_getPids}, 12409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"readProcFile", "(Ljava/lang/String;[I[Ljava/lang/String;[J[F)Z", (void*)android_os_Process_readProcFile}, 1241c64edde69d18498fb2954f71a546357b07ab996aEvan Millar {"parseProcLine", "([BII[I[Ljava/lang/String;[J[F)Z", (void*)android_os_Process_parseProcLine}, 12429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getElapsedCpuTime", "()J", (void*)android_os_Process_getElapsedCpuTime}, 12439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project {"getPss", "(I)J", (void*)android_os_Process_getPss}, 1244f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn {"getPidsForCommands", "([Ljava/lang/String;)[I", (void*)android_os_Process_getPidsForCommands}, 12459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //{"setApplicationObject", "(Landroid/os/IBinder;)V", (void*)android_os_Process_setApplicationObject}, 12460769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross {"killProcessGroup", "(II)I", (void*)android_os_Process_killProcessGroup}, 12470769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross {"removeAllProcessGroups", "()V", (void*)android_os_Process_removeAllProcessGroups}, 12489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}; 12499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectint register_android_os_Process(JNIEnv* env) 12519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{ 1252ed6b9dff563c5e22f040ff37e12c0d771e0478aeAndreas Gampe return RegisterMethodsOrDie(env, "android/os/Process", methods, NELEM(methods)); 12539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1254