summaryrefslogtreecommitdiff
path: root/docs/html/sdk/api_diff/4/changes
diff options
context:
space:
mode:
authorMÃ¥rten Kongstad <marten.kongstad@volvocars.com>2021-01-14 13:46:15 +0000
committerRyan Mitchell <rtmitchell@google.com>2021-01-21 14:33:40 +0000
commitea0b864a1a6e8cbcb019b99c3cdd5c4b99e2c43c (patch)
tree6647501d93cc3d4b007f505cd06f4c2748b80022 /docs/html/sdk/api_diff/4/changes
parentdc427169c958b711466c670b626a997603005ba2 (diff)
OMS: reduce number of OVERLAY_CHANGED broadcasts
As part of "I63df58510:OMS: add transactional API", the OMS changed how to broadcast OVERLAY_CHANGED. The intent used to be sent <once> when an overlay changed state. This was modified to <once per package affected> when an overlay changed state. While this makes it easier for applications to detect if they have been forced to reload their resources, the change drastically increased the number of OVERLAY_CHANGED intents, especially when the target package is "android" which affects all packages. To make matters worse, the package manager responds to an OVERLAY_CHANGED intent by broadcasting PACKAGE_CHANGED. Ultimately the flood of intents caused lock contentions in the activity manager. Revert the OMS strategy for how to broadcast OVERLAY_CHANGED to the old behaviour. Bug: 177065099 Test: atest FrameworksServicesTests:com.android.server.om OverlayDeviceTests OverlayHostTests CtsAppSecurityHostTestCases:OverlayHostTest Test: manual: adb exec-out cmd activity dump # check for OVERLAY_CHANGED in "Historical broadcasts" Change-Id: I33358ce4dc1d72e6e695c70cf02ab72526592b17
Diffstat (limited to 'docs/html/sdk/api_diff/4/changes')
0 files changed, 0 insertions, 0 deletions