diff options
| -rw-r--r-- | services/core/java/com/android/server/am/ActivityManagerService.java | 5 | ||||
| -rw-r--r-- | services/core/java/com/android/server/am/UserController.java | 3 |
2 files changed, 6 insertions, 2 deletions
diff --git a/services/core/java/com/android/server/am/ActivityManagerService.java b/services/core/java/com/android/server/am/ActivityManagerService.java index 8207877cbe31..0c31ade90650 100644 --- a/services/core/java/com/android/server/am/ActivityManagerService.java +++ b/services/core/java/com/android/server/am/ActivityManagerService.java @@ -21433,8 +21433,9 @@ public final class ActivityManagerService extends ActivityManagerNative @Override public boolean isUserRunning(int userId, int flags) { - if (userId != UserHandle.getCallingUserId() && checkCallingPermission( - INTERACT_ACROSS_USERS) != PackageManager.PERMISSION_GRANTED) { + if (!mUserController.isSameProfileGroup(userId, UserHandle.getCallingUserId()) + && checkCallingPermission(INTERACT_ACROSS_USERS) + != PackageManager.PERMISSION_GRANTED) { String msg = "Permission Denial: isUserRunning() from pid=" + Binder.getCallingPid() + ", uid=" + Binder.getCallingUid() diff --git a/services/core/java/com/android/server/am/UserController.java b/services/core/java/com/android/server/am/UserController.java index b685dd3f6771..57dfb7ea41a7 100644 --- a/services/core/java/com/android/server/am/UserController.java +++ b/services/core/java/com/android/server/am/UserController.java @@ -1453,6 +1453,9 @@ final class UserController { } boolean isSameProfileGroup(int callingUserId, int targetUserId) { + if (callingUserId == targetUserId) { + return true; + } synchronized (mUserProfileGroupIdsSelfLocked) { int callingProfile = mUserProfileGroupIdsSelfLocked.get(callingUserId, UserInfo.NO_PROFILE_GROUP_ID); |