diff options
| author | Evan Laird <evanlaird@google.com> | 2019-04-09 16:24:27 -0400 | 
|---|---|---|
| committer | Malcolm Chen <refuhoo@google.com> | 2019-04-09 19:35:21 -0700 | 
| commit | 470ae84f66ce28031fb8adc14068db69429d385d (patch) | |
| tree | 2a1ba7d5231a23f70170ed767085702af16ca7af /tests/DynamicCodeLoggerIntegrationTests/src/cpp/test_executable.cpp | |
| parent | f8d48b03168016dd2da80fd2911e021ea3df496f (diff) | |
Guard against creating too many MobileSignalControllers
The PhoneStateListener that got added to NetworkControllerImpl used the
default (main) looper for its callbacks, which caused race conditions
when updating subscriptions. This resulted in zombie
MobileSignalControllers that were untracked and never stopped listening
for their updates.
To fix the problem we put the phone state listener on the same
background thread as the receiver handler, and also lock around updating
the subscriptions so that we can all have peace of mind.
This should fix a host of issues where the mobile signal is incorrectly
showing state such as disconnected or not showing the data type
indicator.
Fixes: 129717207
Test: visual; remove and insert sim and verify that the proper SIM state
is shown
Change-Id: Iace6a04c0629e24d2ef9c980a8de336a225d0f36
Diffstat (limited to 'tests/DynamicCodeLoggerIntegrationTests/src/cpp/test_executable.cpp')
0 files changed, 0 insertions, 0 deletions
