Process.java revision 48aa86bd0b30815f4c02561f713bd33b032ef2b7
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.os;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.LocalSocket;
20973b4663b0b5ee62006522bf4742af076096e548Narayan Kamathimport android.net.LocalSocketAddress;
2134385d352da19805ae948215e2edbeedd16b7941Elliott Hughesimport android.system.Os;
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log;
23973b4663b0b5ee62006522bf4742af076096e548Narayan Kamathimport com.android.internal.os.Zygote;
24ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampeimport dalvik.system.VMRuntime;
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.BufferedWriter;
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.DataInputStream;
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.IOException;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.OutputStreamWriter;
294444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamathimport java.nio.charset.StandardCharsets;
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.ArrayList;
314444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamathimport java.util.Arrays;
324444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamathimport java.util.List;
33406ec15647b7664cadadde41dbaaa10e298c582bJeff Hao
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*package*/ class ZygoteStartFailedEx extends Exception {
3564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    ZygoteStartFailedEx(String s) {
3664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        super(s);
3764cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    }
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3964cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    ZygoteStartFailedEx(Throwable cause) {
4064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        super(cause);
4164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    }
4264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath
4364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    ZygoteStartFailedEx(String s, Throwable cause) {
4464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        super(s, cause);
4564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    }
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Tools for managing OS processes.
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class Process {
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private static final String LOG_TAG = "Process";
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    /**
5564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     * @hide for internal use only.
5664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     */
5764cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    public static final String ZYGOTE_SOCKET = "zygote";
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5964cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    /**
6064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     * @hide for internal use only.
6164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     */
6264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    public static final String SECONDARY_ZYGOTE_SOCKET = "zygote_secondary";
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
651cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey     * Defines the root UID.
661cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey     * @hide
671cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey     */
681cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey    public static final int ROOT_UID = 0;
691cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey
701cb2d0d4bba387665128c62c342e59103ea4be26Jeff Sharkey    /**
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Defines the UID/GID under which system code runs.
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int SYSTEM_UID = 1000;
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Defines the UID/GID under which the telephony code runs.
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PHONE_UID = 1001;
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
81854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn     * Defines the UID/GID for the user shell.
82854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn     * @hide
83854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn     */
84854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn    public static final int SHELL_UID = 2000;
85854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn
86854060af30f928c0a65591e9c8314ae17056e6b8Dianne Hackborn    /**
87d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood     * Defines the UID/GID for the log group.
88d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood     * @hide
89d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood     */
90d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood    public static final int LOG_UID = 1007;
91d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood
92d42685d5de1dbd6d75b48d42418f370adaa4daefMike Lockwood    /**
93d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani     * Defines the UID/GID for the WIFI supplicant process.
94d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani     * @hide
95d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani     */
96d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani    public static final int WIFI_UID = 1010;
97d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani
98d158214511a3c04753de04fa6389e46d33135c38Amith Yamasani    /**
998b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten     * Defines the UID/GID for the mediaserver process.
1008b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten     * @hide
1018b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten     */
1028b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten    public static final int MEDIA_UID = 1013;
1038b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten
1048b7d1b4d4a33e9429c5cedaa6317efcaad95da68Glenn Kasten    /**
1055294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey     * Defines the UID/GID for the DRM process.
1065294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey     * @hide
1075294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey     */
1085294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey    public static final int DRM_UID = 1019;
1095294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey
1105294a2fc2f401cd248a4bc3f0f9ee1e2854f4e9aJeff Sharkey    /**
11126993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root     * Defines the UID/GID for the group that controls VPN services.
11226993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root     * @hide
11326993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root     */
11426993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root    public static final int VPN_UID = 1016;
11526993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root
11626993b37d525fd64efebd51daec1b4abfebd8a74Kenny Root    /**
117cd0e839a2448deea50f79bddeba782c546b33893Nick Pelly     * Defines the UID/GID for the NFC service process.
118cd0e839a2448deea50f79bddeba782c546b33893Nick Pelly     * @hide
119cd0e839a2448deea50f79bddeba782c546b33893Nick Pelly     */
120a5cb9f42174a52afbeb7e33dab64282f52f8cedbNick Pelly    public static final int NFC_UID = 1027;
121cd0e839a2448deea50f79bddeba782c546b33893Nick Pelly
122cd0e839a2448deea50f79bddeba782c546b33893Nick Pelly    /**
1231abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh     * Defines the UID/GID for the Bluetooth service process.
1241abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh     * @hide
1251abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh     */
1261abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh    public static final int BLUETOOTH_UID = 1002;
1271abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh
1281abb1cb3a8fe17f7866150604c2fd73751da787eJaikumar Ganesh    /**
129dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood     * Defines the GID for the group that allows write access to the internal media storage.
130dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood     * @hide
131dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood     */
132dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood    public static final int MEDIA_RW_GID = 1023;
133dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood
134dcaa10cd361a543cfa93bbb5c53444f437bd07a4Mike Lockwood    /**
135184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey     * Access to installed package details
136184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey     * @hide
137184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey     */
138184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey    public static final int PACKAGE_INFO_GID = 1032;
139184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey
140184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey    /**
14108cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)     * Defines the UID/GID for the shared RELRO file updater process.
14208cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)     * @hide
14308cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)     */
14408cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)    public static final int SHARED_RELRO_UID = 1037;
14508cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)
14608cfaf672604422dd355d6703aec78f3aa5ee74eTorne (Richard Coles)    /**
147ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung     * Defines the UID/GID for the audioserver process.
148ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung     * @hide
149ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung     */
150ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung    public static final int AUDIOSERVER_UID = 1041;
151ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung
152ed0ea40a41aae8e65bc189efe6b631ca78259383Andy Hung    /**
15375cade0a5fd5ec432870de9977f81091ab389423Chien-Yu Chen     * Defines the UID/GID for the cameraserver process
15475cade0a5fd5ec432870de9977f81091ab389423Chien-Yu Chen     * @hide
15575cade0a5fd5ec432870de9977f81091ab389423Chien-Yu Chen     */
156b8b4e85879e93db2ba7821b7fe54710cb6a6de71Chien-Yu Chen    public static final int CAMERASERVER_UID = 1047;
15775cade0a5fd5ec432870de9977f81091ab389423Chien-Yu Chen
15875cade0a5fd5ec432870de9977f81091ab389423Chien-Yu Chen    /**
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Defines the start of a range of UIDs (and GIDs), going from this
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * number to {@link #LAST_APPLICATION_UID} that are reserved for assigning
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to applications.
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int FIRST_APPLICATION_UID = 10000;
164184a0100abc431fc3d6d8dd1b20212b84958cadaJeff Sharkey
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Last of application-specific UIDs starting at
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #FIRST_APPLICATION_UID}.
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
16921fbd1f7da53dc044737803dccddf8099f1fc1e9Dianne Hackborn    public static final int LAST_APPLICATION_UID = 19999;
170a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn
171a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    /**
172a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * First uid used for fully isolated sandboxed processes (with no permissions of their own)
173a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * @hide
174a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     */
175a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    public static final int FIRST_ISOLATED_UID = 99000;
176a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn
177a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    /**
178a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * Last uid used for fully isolated sandboxed processes (with no permissions of their own)
179a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * @hide
180a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     */
181a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    public static final int LAST_ISOLATED_UID = 99999;
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
184e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee     * Defines the gid shared by all applications running under the same profile.
185e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee     * @hide
186e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee     */
187e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee    public static final int SHARED_USER_GID = 9997;
188e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee
189e66b6890ee59d108ae5c608f6ec8d4ad20cb06a8Robin Lee    /**
190e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * First gid for applications to share resources. Used when forward-locking
191e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * is enabled but all UserHandles need to be able to read the resources.
192e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * @hide
193e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     */
194e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root    public static final int FIRST_SHARED_APPLICATION_GID = 50000;
195e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root
196e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root    /**
197e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * Last gid for applications to share resources. Used when forward-locking
198e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * is enabled but all UserHandles need to be able to read the resources.
199e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     * @hide
200e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root     */
201e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root    public static final int LAST_SHARED_APPLICATION_GID = 59999;
202e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root
203e091f22e226f7177e45e23850670c1ad9b63fd75Kenny Root    /**
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of application threads.
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_DEFAULT = 0;
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /*
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * ***************************************
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * ** Keep in sync with utils/threads.h **
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * ***************************************
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Lowest available thread priority.  Only for those who really, really
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * don't want to run if anything else is happening.
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_LOWEST = 19;
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority background threads.  This gives your thread a slightly
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * lower than normal priority, so that it will have less chance of impacting
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the responsiveness of the user interface.
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_BACKGROUND = 10;
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of threads that are currently running a user interface
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * that the user is interacting with.  Applications can not normally
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * change to this priority; the system will automatically adjust your
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * application threads as the user moves through the UI.
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_FOREGROUND = -2;
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of system display threads, involved in updating
2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the user interface.  Applications can not
2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * normally change to this priority.
2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_DISPLAY = -4;
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of the most important display threads, for compositing
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the screen and retrieving input events.  Applications can not normally
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * change to this priority.
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_URGENT_DISPLAY = -8;
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of audio threads.  Applications can not normally
2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * change to this priority.
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_AUDIO = -16;
2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Standard priority of the most important audio threads.
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Applications can not normally change to this priority.
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Use with {@link #setThreadPriority(int)} and
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}, <b>not</b> with the normal
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link java.lang.Thread} class.
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_URGENT_AUDIO = -19;
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Minimum increment to make a priority more favorable.
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_MORE_FAVORABLE = -1;
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Minimum increment to make a priority less favorable.
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int THREAD_PRIORITY_LESS_FAVORABLE = +1;
2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
295e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat    /**
2966793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * Default scheduling policy
2976793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @hide
2986793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
2996793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final int SCHED_OTHER = 0;
3006793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
3016793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
3026793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * First-In First-Out scheduling policy
3036793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @hide
3046793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
3056793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final int SCHED_FIFO = 1;
3066793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
3076793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
3086793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * Round-Robin scheduling policy
3096793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @hide
3106793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
3116793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final int SCHED_RR = 2;
3126793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
3136793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
3146793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * Batch scheduling policy
3156793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @hide
3166793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
3176793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final int SCHED_BATCH = 3;
3186793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
3196793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
3206793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * Idle scheduling policy
3216793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @hide
3226793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
3236793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final int SCHED_IDLE = 5;
3246793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
325f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    // Keep in sync with SP_* constants of enum type SchedPolicy
326f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    // declared in system/core/include/cutils/sched_policy.h,
327f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    // except THREAD_GROUP_DEFAULT does not correspond to any SP_* value.
328f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten
3296793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
330f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Default thread group -
331f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * has meaning with setProcessGroup() only, cannot be used with setThreadGroup().
332f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * When used with setProcessGroup(), the group of each thread in the process
333f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * is conditionally changed based on that thread's current priority, as follows:
334f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * threads with priority numerically less than THREAD_PRIORITY_BACKGROUND
335f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * are moved to foreground thread group.  All other threads are left unchanged.
336e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @hide
337e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     */
338f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    public static final int THREAD_GROUP_DEFAULT = -1;
339e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat
340e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat    /**
341f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Background thread group - All threads in
342e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * this group are scheduled with a reduced share of the CPU.
343f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Value is same as constant SP_BACKGROUND of enum SchedPolicy.
344f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * FIXME rename to THREAD_GROUP_BACKGROUND.
345e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @hide
346e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     */
347f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    public static final int THREAD_GROUP_BG_NONINTERACTIVE = 0;
348e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat
349e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat    /**
350f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Foreground thread group - All threads in
351f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * this group are scheduled with a normal share of the CPU.
352f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Value is same as constant SP_FOREGROUND of enum SchedPolicy.
353f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * Not used at this level.
354e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @hide
355e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     **/
356f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten    private static final int THREAD_GROUP_FOREGROUND = 1;
357e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat
35807b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    /**
35907b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * System thread group.
36007b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @hide
36107b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     **/
36207b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    public static final int THREAD_GROUP_SYSTEM = 2;
36307b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten
36407b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    /**
36507b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * Application audio thread group.
36607b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @hide
36707b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     **/
36807b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    public static final int THREAD_GROUP_AUDIO_APP = 3;
36907b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten
37007b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    /**
37107b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * System audio thread group.
37207b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @hide
37307b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     **/
37407b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    public static final int THREAD_GROUP_AUDIO_SYS = 4;
37507b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten
376ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray    /**
377ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray     * Thread group for top foreground app.
378ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray     * @hide
379ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray     **/
380ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray    public static final int THREAD_GROUP_TOP_APP = 5;
381ece6a22f00de4ab815588e2f7951203adcd2b9c4Tim Murray
3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int SIGNAL_QUIT = 3;
3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int SIGNAL_KILL = 9;
3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int SIGNAL_USR1 = 10;
3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3864444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    /**
3874444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * State for communicating with the zygote process.
38864cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     *
38964cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath     * @hide for internal use only.
3904444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     */
39164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath    public static class ZygoteState {
3924444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        final LocalSocket socket;
3934444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        final DataInputStream inputStream;
3944444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        final BufferedWriter writer;
3954444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        final List<String> abiList;
3964444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
3974444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        boolean mClosed;
3984444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
3994444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        private ZygoteState(LocalSocket socket, DataInputStream inputStream,
4004444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                BufferedWriter writer, List<String> abiList) {
4014444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            this.socket = socket;
4024444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            this.inputStream = inputStream;
4034444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            this.writer = writer;
4044444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            this.abiList = abiList;
4054444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
4064444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
40764cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        public static ZygoteState connect(String socketAddress) throws IOException {
4084444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            DataInputStream zygoteInputStream = null;
4094444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            BufferedWriter zygoteWriter = null;
41064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            final LocalSocket zygoteSocket = new LocalSocket();
4114444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
41264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            try {
41364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                zygoteSocket.connect(new LocalSocketAddress(socketAddress,
41464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                        LocalSocketAddress.Namespace.RESERVED));
4154444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
41664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                zygoteInputStream = new DataInputStream(zygoteSocket.getInputStream());
4174444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
41864cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                zygoteWriter = new BufferedWriter(new OutputStreamWriter(
41964cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                        zygoteSocket.getOutputStream()), 256);
42064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            } catch (IOException ex) {
42164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                try {
42264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                    zygoteSocket.close();
42364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                } catch (IOException ignore) {
4244444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                }
4254444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
42664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                throw ex;
4274444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            }
4284444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4294444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            String abiListString = getAbiList(zygoteWriter, zygoteInputStream);
4304444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            Log.i("Zygote", "Process: zygote socket opened, supported ABIS: " + abiListString);
4314444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4324444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return new ZygoteState(zygoteSocket, zygoteInputStream, zygoteWriter,
4334444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                    Arrays.asList(abiListString.split(",")));
4344444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
4354444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4364444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        boolean matches(String abi) {
4374444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return abiList.contains(abi);
4384444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
4394444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
44064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        public void close() {
4414444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            try {
4424444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                socket.close();
4434444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            } catch (IOException ex) {
4444444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                Log.e(LOG_TAG,"I/O exception on routine close", ex);
4454444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            }
4464444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4474444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            mClosed = true;
4484444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
4494444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4504444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        boolean isClosed() {
4514444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return mClosed;
4524444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
4534444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    }
4544444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
4554444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    /**
4564444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * The state of the connection to the primary zygote.
4574444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     */
4584444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    static ZygoteState primaryZygoteState;
4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4604444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    /**
4614444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * The state of the connection to the secondary zygote.
4624444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     */
4634444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    static ZygoteState secondaryZygoteState;
4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Start a new process.
4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>If processes are enabled, a new process is created and the
4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * static main() function of a <var>processClass</var> is executed there.
4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The process will continue running after this function returns.
4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>If processes are not enabled, a new thread in the caller's
4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * process is created and main() of <var>processClass</var> called there.
4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <p>The niceName parameter, if not an empty string, is a custom name to
4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * give to the process instead of using processClass.  This allows you to
4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * make easily identifyable processes even if you are using the same base
4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <var>processClass</var> to start them.
4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param processClass The class to use as the process's main entry
4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *                     point.
4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param niceName A more readable name to use for the process.
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param uid The user-id under which the process will run.
4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param gid The group-id under which the process will run.
4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param gids Additional group-ids associated with the process.
486e1dfcb7ab01fb991079ec1f70f75281a0ca9073eElliott Hughes     * @param debugFlags Additional flags.
487e1dfcb7ab01fb991079ec1f70f75281a0ca9073eElliott Hughes     * @param targetSdkVersion The target SDK version for the app.
488bd19b9ee305c11d8aa3cbb105bf2d3a6b06389b5Stephen Smalley     * @param seInfo null-ok SELinux information for the new process.
489ff0c470833b2cb4130a30895093630242d5f238dRamin Zaghi     * @param abi non-null the ABI this app should be started with.
490aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe     * @param instructionSet null-ok the instruction set to use.
4912eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu     * @param appDataDir null-ok the data directory of the app.
4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param zygoteArgs Additional arguments to supply to the zygote process.
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4943f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown     * @return An object that describes the result of the attempt to start the process.
4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws RuntimeException on fatal start failure
4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@hide}
4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
4993f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown    public static final ProcessStartResult start(final String processClass,
5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  final String niceName,
5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  int uid, int gid, int[] gids,
5025b1ada2562c17921adf6a62ea62bcb445160983cJeff Sharkey                                  int debugFlags, int mountExternal,
5035b1ada2562c17921adf6a62ea62bcb445160983cJeff Sharkey                                  int targetSdkVersion,
50483d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley                                  String seInfo,
505ff0c470833b2cb4130a30895093630242d5f238dRamin Zaghi                                  String abi,
506aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe                                  String instructionSet,
5072eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu                                  String appDataDir,
50810e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown                                  String[] zygoteArgs) {
5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        try {
51010e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown            return startViaZygote(processClass, niceName, uid, gid, gids,
5114444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                    debugFlags, mountExternal, targetSdkVersion, seInfo,
5122eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu                    abi, instructionSet, appDataDir, zygoteArgs);
51310e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown        } catch (ZygoteStartFailedEx ex) {
51410e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown            Log.e(LOG_TAG,
51510e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown                    "Starting VM process through Zygote failed");
51610e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown            throw new RuntimeException(
51710e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown                    "Starting VM process through Zygote failed", ex);
5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** retry interval for opening a zygote socket */
5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    static final int ZYGOTE_RETRY_MILLIS = 500;
5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5254444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * Queries the zygote for the list of ABIS it supports.
5264444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     *
5274444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * @throws ZygoteStartFailedEx if the query failed.
5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5294444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    private static String getAbiList(BufferedWriter writer, DataInputStream inputStream)
53064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            throws IOException {
53164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        // Each query starts with the argument count (1 in this case)
53264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        writer.write("1");
53364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        // ... followed by a new-line.
53464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        writer.newLine();
53564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        // ... followed by our only argument.
53664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        writer.write("--query-abi-list");
53764cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        writer.newLine();
53864cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        writer.flush();
53964cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath
54064cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        // The response is a length prefixed stream of ASCII bytes.
54164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        int numBytes = inputStream.readInt();
54264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        byte[] bytes = new byte[numBytes];
54364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        inputStream.readFully(bytes);
54464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath
54564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath        return new String(bytes, StandardCharsets.US_ASCII);
5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Sends an argument list to the zygote process, which starts a new child
5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and returns the child's pid. Please note: the present implementation
5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * replaces newlines in the argument list with spaces.
5524444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     *
5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws ZygoteStartFailedEx if process start failed for any reason
5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
5554444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    private static ProcessStartResult zygoteSendArgsAndGetResult(
5564444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            ZygoteState zygoteState, ArrayList<String> args)
5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throws ZygoteStartFailedEx {
5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        try {
5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            /**
5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             * See com.android.internal.os.ZygoteInit.readArgumentList()
5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             * Presently the wire format to the zygote process is:
5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             * a) a count of arguments (argc, in essence)
5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             * b) a number of newline-separated argument strings equal to count
5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             *
5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             * After the zygote process reads these it will write the pid of
5663f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown             * the child or -1 on failure, followed by boolean to
5673f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown             * indicate whether a wrapper process was used.
5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project             */
5694444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            final BufferedWriter writer = zygoteState.writer;
5704444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            final DataInputStream inputStream = zygoteState.inputStream;
5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5724444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            writer.write(Integer.toString(args.size()));
5734444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            writer.newLine();
5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            int sz = args.size();
5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            for (int i = 0; i < sz; i++) {
5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                String arg = args.get(i);
5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                if (arg.indexOf('\n') >= 0) {
5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    throw new ZygoteStartFailedEx(
5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            "embedded newlines not allowed");
5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
5824444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                writer.write(arg);
5834444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                writer.newLine();
5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5864444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            writer.flush();
5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // Should there be a timeout on this?
5893f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown            ProcessStartResult result = new ProcessStartResult();
5904444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            result.pid = inputStream.readInt();
5913f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown            if (result.pid < 0) {
5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                throw new ZygoteStartFailedEx("fork() failed");
5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
5944444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            result.usingWrapper = inputStream.readBoolean();
5953f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown            return result;
5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } catch (IOException ex) {
5974444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            zygoteState.close();
5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throw new ZygoteStartFailedEx(ex);
5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Starts a new process via the zygote mechanism.
6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param processClass Class name whose static main() to run
6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param niceName 'nice' process name to appear in ps
6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param uid a POSIX uid that the new process should setuid() to
6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param gid a POSIX gid that the new process shuold setgid() to
6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param gids null-ok; a list of supplementary group IDs that the
6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * new process should setgroup() to.
611e1dfcb7ab01fb991079ec1f70f75281a0ca9073eElliott Hughes     * @param debugFlags Additional flags.
612e1dfcb7ab01fb991079ec1f70f75281a0ca9073eElliott Hughes     * @param targetSdkVersion The target SDK version for the app.
613bd19b9ee305c11d8aa3cbb105bf2d3a6b06389b5Stephen Smalley     * @param seInfo null-ok SELinux information for the new process.
6144444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * @param abi the ABI the process should use.
615aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe     * @param instructionSet null-ok the instruction set to use.
6162eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu     * @param appDataDir null-ok the data directory of the app.
6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param extraArgs Additional arguments to supply to the zygote process.
6183f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown     * @return An object that describes the result of the attempt to start the process.
6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws ZygoteStartFailedEx if process start failed for any reason
6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
6213f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown    private static ProcessStartResult startViaZygote(final String processClass,
6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  final String niceName,
6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  final int uid, final int gid,
6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  final int[] gids,
6255b1ada2562c17921adf6a62ea62bcb445160983cJeff Sharkey                                  int debugFlags, int mountExternal,
6265b1ada2562c17921adf6a62ea62bcb445160983cJeff Sharkey                                  int targetSdkVersion,
62783d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley                                  String seInfo,
6284444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath                                  String abi,
629aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe                                  String instructionSet,
6302eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu                                  String appDataDir,
6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  String[] extraArgs)
6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                                  throws ZygoteStartFailedEx {
6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        synchronized(Process.class) {
6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            ArrayList<String> argsForZygote = new ArrayList<String>();
6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
636f48029f00a66e23d7872a00b56fbcf88528ba476Narayan Kamath            // --runtime-args, --setuid=, --setgid=,
6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // and --setgroups= must go first
638f48029f00a66e23d7872a00b56fbcf88528ba476Narayan Kamath            argsForZygote.add("--runtime-args");
6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            argsForZygote.add("--setuid=" + uid);
6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            argsForZygote.add("--setgid=" + gid);
641ae07ecf3766c38af1c12822458b98036b28bd4c0Elliott Hughes            if ((debugFlags & Zygote.DEBUG_ENABLE_JNI_LOGGING) != 0) {
642ae07ecf3766c38af1c12822458b98036b28bd4c0Elliott Hughes                argsForZygote.add("--enable-jni-logging");
643ae07ecf3766c38af1c12822458b98036b28bd4c0Elliott Hughes            }
64423085b781e145ed684e7270af1d5ced6800b8effBen Cheng            if ((debugFlags & Zygote.DEBUG_ENABLE_SAFEMODE) != 0) {
64523085b781e145ed684e7270af1d5ced6800b8effBen Cheng                argsForZygote.add("--enable-safemode");
64623085b781e145ed684e7270af1d5ced6800b8effBen Cheng            }
6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if ((debugFlags & Zygote.DEBUG_ENABLE_DEBUGGER) != 0) {
6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                argsForZygote.add("--enable-debugger");
6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if ((debugFlags & Zygote.DEBUG_ENABLE_CHECKJNI) != 0) {
6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                argsForZygote.add("--enable-checkjni");
6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
653065075e1f993a68579ed7f8034ab09d96ec957a9David Srbecky            if ((debugFlags & Zygote.DEBUG_GENERATE_DEBUG_INFO) != 0) {
654065075e1f993a68579ed7f8034ab09d96ec957a9David Srbecky                argsForZygote.add("--generate-debug-info");
65527c39f1adeaf1a653fb41a5af64ee815b8048dd6Andreas Gampe            }
656df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer            if ((debugFlags & Zygote.DEBUG_ALWAYS_JIT) != 0) {
657df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer                argsForZygote.add("--always-jit");
658df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer            }
659df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer            if ((debugFlags & Zygote.DEBUG_NATIVE_DEBUGGABLE) != 0) {
660df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer                argsForZygote.add("--native-debuggable");
661df6cb282937e5f804686ebbc952ae9f2290d93c7Tamas Berghammer            }
6629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if ((debugFlags & Zygote.DEBUG_ENABLE_ASSERT) != 0) {
6639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                argsForZygote.add("--enable-assert");
6649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6654887789e44cdb16b042a35e8ec03983213e88ac6Jeff Sharkey            if (mountExternal == Zygote.MOUNT_EXTERNAL_DEFAULT) {
6664887789e44cdb16b042a35e8ec03983213e88ac6Jeff Sharkey                argsForZygote.add("--mount-external-default");
6679527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey            } else if (mountExternal == Zygote.MOUNT_EXTERNAL_READ) {
6689527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey                argsForZygote.add("--mount-external-read");
6699527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey            } else if (mountExternal == Zygote.MOUNT_EXTERNAL_WRITE) {
6709527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey                argsForZygote.add("--mount-external-write");
6715b1ada2562c17921adf6a62ea62bcb445160983cJeff Sharkey            }
672e1dfcb7ab01fb991079ec1f70f75281a0ca9073eElliott Hughes            argsForZygote.add("--target-sdk-version=" + targetSdkVersion);
6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            //TODO optionally enable debuger
6759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            //argsForZygote.add("--enable-debugger");
6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            // --setgroups is a comma-separated list
6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (gids != null && gids.length > 0) {
6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                StringBuilder sb = new StringBuilder();
6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                sb.append("--setgroups=");
6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                int sz = gids.length;
6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                for (int i = 0; i < sz; i++) {
6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    if (i != 0) {
6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                        sb.append(',');
6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    }
6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    sb.append(gids[i]);
6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                argsForZygote.add(sb.toString());
6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (niceName != null) {
6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                argsForZygote.add("--nice-name=" + niceName);
6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
69783d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley            if (seInfo != null) {
69883d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley                argsForZygote.add("--seinfo=" + seInfo);
69983d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley            }
70083d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley
701aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe            if (instructionSet != null) {
702aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe                argsForZygote.add("--instruction-set=" + instructionSet);
703aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe            }
704aec67dcc02362e4d2f7641c6605405b839bd1bd4Andreas Gampe
7052eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu            if (appDataDir != null) {
7062eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu                argsForZygote.add("--app-data-dir=" + appDataDir);
7072eacd06bfb82b33dfcbccafbcfc0bf1218484bb5jgu            }
70883d9eda9c2c411e3480c52f01e192bf3c86be8e9Stephen Smalley
7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            argsForZygote.add(processClass);
7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            if (extraArgs != null) {
7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                for (String arg : extraArgs) {
7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                    argsForZygote.add(arg);
7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                }
7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7174444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return zygoteSendArgsAndGetResult(openZygoteSocketIfNeeded(abi), argsForZygote);
7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
7204444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7214444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    /**
722343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath     * Tries to establish a connection to the zygote that handles a given {@code abi}. Might block and retry if the
723343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath     * zygote is unresponsive. This method is a no-op if a connection is already open.
724343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath     *
725343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath     * @hide
726343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath     */
727343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath    public static void establishZygoteConnectionForAbi(String abi) {
728343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath        try {
729343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath            openZygoteSocketIfNeeded(abi);
730343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath        } catch (ZygoteStartFailedEx ex) {
731343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath            throw new RuntimeException("Unable to connect to zygote for abi: " + abi, ex);
732343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath        }
733343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath    }
734343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath
735343f478241fab49c909b229d6876ff8405e7b0d5Narayan Kamath    /**
7364444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * Tries to open socket to Zygote process if not already open. If
7374444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     * already open, does nothing.  May block and retry.
7384444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath     */
7394444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    private static ZygoteState openZygoteSocketIfNeeded(String abi) throws ZygoteStartFailedEx {
7404444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        if (primaryZygoteState == null || primaryZygoteState.isClosed()) {
74164cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            try {
74264cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                primaryZygoteState = ZygoteState.connect(ZYGOTE_SOCKET);
74364cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            } catch (IOException ioe) {
74464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                throw new ZygoteStartFailedEx("Error connecting to primary zygote", ioe);
74564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            }
7464444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
7474444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7484444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        if (primaryZygoteState.matches(abi)) {
7494444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return primaryZygoteState;
7504444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
7514444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7524444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        // The primary zygote didn't match. Try the secondary.
7534444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        if (secondaryZygoteState == null || secondaryZygoteState.isClosed()) {
75464cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            try {
75564cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            secondaryZygoteState = ZygoteState.connect(SECONDARY_ZYGOTE_SOCKET);
75664cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            } catch (IOException ioe) {
75764cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath                throw new ZygoteStartFailedEx("Error connecting to secondary zygote", ioe);
75864cd907af99ce9702e8975a657ee437c2626f8b5Narayan Kamath            }
7594444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
7604444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7614444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        if (secondaryZygoteState.matches(abi)) {
7624444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath            return secondaryZygoteState;
7634444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        }
7644444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7654444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath        throw new ZygoteStartFailedEx("Unsupported zygote ABI: " + abi);
7664444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath    }
7674444dcd0adc7e035cca030b90ed91f0cff9a772bNarayan Kamath
7689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns elapsed milliseconds of the time this process has run.
7709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return  Returns the number of milliseconds this process has return.
7719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native long getElapsedCpuTime();
773ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe
774ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe    /**
775ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe     * Returns true if the current process is a 64-bit runtime.
776ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe     */
777ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe    public static final boolean is64Bit() {
778ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe        return VMRuntime.getRuntime().is64Bit();
779ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe    }
780ee0cdce2a80f8cc033378134e37092bc467c0f38Andreas Gampe
7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns the identifier of this process, which can be used with
7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #killProcess} and {@link #sendSignal}.
7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
785406ec15647b7664cadadde41dbaaa10e298c582bJeff Hao    public static final int myPid() {
78634385d352da19805ae948215e2edbeedd16b7941Elliott Hughes        return Os.getpid();
787406ec15647b7664cadadde41dbaaa10e298c582bJeff Hao    }
7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
79080b12fcaaec458377d966803c3a61504f0897ea1Romain Guy     * Returns the identifier of this process' parent.
79180b12fcaaec458377d966803c3a61504f0897ea1Romain Guy     * @hide
79280b12fcaaec458377d966803c3a61504f0897ea1Romain Guy     */
7932a805f930463ece57bc0d0fd8dee7f5d50681b22Elliott Hughes    public static final int myPpid() {
79434385d352da19805ae948215e2edbeedd16b7941Elliott Hughes        return Os.getppid();
7952a805f930463ece57bc0d0fd8dee7f5d50681b22Elliott Hughes    }
79680b12fcaaec458377d966803c3a61504f0897ea1Romain Guy
79780b12fcaaec458377d966803c3a61504f0897ea1Romain Guy    /**
7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns the identifier of the calling thread, which be used with
7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)}.
8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8016d4b1e24aef5b74b40de4d8f6e63c21874ce8e3aElliott Hughes    public static final int myTid() {
80234385d352da19805ae948215e2edbeedd16b7941Elliott Hughes        return Os.gettid();
8036d4b1e24aef5b74b40de4d8f6e63c21874ce8e3aElliott Hughes    }
8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8067d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * Returns the identifier of this process's uid.  This is the kernel uid
8077d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * that the process is running under, which is the identity of its
8087d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * app-specific sandbox.  It is different from {@link #myUserHandle} in that
8097d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * a uid identifies a specific app sandbox in a specific user.
8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
811406ec15647b7664cadadde41dbaaa10e298c582bJeff Hao    public static final int myUid() {
81234385d352da19805ae948215e2edbeedd16b7941Elliott Hughes        return Os.getuid();
813406ec15647b7664cadadde41dbaaa10e298c582bJeff Hao    }
8149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
81679af1dd54c16cde063152922b42c96d72ae9eca8Dianne Hackborn     * Returns this process's user handle.  This is the
8177d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * user the process is running under.  It is distinct from
8187d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * {@link #myUid()} in that a particular user will have multiple
8197d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     * distinct apps running under it each with their own uid.
8207d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn     */
82102cb6e773b323a0d54b21f43460a23f668b7727cFyodor Kupolov    public static UserHandle myUserHandle() {
82202cb6e773b323a0d54b21f43460a23f668b7727cFyodor Kupolov        return UserHandle.of(UserHandle.getUserId(myUid()));
8237d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn    }
8247d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn
8257d19e0242faac8017033dabb872cdf1542fa184cDianne Hackborn    /**
82648aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson     * Returns whether the given uid belongs to an application.
82748aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson     * @param uid A kernel uid.
82848aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson     * @return Whether the uid corresponds to an application sandbox running in
82948aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson     *     a specific user.
83048aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson     */
83148aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson    public static boolean isApplicationUid(int uid) {
83248aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson        return UserHandle.isApp(uid);
83348aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson    }
83448aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson
83548aa86bd0b30815f4c02561f713bd33b032ef2b7Jeff Davidson    /**
836a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * Returns whether the current process is in an isolated sandbox.
837a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     * @hide
838a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn     */
839a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    public static final boolean isIsolated() {
8409527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey        return isIsolated(myUid());
8419527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey    }
8429527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey
8439527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey    /** {@hide} */
8449527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey    public static final boolean isIsolated(int uid) {
8459527b223a9d4a4d149bb005afc77148dbeeff785Jeff Sharkey        uid = UserHandle.getAppId(uid);
846a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn        return uid >= FIRST_ISOLATED_UID && uid <= LAST_ISOLATED_UID;
847a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    }
848a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn
849a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    /**
8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns the UID assigned to a particular user name, or -1 if there is
8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * none.  If the given string consists of only numbers, it is converted
8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * directly to a uid.
8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int getUidForName(String name);
8559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
8569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
8579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns the GID assigned to a particular user name, or -1 if there is
8589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * none.  If the given string consists of only numbers, it is converted
8599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * directly to a gid.
8609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int getGidForName(String name);
862819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani
863819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani    /**
864819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani     * Returns a uid for a currently running process.
865819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani     * @param pid the process id
866819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani     * @return the uid of the process, or -1 if the process is not running.
867819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani     * @hide pending API council review
868819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani     */
869819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani    public static final int getUidForPid(int pid) {
870819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani        String[] procStatusLabels = { "Uid:" };
871819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani        long[] procStatusValues = new long[1];
872819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani        procStatusValues[0] = -1;
873819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani        Process.readProcLines("/proc/" + pid + "/status", procStatusLabels, procStatusValues);
874819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani        return (int) procStatusValues[0];
875819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani    }
876819f928f6a9dc3fdf408236f33e17f03a7dfed2cAmith Yamasani
8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
878ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown     * Returns the parent process id for a currently running process.
879ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown     * @param pid the process id
880ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown     * @return the parent process id of the process, or -1 if the process is not running.
881ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown     * @hide
882ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown     */
883ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown    public static final int getParentPid(int pid) {
884ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown        String[] procStatusLabels = { "PPid:" };
885ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown        long[] procStatusValues = new long[1];
886ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown        procStatusValues[0] = -1;
887ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown        Process.readProcLines("/proc/" + pid + "/status", procStatusLabels, procStatusValues);
888ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown        return (int) procStatusValues[0];
889ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown    }
890ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown
891ebed7d6e35f7f960e6e6add2b8ab7c7a31a511c3Jeff Brown    /**
89207b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * Returns the thread group leader id for a currently running thread.
89307b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @param tid the thread id
89407b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @return the thread group leader id of the thread, or -1 if the thread is not running.
89507b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     *         This is same as what getpid(2) would return if called by tid.
89607b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     * @hide
89707b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten     */
89807b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    public static final int getThreadGroupLeader(int tid) {
89907b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten        String[] procStatusLabels = { "Tgid:" };
90007b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten        long[] procStatusValues = new long[1];
90107b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten        procStatusValues[0] = -1;
90207b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten        Process.readProcLines("/proc/" + tid + "/status", procStatusLabels, procStatusValues);
90307b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten        return (int) procStatusValues[0];
90407b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    }
90507b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten
90607b0465095bd9ab3412caefa4fcacbdc3825c64bGlenn Kasten    /**
9079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the priority of a thread, based on Linux priorities.
9089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param tid The identifier of the thread/process to change.
9109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param priority A Linux priority level, from -20 for highest scheduling
9119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * priority to 19 for lowest scheduling priority.
9129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws IllegalArgumentException Throws IllegalArgumentException if
9149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <var>tid</var> does not exist.
9159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws SecurityException Throws SecurityException if your process does
9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * not have permission to modify the given thread, or to use the given
9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * priority.
9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native void setThreadPriority(int tid, int priority)
9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throws IllegalArgumentException, SecurityException;
921e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat
922e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat    /**
923160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     * Call with 'false' to cause future calls to {@link #setThreadPriority(int)} to
924160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     * throw an exception if passed a background-level thread priority.  This is only
925160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     * effective if the JNI layer is built with GUARD_THREAD_PRIORITY defined to 1.
926160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     *
927160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     * @hide
928160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate     */
929160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate    public static final native void setCanSelfBackground(boolean backgroundOk);
930160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate
931160edb3645f8b7012bab70ae6e6e8c4a5733082bChristopher Tate    /**
932e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * Sets the scheduling group for a thread.
933e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @hide
934f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * @param tid The identifier of the thread to change.
935f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * @param group The target group for this thread from THREAD_GROUP_*.
936e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     *
937e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @throws IllegalArgumentException Throws IllegalArgumentException if
938e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * <var>tid</var> does not exist.
939e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * @throws SecurityException Throws SecurityException if your process does
940e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * not have permission to modify the given thread, or to use the given
941e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     * priority.
942f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * If the thread is a thread group leader, that is it's gettid() == getpid(),
943f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * then the other threads in the same thread group are _not_ affected.
944e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat     */
945e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat    public static final native void setThreadGroup(int tid, int group)
946e9d376b801b7890b1ef5006ed55de4208e64bb63San Mehat            throws IllegalArgumentException, SecurityException;
947f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten
9483e458241d9930465a20a861ecb42744355d48e48San Mehat    /**
9493e458241d9930465a20a861ecb42744355d48e48San Mehat     * Sets the scheduling group for a process and all child threads
9503e458241d9930465a20a861ecb42744355d48e48San Mehat     * @hide
951f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * @param pid The identifier of the process to change.
952f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * @param group The target group for this process from THREAD_GROUP_*.
9533e458241d9930465a20a861ecb42744355d48e48San Mehat     *
9543e458241d9930465a20a861ecb42744355d48e48San Mehat     * @throws IllegalArgumentException Throws IllegalArgumentException if
9553e458241d9930465a20a861ecb42744355d48e48San Mehat     * <var>tid</var> does not exist.
9563e458241d9930465a20a861ecb42744355d48e48San Mehat     * @throws SecurityException Throws SecurityException if your process does
9573e458241d9930465a20a861ecb42744355d48e48San Mehat     * not have permission to modify the given thread, or to use the given
9583e458241d9930465a20a861ecb42744355d48e48San Mehat     * priority.
959f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     *
960f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * group == THREAD_GROUP_DEFAULT means to move all non-background priority
961f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * threads to the foreground scheduling group, but to leave background
962f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * priority threads alone.  group == THREAD_GROUP_BG_NONINTERACTIVE moves all
963f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * threads, regardless of priority, to the background scheduling group.
964f1b56449f58963e4f0473d5e26961f68c31759f4Glenn Kasten     * group == THREAD_GROUP_FOREGROUND is not allowed.
9653e458241d9930465a20a861ecb42744355d48e48San Mehat     */
9663e458241d9930465a20a861ecb42744355d48e48San Mehat    public static final native void setProcessGroup(int pid, int group)
9673e458241d9930465a20a861ecb42744355d48e48San Mehat            throws IllegalArgumentException, SecurityException;
9689e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey
9699e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey    /**
9709e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey     * Return the scheduling group of requested process.
9719e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey     *
9729e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey     * @hide
9739e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey     */
9749e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey    public static final native int getProcessGroup(int pid)
9759e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey            throws IllegalArgumentException, SecurityException;
9769e57c414f39e1a31349bc215635fdcfaf1902ceeJeff Sharkey
9779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Set the priority of the calling thread, based on Linux priorities.  See
9799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@link #setThreadPriority(int, int)} for more information.
9809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param priority A Linux priority level, from -20 for highest scheduling
9829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * priority to 19 for lowest scheduling priority.
9839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws IllegalArgumentException Throws IllegalArgumentException if
9859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <var>tid</var> does not exist.
9869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws SecurityException Throws SecurityException if your process does
9879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * not have permission to modify the given thread, or to use the given
9889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * priority.
9899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @see #setThreadPriority(int, int)
9919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
9929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native void setThreadPriority(int priority)
9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throws IllegalArgumentException, SecurityException;
9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Return the current priority of a thread, based on Linux priorities.
9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param tid The identifier of the thread/process to change.
9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Returns the current priority, as a Linux priority level,
10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * from -20 for highest scheduling priority to 19 for lowest scheduling
10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * priority.
10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @throws IllegalArgumentException Throws IllegalArgumentException if
10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * <var>tid</var> does not exist.
10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int getThreadPriority(int tid)
10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throws IllegalArgumentException;
10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10116793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * Set the scheduling policy and priority of a thread, based on Linux.
10126793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     *
10136793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @param tid The identifier of the thread/process to change.
10146793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @param policy A Linux scheduling policy such as SCHED_OTHER etc.
10156793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @param priority A Linux priority level in a range appropriate for the given policy.
10166793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     *
10176793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @throws IllegalArgumentException Throws IllegalArgumentException if
10186793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * <var>tid</var> does not exist, or if <var>priority</var> is out of range for the policy.
10196793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * @throws SecurityException Throws SecurityException if your process does
10206793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * not have permission to modify the given thread, or to use the given
10216793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * scheduling policy or priority.
10226793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     *
10236793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     * {@hide}
10246793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten     */
10256793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    public static final native void setThreadScheduler(int tid, int policy, int priority)
10266793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten            throws IllegalArgumentException;
10276793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten
10286793ac943afeb16642f477c43ddfd27e498db37bGlenn Kasten    /**
10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Determine whether the current environment supports multiple processes.
10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return Returns true if the system can run in multiple processes, else
10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * false if everything is running in a single process.
103310e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown     *
103410e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown     * @deprecated This method always returns true.  Do not use.
10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
103610e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown    @Deprecated
103710e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown    public static final boolean supportsProcesses() {
103810e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown        return true;
103910e89712863f5b91a2982dc1783fbdfe39c1485dJeff Brown    }
10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10425534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     * Adjust the swappiness level for a process.
10435534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     *
10445534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     * @param pid The process identifier to set.
10455534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     * @param is_increased Whether swappiness should be increased or default.
10465534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     *
10475534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     * @return Returns true if the underlying system supports this
10485534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     *         feature, else false.
10495534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     *
10505534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     * {@hide}
10515534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand     */
10525534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand    public static final native boolean setSwappiness(int pid, boolean is_increased);
10535534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand
10545534ba91ac0a0c9af822af62bcf92e2c5a8d6ec8Rom Lemarchand    /**
10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Change this process's argv[0] parameter.  This can be useful to show
10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * more descriptive information in things like the 'ps' command.
10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param text The new name of this process.
10599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * {@hide}
10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native void setArgV0(String text);
10639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Kill the process with the given PID.
10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Note that, though this API allows us to request to
10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * kill any process based on its PID, the kernel will
10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * still impose standard restrictions on which PIDs you
10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * are actually able to kill.  Typically this means only
10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * the process running the caller's packages/application
10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * and any additional processes created by that app; packages
10729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * sharing a common UID will also be able to kill each
10739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * other's processes.
10749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final void killProcess(int pid) {
10769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        sendSignal(pid, SIGNAL_KILL);
10779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int setUid(int uid);
10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int setGid(int uid);
10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Send a signal to the given process.
10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param pid The pid of the target process.
10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param signal The signal to send.
10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native void sendSignal(int pid, int signal);
10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1093906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn    /**
1094906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * @hide
1095906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * Private impl for avoiding a log message...  DO NOT USE without doing
1096906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * your own log, or the Android Illuminati will find you some night and
1097906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * beat you up.
1098906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     */
1099906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn    public static final void killProcessQuiet(int pid) {
1100906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn        sendSignalQuiet(pid, SIGNAL_KILL);
1101906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn    }
1102906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn
1103906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn    /**
1104906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * @hide
1105906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * Private impl for avoiding a log message...  DO NOT USE without doing
1106906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * your own log, or the Android Illuminati will find you some night and
1107906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     * beat you up.
1108906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn     */
1109906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn    public static final native void sendSignalQuiet(int pid, int signal);
1110906497c574d45d8dfd295b16dece0d0bc32c0895Dianne Hackborn
11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11120bca96bcbfe559f9330a01f723c5c9cba51ec05aMarco Nelissen    public static final native long getFreeMemory();
11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
111559325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn    public static final native long getTotalMemory();
111659325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn
111759325eb31f25704bb88c348160bb69e7c1aa3b48Dianne Hackborn    /** @hide */
11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native void readProcLines(String path,
11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String[] reqFields, long[] outSizes);
11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native int[] getPids(String path, int[] lastArray);
11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_TERM_MASK = 0xff;
11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_ZERO_TERM = 0;
11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_SPACE_TERM = (int)' ';
11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
1131c64edde69d18498fb2954f71a546357b07ab996aEvan Millar    public static final int PROC_TAB_TERM = (int)'\t';
1132c64edde69d18498fb2954f71a546357b07ab996aEvan Millar    /** @hide */
11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_COMBINE = 0x100;
11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_PARENS = 0x200;
11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
113713ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn    public static final int PROC_QUOTES = 0x400;
113813ac041b9f21043bc7c848a743be618bfd7a67e9Dianne Hackborn    /** @hide */
11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_OUT_STRING = 0x1000;
11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_OUT_LONG = 0x2000;
11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final int PROC_OUT_FLOAT = 0x4000;
11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /** @hide */
11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native boolean readProcFile(String file, int[] format,
11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String[] outStrings, long[] outLongs, float[] outFloats);
1148c64edde69d18498fb2954f71a546357b07ab996aEvan Millar
1149c64edde69d18498fb2954f71a546357b07ab996aEvan Millar    /** @hide */
1150c64edde69d18498fb2954f71a546357b07ab996aEvan Millar    public static final native boolean parseProcLine(byte[] buffer, int startIndex,
1151c64edde69d18498fb2954f71a546357b07ab996aEvan Millar            int endIndex, int[] format, String[] outStrings, long[] outLongs, float[] outFloats);
11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1153f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn    /** @hide */
1154f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn    public static final native int[] getPidsForCommands(String[] cmds);
1155f72467ad9843bf5d4b75fb308386e77ebb5c3447Dianne Hackborn
11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Gets the total Pss value for a given process, in bytes.
11589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
11599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param pid the process to the Pss for
11609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return the total Pss value for the given process in bytes,
11619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *  or -1 if the value cannot be determined
11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @hide
11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final native long getPss(int pid);
11653f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown
11663f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown    /**
11673f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown     * Specifies the outcome of having started a process.
11683f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown     * @hide
11693f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown     */
11703f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown    public static final class ProcessStartResult {
11713f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown        /**
11723f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown         * The PID of the newly started process.
11733f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown         * Always >= 0.  (If the start failed, an exception will have been thrown instead.)
11743f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown         */
11753f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown        public int pid;
11763f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown
11773f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown        /**
11783f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown         * True if the process was started with a wrapper attached.
11793f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown         */
11803f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown        public boolean usingWrapper;
11813f9dd287b99340efaaa257759e71a8f81b2ed113Jeff Brown    }
11820769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross
11830769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross    /**
11840769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * Kill all processes in a process group started for the given
11850769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * pid.
11860769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * @hide
11870769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     */
11880769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross    public static final native int killProcessGroup(int uid, int pid);
11890769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross
11900769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross    /**
11910769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * Remove all process groups.  Expected to be called when ActivityManager
11920769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * is restarted.
11930769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     * @hide
11940769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross     */
11950769e550011d8f8a19e333efe1706ef0e6cc6a5fColin Cross    public static final native void removeAllProcessGroups();
11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
1197