summaryrefslogtreecommitdiff
path: root/docs/html/sdk/api_diff/22/changes
diff options
context:
space:
mode:
authorriddle_hsu <riddle_hsu@htc.com>2014-07-08 04:30:19 +0800
committerriddle_hsu <riddle_hsu@htc.com>2014-07-08 04:30:19 +0800
commit7f1e3f3e93a9a42e221cffb09c5950135069bde2 (patch)
tree4cb47c60a418403c5253091cb40dbfbe7c5ddcce /docs/html/sdk/api_diff/22/changes
parentef2e76675a6c60a2a4764a2e19fdb2c4d9beb00e (diff)
[ActivityManager] Prevent potential deadlock from system error dialog and InputMethodManager.
Sympton: When application crash in a special timing and system server's InputMethodManager is binding, deadlock may occur. Root Cause: Thread(1): When using InputMethodManager in system server, it will lock mH(handler) of InputMethodManager, and sometimes it will call to InputMethodManagerService::showCurrentInputLocked and will call bindService at some condition, then it will also lock ActivityManagerService. Thread(2): When an application crashed, it will lock ActivityManager when showing crash dialog, inside the dialog, it will call setEnabled of Button and lock mH of InputMethodManager.setEnable of TextView will lock IMM's handler. So the deadlock happened as the flow: (2) lock AMS -> (1)lock mH -> (2)wait mH -> (1) wait AMS Solution: Reduce nested lock of error dialog: post message to let (2) lock mH after release AMS lock. Change-Id: Id85c29406236db3b5fca9655fde1fcaf0afd1337
Diffstat (limited to 'docs/html/sdk/api_diff/22/changes')
0 files changed, 0 insertions, 0 deletions