From c5f86647b19d5cac4d9874ef84954fcf7a6d5fa9 Mon Sep 17 00:00:00 2001 From: Robert Sesek Date: Fri, 4 Nov 2016 10:20:38 -0400 Subject: [PATCH] Add new hostingType for startProcessLocked() that selects using the WebViewZygote. Test: m Test: angler boots Test: Turn on Multiprocess WebView in Developer Options and launch the WebView Shell. The sandboxed_service parent process is the webview_zygote. Bug: 21643067 Change-Id: I9dab548853372fd91f6bbe204cc8686ef2e94448 --- core/java/android/webkit/WebViewZygote.java | 4 ++++ .../com/android/server/am/ActiveServices.java | 8 +++++++- .../server/am/ActivityManagerService.java | 16 ++++++++++++---- 3 files changed, 23 insertions(+), 5 deletions(-) diff --git a/core/java/android/webkit/WebViewZygote.java b/core/java/android/webkit/WebViewZygote.java index c2069741d6cde..e0d589a8a8fbf 100644 --- a/core/java/android/webkit/WebViewZygote.java +++ b/core/java/android/webkit/WebViewZygote.java @@ -53,6 +53,10 @@ public class WebViewZygote { return sPackage.packageName; } + public static boolean isMultiprocessEnabled() { + return sMultiprocessEnabled && sPackage != null; + } + public static void setMultiprocessEnabled(boolean enabled) { sMultiprocessEnabled = enabled; diff --git a/services/core/java/com/android/server/am/ActiveServices.java b/services/core/java/com/android/server/am/ActiveServices.java index 2d534171b94d3..8bd729b4e6694 100644 --- a/services/core/java/com/android/server/am/ActiveServices.java +++ b/services/core/java/com/android/server/am/ActiveServices.java @@ -75,6 +75,7 @@ import android.util.EventLog; import android.util.Slog; import android.util.SparseArray; import android.util.TimeUtils; +import android.webkit.WebViewZygote; public final class ActiveServices { private static final String TAG = TAG_WITH_CLASS_NAME ? "ActiveServices" : TAG_AM; @@ -1689,6 +1690,7 @@ public final class ActiveServices { final boolean isolated = (r.serviceInfo.flags&ServiceInfo.FLAG_ISOLATED_PROCESS) != 0; final String procName = r.processName; + String hostingType = "service"; ProcessRecord app; if (!isolated) { @@ -1717,13 +1719,17 @@ public final class ActiveServices { // in the service any current isolated process it is running in or // waiting to have come up. app = r.isolatedProc; + if (WebViewZygote.isMultiprocessEnabled() + && r.serviceInfo.packageName.equals(WebViewZygote.getPackageName())) { + hostingType = "webview_service"; + } } // Not running -- get it started, and enqueue this service record // to be executed when the app comes up. if (app == null && !permissionsReviewRequired) { if ((app=mAm.startProcessLocked(procName, r.appInfo, true, intentFlags, - "service", r.name, false, isolated, false)) == null) { + hostingType, r.name, false, isolated, false)) == null) { String msg = "Unable to launch app " + r.appInfo.packageName + "/" + r.appInfo.uid + " for service " diff --git a/services/core/java/com/android/server/am/ActivityManagerService.java b/services/core/java/com/android/server/am/ActivityManagerService.java index 0f54d23ce75b3..0f9162ae5d7e8 100644 --- a/services/core/java/com/android/server/am/ActivityManagerService.java +++ b/services/core/java/com/android/server/am/ActivityManagerService.java @@ -3745,10 +3745,18 @@ public final class ActivityManagerService extends ActivityManagerNative Trace.traceBegin(Trace.TRACE_TAG_ACTIVITY_MANAGER, "Start proc: " + app.processName); checkTime(startTime, "startProcess: asking zygote to start proc"); - Process.ProcessStartResult startResult = Process.start(entryPoint, - app.processName, uid, uid, gids, debugFlags, mountExternal, - app.info.targetSdkVersion, app.info.seinfo, requiredAbi, instructionSet, - app.info.dataDir, entryPointArgs); + Process.ProcessStartResult startResult; + if (hostingType.equals("webview_service")) { + startResult = Process.startWebView(entryPoint, + app.processName, uid, uid, gids, debugFlags, mountExternal, + app.info.targetSdkVersion, app.info.seinfo, requiredAbi, instructionSet, + app.info.dataDir, entryPointArgs); + } else { + startResult = Process.start(entryPoint, + app.processName, uid, uid, gids, debugFlags, mountExternal, + app.info.targetSdkVersion, app.info.seinfo, requiredAbi, instructionSet, + app.info.dataDir, entryPointArgs); + } checkTime(startTime, "startProcess: returned from zygote!"); Trace.traceEnd(Trace.TRACE_TAG_ACTIVITY_MANAGER);