summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Yohei Yukawa <yukawa@google.com> 2024-02-08 11:03:51 -0800
committer Yohei Yukawa <yukawa@google.com> 2024-02-08 12:07:15 -0800
commitd1f53e5ed941424de59cfbd90817429451e30edd (patch)
treedf0207a9aed7665c1a9b2db9b40ee415ee9602d5
parent8e3ca63b321cc8055495f6032e76d06bf1f64fa7 (diff)
Fix the missing lock in onPackageDataCleared()
As a preparation for supporting concurrent multi-user with MyPackageMonitor, with this CL fixes a missing lock in MyPackageMonitor#onPackageDataCleared, which was introduced recently [1]. As fields like InputMethodManager#mSettings InputMethodManager#mAdditionalSubtypeMap need to be touched only within ImfLock, we still need an explicit lock there. [1]: I159d9b7a2d1dcc8df478bb45d0be706d615724a2 18a26c88a8c73d18b3aedf513ad4dc4c698fbf0e Bug: 267124364 Bug: 309837937 Bug: 322062773 Test: manually tested the case. Change-Id: Ida9e9143324ccf0e5bcff224fbb0e4e6650996b0
-rw-r--r--services/core/java/com/android/server/inputmethod/InputMethodManagerService.java22
1 files changed, 12 insertions, 10 deletions
diff --git a/services/core/java/com/android/server/inputmethod/InputMethodManagerService.java b/services/core/java/com/android/server/inputmethod/InputMethodManagerService.java
index 3bd1e1a43629..c023993a24f7 100644
--- a/services/core/java/com/android/server/inputmethod/InputMethodManagerService.java
+++ b/services/core/java/com/android/server/inputmethod/InputMethodManagerService.java
@@ -1331,17 +1331,19 @@ public final class InputMethodManagerService extends IInputMethodManager.Stub
@Override
public void onPackageDataCleared(String packageName, int uid) {
- boolean changed = false;
- for (InputMethodInfo imi : mSettings.getMethodList()) {
- if (imi.getPackageName().equals(packageName)) {
- mAdditionalSubtypeMap.remove(imi.getId());
- changed = true;
+ synchronized (ImfLock.class) {
+ boolean changed = false;
+ for (InputMethodInfo imi : mSettings.getMethodList()) {
+ if (imi.getPackageName().equals(packageName)) {
+ mAdditionalSubtypeMap.remove(imi.getId());
+ changed = true;
+ }
+ }
+ if (changed) {
+ AdditionalSubtypeUtils.save(
+ mAdditionalSubtypeMap, mSettings.getMethodMap(), mSettings.getUserId());
+ mChangedPackages.add(packageName);
}
- }
- if (changed) {
- AdditionalSubtypeUtils.save(
- mAdditionalSubtypeMap, mSettings.getMethodMap(), mSettings.getUserId());
- mChangedPackages.add(packageName);
}
}