summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author hansson <hansson@google.com> 2018-02-13 16:39:33 +0000
committer android-build-merger <android-build-merger@google.com> 2018-02-13 16:39:33 +0000
commit927afd1edf81f6a87258977e5da3506d5679ccab (patch)
tree56cdde6537ed5c297375b238432eb00467c93fa3
parent82d572ed07687b12b444ae15611c56b514c24701 (diff)
parent78d15fd15aa8809c26cd335b5eaaf688a148b037 (diff)
Merge "fix misleading FATAL EXCEPTION IN SYSTEM PROCESS log" am: c0c9f53175
am: 78d15fd15a Change-Id: Ie90bccf5aa5fb67e1b4769fcbb1013b1fae71063
-rw-r--r--core/java/com/android/internal/os/RuntimeInit.java9
1 files changed, 5 insertions, 4 deletions
diff --git a/core/java/com/android/internal/os/RuntimeInit.java b/core/java/com/android/internal/os/RuntimeInit.java
index 66475e445efa..895be082c679 100644
--- a/core/java/com/android/internal/os/RuntimeInit.java
+++ b/core/java/com/android/internal/os/RuntimeInit.java
@@ -71,10 +71,11 @@ public class RuntimeInit {
public void uncaughtException(Thread t, Throwable e) {
// Don't re-enter if KillApplicationHandler has already run
if (mCrashing) return;
- if (mApplicationObject == null) {
- // The "FATAL EXCEPTION" string is still used on Android even though
- // apps can set a custom UncaughtExceptionHandler that renders uncaught
- // exceptions non-fatal.
+
+ // mApplicationObject is null for non-zygote java programs (e.g. "am")
+ // There are also apps running with the system UID. We don't want the
+ // first clause in either of these two cases, only for system_server.
+ if (mApplicationObject == null && (Process.SYSTEM_UID == Process.myUid())) {
Clog_e(TAG, "*** FATAL EXCEPTION IN SYSTEM PROCESS: " + t.getName(), e);
} else {
StringBuilder message = new StringBuilder();