summaryrefslogtreecommitdiff
path: root/docs/html/sdk/api_diff
diff options
context:
space:
mode:
authorHai Zhang <zhanghai@google.com>2021-01-20 04:27:15 -0800
committerHai Zhang <zhanghai@google.com>2021-01-20 04:57:45 -0800
commit907dcf8fb867b6463e1cb8328e196dbfb0eb60c1 (patch)
treeb29968484a1b07ecdcf9f8883a8cfbe383592a0f /docs/html/sdk/api_diff
parent3f8337ff576f903bdc7149a42e6759c9eab08f7a (diff)
Fix granting default roles timeout.
The RoleControllerManager takes a Handler for service connection callbacks, and that Handler has to be a thread other than the main thread inside system server because we need to block the main thread before necessary permissions are granted via role. However, since a recent change that exposed RoleControllerManager APIs on RoleManager instead to hide this implementation detail from API, we are creating the RoleControllerManager instance upon RoleManager creation and implicitly initializing it with the main thread Handler. This may result in the RoleControllerManager getting the main thread handler instead of the desired foreground thread handler if someone else in the system server created RoleManager first, and that would create a deadlock when we block the main thread. So revert to the original timing for RoleControllerManager creation by creating it lazily, so that it gets the correct handler as the only user of it inside system server is RoleManagerService, and other services who only need the RoleManager won't affect RoleControllerManager. Fixes: 177251364 Test: manual Change-Id: I649a23fa3b88fbd9120b3de408eee8a590d50a17
Diffstat (limited to 'docs/html/sdk/api_diff')
0 files changed, 0 insertions, 0 deletions