Merge "Frameworks/base: Add debug.gencfi property"
This commit is contained in:
@ -634,6 +634,9 @@ public class Process {
|
|||||||
if ((debugFlags & Zygote.DEBUG_ENABLE_JIT) != 0) {
|
if ((debugFlags & Zygote.DEBUG_ENABLE_JIT) != 0) {
|
||||||
argsForZygote.add("--enable-jit");
|
argsForZygote.add("--enable-jit");
|
||||||
}
|
}
|
||||||
|
if ((debugFlags & Zygote.DEBUG_GENERATE_CFI) != 0) {
|
||||||
|
argsForZygote.add("--generate-cfi");
|
||||||
|
}
|
||||||
if ((debugFlags & Zygote.DEBUG_ENABLE_ASSERT) != 0) {
|
if ((debugFlags & Zygote.DEBUG_ENABLE_ASSERT) != 0) {
|
||||||
argsForZygote.add("--enable-assert");
|
argsForZygote.add("--enable-assert");
|
||||||
}
|
}
|
||||||
|
@ -40,6 +40,8 @@ public final class Zygote {
|
|||||||
public static final int DEBUG_ENABLE_JNI_LOGGING = 1 << 4;
|
public static final int DEBUG_ENABLE_JNI_LOGGING = 1 << 4;
|
||||||
/** enable the JIT compiler */
|
/** enable the JIT compiler */
|
||||||
public static final int DEBUG_ENABLE_JIT = 1 << 5;
|
public static final int DEBUG_ENABLE_JIT = 1 << 5;
|
||||||
|
/** Force generation of CFI code */
|
||||||
|
public static final int DEBUG_GENERATE_CFI = 1 << 6;
|
||||||
|
|
||||||
|
|
||||||
/** No external storage should be mounted. */
|
/** No external storage should be mounted. */
|
||||||
|
@ -322,7 +322,7 @@ class ZygoteConnection {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* From --enable-debugger, --enable-checkjni, --enable-assert,
|
* From --enable-debugger, --enable-checkjni, --enable-assert,
|
||||||
* --enable-safemode, --enable-jit, and --enable-jni-logging.
|
* --enable-safemode, --enable-jit, --generate-cfi and --enable-jni-logging.
|
||||||
*/
|
*/
|
||||||
int debugFlags;
|
int debugFlags;
|
||||||
|
|
||||||
@ -434,6 +434,8 @@ class ZygoteConnection {
|
|||||||
debugFlags |= Zygote.DEBUG_ENABLE_CHECKJNI;
|
debugFlags |= Zygote.DEBUG_ENABLE_CHECKJNI;
|
||||||
} else if (arg.equals("--enable-jit")) {
|
} else if (arg.equals("--enable-jit")) {
|
||||||
debugFlags |= Zygote.DEBUG_ENABLE_JIT;
|
debugFlags |= Zygote.DEBUG_ENABLE_JIT;
|
||||||
|
} else if (arg.equals("--generate-cfi")) {
|
||||||
|
debugFlags |= Zygote.DEBUG_GENERATE_CFI;
|
||||||
} else if (arg.equals("--enable-jni-logging")) {
|
} else if (arg.equals("--enable-jni-logging")) {
|
||||||
debugFlags |= Zygote.DEBUG_ENABLE_JNI_LOGGING;
|
debugFlags |= Zygote.DEBUG_ENABLE_JNI_LOGGING;
|
||||||
} else if (arg.equals("--enable-assert")) {
|
} else if (arg.equals("--enable-assert")) {
|
||||||
|
@ -873,6 +873,19 @@ int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv)
|
|||||||
snprintf(cpuAbiListBuf, sizeof(cpuAbiListBuf), "--cpu-abilist=%s", propBuf);
|
snprintf(cpuAbiListBuf, sizeof(cpuAbiListBuf), "--cpu-abilist=%s", propBuf);
|
||||||
addOption(cpuAbiListBuf);
|
addOption(cpuAbiListBuf);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* When running with debug.gencfi, add --include-cfi to the compiler options so that the boot
|
||||||
|
* image, if it is compiled on device, will include CFI info, as well as other compilations
|
||||||
|
* started by the runtime.
|
||||||
|
*/
|
||||||
|
property_get("debug.gencfi", propBuf, "");
|
||||||
|
if (strcmp(propBuf, "true") == 0) {
|
||||||
|
addOption("-Xcompiler-option");
|
||||||
|
addOption("--include-cfi");
|
||||||
|
addOption("-Ximage-compiler-option");
|
||||||
|
addOption("--include-cfi");
|
||||||
|
}
|
||||||
|
|
||||||
initArgs.version = JNI_VERSION_1_4;
|
initArgs.version = JNI_VERSION_1_4;
|
||||||
initArgs.options = mOptions.editArray();
|
initArgs.options = mOptions.editArray();
|
||||||
initArgs.nOptions = mOptions.size();
|
initArgs.nOptions = mOptions.size();
|
||||||
|
@ -3016,6 +3016,10 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
debugFlags |= Zygote.DEBUG_ENABLE_JIT;
|
debugFlags |= Zygote.DEBUG_ENABLE_JIT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
String genCFIDebugProperty = SystemProperties.get("debug.gencfi");
|
||||||
|
if ("true".equals(genCFIDebugProperty)) {
|
||||||
|
debugFlags |= Zygote.DEBUG_GENERATE_CFI;
|
||||||
|
}
|
||||||
if ("1".equals(SystemProperties.get("debug.jni.logging"))) {
|
if ("1".equals(SystemProperties.get("debug.jni.logging"))) {
|
||||||
debugFlags |= Zygote.DEBUG_ENABLE_JNI_LOGGING;
|
debugFlags |= Zygote.DEBUG_ENABLE_JNI_LOGGING;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user