diff options
author | Nick Kralevich <nnk@google.com> | 2013-04-23 15:30:45 -0700 |
---|---|---|
committer | Nick Kralevich <nnk@google.com> | 2013-04-23 15:40:03 -0700 |
commit | fc17dc2548234461eb43ff83539ede4c9893a825 (patch) | |
tree | 8f8bbf8c1ab2defe9926b461fa9090222ced4275 /cmds/app_process | |
parent | be4536d214eedc3d12b50f0f30b47bba773b8dbc (diff) | |
download | frameworks_base-fc17dc2548234461eb43ff83539ede4c9893a825.zip frameworks_base-fc17dc2548234461eb43ff83539ede4c9893a825.tar.gz frameworks_base-fc17dc2548234461eb43ff83539ede4c9893a825.tar.bz2 |
Don't set ADDR_COMPAT_LAYOUT on the emulator
Don't work around third party app bugs on the emulator.
Change-Id: I4440fcd56b72e3a74881ddec2a469f037a060525
Diffstat (limited to 'cmds/app_process')
-rw-r--r-- | cmds/app_process/app_main.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/cmds/app_process/app_main.cpp b/cmds/app_process/app_main.cpp index 0668be6..6f37180 100644 --- a/cmds/app_process/app_main.cpp +++ b/cmds/app_process/app_main.cpp @@ -7,6 +7,7 @@ #define LOG_TAG "appproc" +#include <cutils/properties.h> #include <binder/IPCThreadState.h> #include <binder/ProcessState.h> #include <utils/Log.h> @@ -144,7 +145,10 @@ int main(int argc, char* const argv[]) * This breaks some programs which improperly embed * an out of date copy of Android's linker. */ - if (getenv("NO_ADDR_COMPAT_LAYOUT_FIXUP") == NULL) { + char value[PROPERTY_VALUE_MAX]; + property_get("ro.kernel.qemu", value, ""); + bool is_qemu = (strcmp(value, "1") == 0); + if ((getenv("NO_ADDR_COMPAT_LAYOUT_FIXUP") == NULL) && !is_qemu) { int current = personality(0xFFFFFFFF); if ((current & ADDR_COMPAT_LAYOUT) == 0) { personality(current | ADDR_COMPAT_LAYOUT); |