diff options
author | Nick Kralevich <nnk@google.com> | 2013-03-15 11:38:29 -0700 |
---|---|---|
committer | Nick Kralevich <nnk@google.com> | 2013-03-15 11:59:03 -0700 |
commit | 1fe21bd1b6ca8b94c78fbf3666a1e8e0472355de (patch) | |
tree | d3fe55e4014a23cc1d6991ce3110b26a2d97de83 /cmds | |
parent | 1ae6ae2094fd0ab8c82ad1a347e7a8bd67d995e5 (diff) | |
download | frameworks_base-1fe21bd1b6ca8b94c78fbf3666a1e8e0472355de.zip frameworks_base-1fe21bd1b6ca8b94c78fbf3666a1e8e0472355de.tar.gz frameworks_base-1fe21bd1b6ca8b94c78fbf3666a1e8e0472355de.tar.bz2 |
Never call app_main more than once
Different kernels seem to handle ADDR_COMPAT_LAYOUT differently,
sometimes passing it to its children, sometimes not. If it's not
passed to its child successfully, we can end up in a restart loop.
Instead of testing for the presence of ADDR_COMPAT_LAYOUT, use an
environment variable instead, which is handled more predictably.
Bug: 8392487
Change-Id: Ia531dd2abb4e1cd46f3430d844e644f53581f530
Diffstat (limited to 'cmds')
-rw-r--r-- | cmds/app_process/app_main.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/cmds/app_process/app_main.cpp b/cmds/app_process/app_main.cpp index b54774e..80df568 100644 --- a/cmds/app_process/app_main.cpp +++ b/cmds/app_process/app_main.cpp @@ -12,10 +12,10 @@ #include <utils/Log.h> #include <cutils/process_name.h> #include <cutils/memory.h> -#include <cutils/properties.h> #include <android_runtime/AndroidRuntime.h> #include <sys/personality.h> +#include <stdlib.h> #include <stdio.h> #include <unistd.h> @@ -144,12 +144,11 @@ int main(int argc, char* const argv[]) * This breaks some programs which improperly embed * an out of date copy of Android's linker. */ - char value[PROPERTY_VALUE_MAX]; - property_get("ro.kernel.qemu", value, ""); - if (strcmp(value, "1") != 0) { + if (getenv("NO_ADDR_COMPAT_LAYOUT_FIXUP") == NULL) { int current = personality(0xFFFFFFFF); if ((current & ADDR_COMPAT_LAYOUT) == 0) { personality(current | ADDR_COMPAT_LAYOUT); + setenv("NO_ADDR_COMPAT_LAYOUT_FIXUP", "1", 1); execv("/system/bin/app_process", argv); return -1; } |