summaryrefslogtreecommitdiffstats
path: root/core/jni
diff options
context:
space:
mode:
authorCalin Juravle <calin@google.com>2014-10-27 15:16:03 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2014-10-27 15:16:03 +0000
commitf7d24d244319599f62c22e29c3e6540d6cbadf49 (patch)
tree0ea8ad3b6ec454abbbec233f3806b00cf7b280e1 /core/jni
parentced7ebdb1d522b4206e2048b278554ca841aeaba (diff)
parent79ec4c15ab941419d21700a9734f5238b975c31a (diff)
downloadframeworks_base-f7d24d244319599f62c22e29c3e6540d6cbadf49.zip
frameworks_base-f7d24d244319599f62c22e29c3e6540d6cbadf49.tar.gz
frameworks_base-f7d24d244319599f62c22e29c3e6540d6cbadf49.tar.bz2
Merge "PreInitializeNativeBridge only if its Available"
Diffstat (limited to 'core/jni')
-rw-r--r--core/jni/com_android_internal_os_Zygote.cpp26
1 files changed, 13 insertions, 13 deletions
diff --git a/core/jni/com_android_internal_os_Zygote.cpp b/core/jni/com_android_internal_os_Zygote.cpp
index 6dc29ed..0c953aa 100644
--- a/core/jni/com_android_internal_os_Zygote.cpp
+++ b/core/jni/com_android_internal_os_Zygote.cpp
@@ -416,6 +416,10 @@ static pid_t ForkAndSpecializeCommon(JNIEnv* env, uid_t uid, gid_t gid, jintArra
pid_t pid = fork();
if (pid == 0) {
+ if (!is_system_server && dataDir == NULL) {
+ ALOGE("Application private dir cannot be null");
+ RuntimeAbort(env);
+ }
// The child process.
gMallocLeakZygoteChild = 1;
@@ -429,13 +433,14 @@ static pid_t ForkAndSpecializeCommon(JNIEnv* env, uid_t uid, gid_t gid, jintArra
DropCapabilitiesBoundingSet(env);
- bool need_native_bridge = false;
- if (instructionSet != NULL) {
+ bool use_native_bridge = !is_system_server && (instructionSet != NULL)
+ && android::NativeBridgeAvailable();
+ if (use_native_bridge) {
ScopedUtfChars isa_string(env, instructionSet);
- need_native_bridge = android::NeedsNativeBridge(isa_string.c_str());
+ use_native_bridge = android::NeedsNativeBridge(isa_string.c_str());
}
- if (!MountEmulatedStorage(uid, mount_external, need_native_bridge)) {
+ if (!MountEmulatedStorage(uid, mount_external, use_native_bridge)) {
ALOGW("Failed to mount emulated storage: %s", strerror(errno));
if (errno == ENOTCONN || errno == EROFS) {
// When device is actively encrypting, we get ENOTCONN here
@@ -453,15 +458,10 @@ static pid_t ForkAndSpecializeCommon(JNIEnv* env, uid_t uid, gid_t gid, jintArra
SetRLimits(env, javaRlimits);
- if (!is_system_server && need_native_bridge) {
- // Set the environment for the apps running with native bridge.
- ScopedUtfChars isa_string(env, instructionSet); // Known non-null because of need_native_...
- if (dataDir == NULL) {
- android::PreInitializeNativeBridge(NULL, isa_string.c_str());
- } else {
- ScopedUtfChars data_dir(env, dataDir);
- android::PreInitializeNativeBridge(data_dir.c_str(), isa_string.c_str());
- }
+ if (use_native_bridge) {
+ ScopedUtfChars isa_string(env, instructionSet);
+ ScopedUtfChars data_dir(env, dataDir);
+ android::PreInitializeNativeBridge(data_dir.c_str(), isa_string.c_str());
}
int rc = setresgid(gid, gid, gid);