summaryrefslogtreecommitdiffstats
path: root/core/java
diff options
context:
space:
mode:
authorBrad Fitzpatrick <bradfitz@android.com>2010-11-24 15:27:51 -0800
committerBrad Fitzpatrick <bradfitz@android.com>2010-11-24 15:27:51 -0800
commitf54545927f365d6e55cbf66ff9f7ffe91aada774 (patch)
tree830fec91bfb6aaae4b03e50dfc679a45e6832911 /core/java
parented798a0dd62fc267d941fb592dfc99e6ae968324 (diff)
downloadframeworks_base-f54545927f365d6e55cbf66ff9f7ffe91aada774.zip
frameworks_base-f54545927f365d6e55cbf66ff9f7ffe91aada774.tar.gz
frameworks_base-f54545927f365d6e55cbf66ff9f7ffe91aada774.tar.bz2
Don't flash StrictMode from the system server.
These are false positives from a developer's point of view. Change-Id: Ic8baf81c0e2cf559a38c1fe6adfa6e739dd3eaed
Diffstat (limited to 'core/java')
-rw-r--r--core/java/android/os/StrictMode.java26
1 files changed, 25 insertions, 1 deletions
diff --git a/core/java/android/os/StrictMode.java b/core/java/android/os/StrictMode.java
index c2ecf13..754d073 100644
--- a/core/java/android/os/StrictMode.java
+++ b/core/java/android/os/StrictMode.java
@@ -719,13 +719,37 @@ public final class StrictMode {
return new ThreadPolicy(oldPolicyMask);
}
+ // We don't want to flash the screen red in the system server
+ // process, nor do we want to modify all the call sites of
+ // conditionallyEnableDebugLogging() in the system server,
+ // so instead we use this to determine if we are the system server.
+ private static boolean amTheSystemServerProcess() {
+ // Fast path. Most apps don't have the system server's UID.
+ if (Process.myUid() != Process.SYSTEM_UID) {
+ return false;
+ }
+
+ // The settings app, though, has the system server's UID so
+ // look up our stack to see if we came from the system server.
+ Throwable stack = new Throwable();
+ stack.fillInStackTrace();
+ for (StackTraceElement ste : stack.getStackTrace()) {
+ String clsName = ste.getClassName();
+ if (clsName != null && clsName.startsWith("com.android.server.")) {
+ return true;
+ }
+ }
+ return false;
+ }
+
/**
* Enable DropBox logging for debug phone builds.
*
* @hide
*/
public static boolean conditionallyEnableDebugLogging() {
- boolean doFlashes = SystemProperties.getBoolean(VISUAL_PROPERTY, IS_ENG_BUILD);
+ boolean doFlashes = !amTheSystemServerProcess() &&
+ SystemProperties.getBoolean(VISUAL_PROPERTY, IS_ENG_BUILD);
// For debug builds, log event loop stalls to dropbox for analysis.
// Similar logic also appears in ActivityThread.java for system apps.