From: chen xu Date: Sun, 17 Mar 2019 07:50:56 +0000 (-0700) Subject: improve mism support for phonestatelistner X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=2506ceb71e1535af49fd3495f8eae0bbdfe36c5b;p=android-x86%2Fframeworks-base.git improve mism support for phonestatelistner 1. throw exception if reuse the same listner for different sub 2. subId should come from TM instance not phonestateListener. 3. refactor settings to apply phonestatelistner with TM instances Bug: 117555407 Test: Manual Change-Id: I1af07798d7982575cccc27462af179182c033409 (cherry picked from commit 0ebc9b67e96d0c4a625837ce7a32dbea4afa44ab) Merged-in: I1af07798d7982575cccc27462af179182c033409 --- diff --git a/services/core/java/com/android/server/TelephonyRegistry.java b/services/core/java/com/android/server/TelephonyRegistry.java index d2a0d7bc23fa..fdd698f19991 100644 --- a/services/core/java/com/android/server/TelephonyRegistry.java +++ b/services/core/java/com/android/server/TelephonyRegistry.java @@ -627,6 +627,11 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub { r.callingPackage = callingPackage; r.callerUid = Binder.getCallingUid(); r.callerPid = Binder.getCallingPid(); + if (r.subId != SubscriptionManager.INVALID_SUBSCRIPTION_ID && r.subId != subId) { + throw new IllegalArgumentException( + "PhoneStateListener cannot concurrently listen on multiple " + + "subscriptions. Previously registered on subId: " + r.subId); + } // Legacy applications pass SubscriptionManager.DEFAULT_SUB_ID, // force all illegal subId to SubscriptionManager.DEFAULT_SUB_ID if (!SubscriptionManager.isValidSubscriptionId(subId)) { diff --git a/telephony/java/android/telephony/TelephonyManager.java b/telephony/java/android/telephony/TelephonyManager.java index 973cd77916b5..43dcc6b27c66 100644 --- a/telephony/java/android/telephony/TelephonyManager.java +++ b/telephony/java/android/telephony/TelephonyManager.java @@ -4755,18 +4755,22 @@ public class TelephonyManager { * Registers a listener object to receive notification of changes * in specified telephony states. *

- * To register a listener, pass a {@link PhoneStateListener} - * and specify at least one telephony state of interest in - * the events argument. - * - * At registration, and when a specified telephony state - * changes, the telephony manager invokes the appropriate - * callback method on the listener object and passes the - * current (updated) values. + * To register a listener, pass a {@link PhoneStateListener} and specify at least one telephony + * state of interest in the events argument. + * + * At registration, and when a specified telephony state changes, the telephony manager invokes + * the appropriate callback method on the listener object and passes the current (updated) + * values. *

- * To unregister a listener, pass the listener object and set the - * events argument to + * To un-register a listener, pass the listener object and set the events argument to * {@link PhoneStateListener#LISTEN_NONE LISTEN_NONE} (0). + * + * If this TelephonyManager object has been created with {@link #createForSubscriptionId}, + * applies to the given subId. Otherwise, applies to + * {@link SubscriptionManager#getDefaultSubscriptionId()}. To listen events for multiple subIds, + * pass a separate listener object to each TelephonyManager object created with + * {@link #createForSubscriptionId}. + * * Note: if you call this method while in the middle of a binder transaction, you must * call {@link android.os.Binder#clearCallingIdentity()} before calling this method. A * {@link SecurityException} will be thrown otherwise. @@ -4781,17 +4785,18 @@ public class TelephonyManager { if (mContext == null) return; try { boolean notifyNow = (getITelephony() != null); - // If the listener has not explicitly set the subId (for example, created with the - // default constructor), replace the subId so it will listen to the account the - // telephony manager is created with. - if (listener.mSubId == null) { - listener.mSubId = mSubId; - } - ITelephonyRegistry registry = getTelephonyRegistry(); if (registry != null) { - registry.listenForSubscriber(listener.mSubId, getOpPackageName(), + // listen to the subId the telephony manager is created with. Ignore subId in + // PhoneStateListener. + registry.listenForSubscriber(mSubId, getOpPackageName(), listener.callback, events, notifyNow); + // TODO: remove this once we remove PhoneStateListener constructor with subId. + if (events == PhoneStateListener.LISTEN_NONE) { + listener.mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID; + } else { + listener.mSubId = mSubId; + } } else { Rlog.w(TAG, "telephony registry not ready."); }