Found 22225 results in 3577 files, showing top 50 files (show more).
android.googlesource.com/platform/packages/services/Telephony:src/com/android/phone/PhoneInterfaceManager.java: [ master, ]
433:         public Phone phone;
17: package com.android.phone;
223: public class PhoneInterfaceManager extends ITelephony.Stub {
2097:     private PhoneInterfaceManager(PhoneGlobals app) {
2115:     private Phone getDefaultPhone() {
2149:     private Phone getPhone(int subId) {
2801:     public String getNetworkCountryIsoForPhone(int phoneId) {
6556:     public int checkCarrierPrivilegesForPackageAnyPhone(String pkgName) {
6579:     public List<String> getCarrierPackageNamesForIntentAndPhone(Intent intent, int phoneId) {
7077:     public boolean isWorldPhone(int subId, String callingPackage, String callingFeatureId) {
351:     private PhoneConfigurationManager mPhoneConfigurationManager;
2129:     private Phone getPhoneFromRequest(MainThreadRequest request) {
2137:     private Phone getPhoneFromSubId(int subId) {
2298:         private final int mPhoneId;
2577:     private void shutdownRadioUsingPhoneId(int phoneId) {
3219:     public int getActivePhoneType() {
3224:     public int getActivePhoneTypeForSlot(int slotIndex) {
4265:     private void checkModifyPhoneStatePermission(int subId, String message) {
4917:     private Phone getPhoneFromSlotIdOrThrowException(int slotIndex) {
6623:     public List<String> getPackagesWithCarrierPrivilegesForAllPhones() {
7203:     public int getSubIdForPhoneAccount(PhoneAccount phoneAccount) {
7213:     public int getSubIdForPhoneAccountHandle(
7228:     public @Nullable PhoneAccountHandle getPhoneAccountHandleForSubscriptionId(int subscriptionId) {
9536:     private boolean isAnyPhoneInEmergencyState() {
10354:     public PhoneCapability getPhoneCapability() {
21: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_CDMA;
22: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_GSM;
23: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_IMS;
159: import com.android.internal.telephony.Phone;
195: import com.android.phone.settings.PickSmsSubscriptionActivity;
196: import com.android.phone.vvm.PhoneAccountHandleConverter;
197: import com.android.phone.vvm.RemoteVvmTaskManager;
198: import com.android.phone.vvm.VisualVoicemailSettingsUtil;
199: import com.android.phone.vvm.VisualVoicemailSmsFilterConfig;
432:         // In cases where subId is unavailable, the caller needs to specify the phone.
441:         MainThreadRequest(Object argument, Phone phone, WorkSource workSource) {
443:             if (phone != null) {
444:                 this.phone = phone;
472:      * A handler that processes messages on the main thread in the phone process. Since many
473:      * of the Phone calls are not thread safe this is needed to shuttle the requests from the
474:      * inbound binder threads to the main thread in the phone process.  The Binder thread
491:             final Phone defaultPhone = getDefaultPhone();
496:                     final Phone phone = getPhoneFromRequest(request);
515:                         request.result = phone != null
516:                                 ? phone.handleUssdRequest(ussdRequest, wrappedCallback) : false;
527:                     final Phone phone = getPhoneFromRequest(request);
528:                     request.result = phone != null ?
805:                     Phone phone = getPhoneFromRequest(request);
806:                     if (phone != null) {
807:                         phone.isNrDualConnectivityEnabled(onCompleted, request.workSource);
809:                         loge("isNRDualConnectivityEnabled: No phone object");
844:                     Phone phone = getPhoneFromRequest(request);
845:                     if (phone != null) {
846:                         phone.setNrDualConnectivityState((int) request.argument, onCompleted,
849:                         loge("enableNrDualConnectivity: No phone object");
982:                     request.phone.getCallForwardingOption(callForwardingReason, onCompleted);
1044:                     request.phone.setCallForwardingOption(
1468:                     request.phone.requestCellInfoUpdate(request.workSource, onCompleted);
1482:                     request.phone.requestCellInfoUpdate(request.workSource,
1510:                     Phone phone = getPhoneFromRequest(request);
1511:                     phone.getCellIdentity(ws, obtainMessage(EVENT_GET_CELL_LOCATION_DONE, request));
1520:                         Phone phone = getPhoneFromRequest(request);
1521:                         request.result = (phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
1544:                             .enablePhone(request.phone, enable, onCompleted);
1550:                     int phoneId = request.phone.getPhoneId();
1566:                             .getPhoneStatusFromModem(request.phone, onCompleted);
1571:                     int id = request.phone.getPhoneId();
1594:                     request.phone.setSystemSelectionChannels(args.first, onCompleted);
1609:                     Phone phone = getPhoneFromRequest(request);
1610:                     if (phone != null) {
1611:                         phone.getSystemSelectionChannels(onCompleted);
1613:                         loge("getSystemSelectionChannels: No phone object");
1754:                     Phone phone = getPhoneFromRequest(request);
1755:                     if (phone != null) {
1756:                         phone.setDataThrottling(onCompleted,
1760:                         loge("setDataThrottling: No phone object");
1804:                     request.phone.setSimPowerState(stateToSet, onCompleted, request.workSource);
1848:                     final Phone phone = getPhoneFromRequest(request);
1849:                     if (phone == null || phone.getServiceStateTracker() == null) {
1850:                         request.result = new IllegalStateException("Phone or SST is null");
1859:                     phone.getServiceStateTracker().setSignalStrengthUpdateRequest(
1876:                     Phone phone = getPhoneFromRequest(request);
1877:                     if (phone == null || phone.getServiceStateTracker() == null) {
1878:                         request.result = new IllegalStateException("Phone or SST is null");
1887:                     phone.getServiceStateTracker().clearSignalStrengthUpdateRequest(
1990:     private Object sendRequest(int command, Object argument, Phone phone, WorkSource workSource) {
1991:         return sendRequest(command, argument, SubscriptionManager.INVALID_SUBSCRIPTION_ID, phone,
2001:     private @Nullable Object sendRequest(int command, Object argument, Integer subId, Phone phone,
2008:         if (subId != SubscriptionManager.INVALID_SUBSCRIPTION_ID && phone != null) {
2009:             throw new IllegalArgumentException("subId and phone cannot both be specified!");
2010:         } else if (phone != null) {
2011:             request = new MainThreadRequest(argument, phone, workSource);
2071:      * Same as {@link #sendRequestAsync(int,Object)} except it takes a Phone and WorkSource.
2075:             int command, Object argument, Phone phone, WorkSource workSource) {
2076:         MainThreadRequest request = new MainThreadRequest(argument, phone, workSource);
2116:         Phone thePhone = getPhone(getDefaultSubscription());
2130:         if (request.phone != null) {
2131:             return request.phone;
2143:         Phone phone = getPhoneFromRequest(request);
2144:         return phone == null ? null :
2145:                 UiccController.getInstance().getUiccCard(phone.getPhoneId());
2148:     // returns phone associated with the subId.
2153:     private void sendEraseModemConfig(Phone phone) {
2154:         if (phone != null) {
2156:                   mApp, phone.getSubId(), "eraseModemConfig");
2194:             // PENDING: should we just silently fail if phone is offhook or ringing?
2215:         // from the context of the phone app.
2218:         if (mAppOps.noteOp(AppOpsManager.OPSTR_CALL_PHONE, Binder.getCallingUid(), callingPackage)
2268:             Phone phone = getPhone(subId);
2269:             final UnlockSim checkSimPin = new UnlockSim(phone.getPhoneId(), phone.getIccCard());
2282:             Phone phone = getPhone(subId);
2283:             final UnlockSim checkSimPuk = new UnlockSim(phone.getPhoneId(), phone.getIccCard());
2445:             final Phone phone = getPhone(getDefaultSubscription());
2446:             if (phone != null) {
2447:                 phone.updateServiceLocation(workSource);
2492:             final Phone phone = getPhone(subId);
2493:             if (phone != null) {
2494:                 return phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF;
2512:             final Phone phone = getPhone(subId);
2513:             if (phone != null) {
2514:                 phone.setRadioPower(!isRadioOnForSubscriber(subId));
2530:             final Phone phone = getPhone(subId);
2531:             if (phone == null) {
2534:             if ((phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF) != turnOn) {
2552:                 Phone phone = PhoneFactory.getPhone(i);
2553:                 if (phone != null && phone.isRadioAvailable()) return true;
2569:                 logv("Shutting down Phone " + i);
2578:         Phone phone = PhoneFactory.getPhone(phoneId);
2579:         if (phone != null && phone.isRadioAvailable()) {
2580:             phone.shutdownRadio();
2589:             final Phone defaultPhone = PhoneFactory.getDefaultPhone();
2594:                 loge("There's no default phone.");
2607:             final Phone phone = getPhone(subId);
2608:             if (phone != null) {
2609:                 phone.setRadioPower(turnOn);
2627:             final Phone phone = getPhone(subId);
2628:             if (phone != null) {
2629:                 phone.getDataEnabledSettings().setDataEnabled(
2648:             final Phone phone = getPhone(subId);
2649:             if (phone != null) {
2650:                 phone.getDataEnabledSettings().setDataEnabled(
2665:             final Phone phone = getPhone(subId);
2666:             if (phone != null) {
2667:                 return phone.isDataAllowed(ApnSetting.TYPE_DEFAULT);
2716:             Phone phone = PhoneFactory.getPhone(slotIndex);
2717:             return phone == null ? TelephonyManager.CALL_STATE_IDLE :
2718:                     PhoneConstantConversions.convertCallState(phone.getState());
2733:             final Phone phone = getPhone(subId);
2734:             if (phone != null) {
2735:                 return PhoneConstantConversions.convertDataState(phone.getDataConnectionState());
2754:             final Phone phone = getPhone(subId);
2755:             if (phone != null) {
2756:                 return DefaultPhoneNotifier.convertDataActivityState(phone.getDataActivityState());
2785:                 return (getDefaultPhone().getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
2806:             if (phoneId == SubscriptionManager.INVALID_PHONE_INDEX) {
2807:                 // Get default phone in this case.
2808:                 phoneId = SubscriptionManager.DEFAULT_PHONE_INDEX;
2811:             Phone phone = PhoneFactory.getPhone(phoneId);
2812:             if (phone == null) return "";
2813:             ServiceStateTracker sst = phone.getServiceStateTracker();
2882:         for (Phone phone : PhoneFactory.getPhones()) {
2883:             List<CellInfo> info = phone.getAllCellInfo();
2922:             for (Phone phone : PhoneFactory.getPhones()) {
2924:                         CMD_GET_ALL_CELL_INFO, null, phone, workSource);
2986:         final Phone phone = getPhoneFromSubId(subId);
2987:         if (phone == null) throw new IllegalArgumentException("Invalid Subscription Id: " + subId);
2989:         sendRequestAsync(CMD_REQUEST_CELL_INFO_UPDATE, cb, phone, workSource);
3007:         Phone phone = PhoneFactory.getPhone(slotIndex);
3008:         if (phone == null) {
3011:         int subId = phone.getSubId();
3019:             return phone.getImei();
3027:         Phone phone = PhoneFactory.getPhone(slotIndex);
3029:         if (phone != null) {
3030:             String imei = phone.getImei();
3038:         Phone phone = PhoneFactory.getPhone(slotIndex);
3039:         if (phone == null) {
3043:         int subId = phone.getSubId();
3051:             return phone.getMeid();
3059:         Phone phone = PhoneFactory.getPhone(slotIndex);
3061:         if (phone != null) {
3062:             String meid = phone.getMeid();
3071:         Phone phone = PhoneFactory.getPhone(slotIndex);
3072:         if (phone == null) {
3075:         int subId = phone.getSubId();
3084:             return phone.getDeviceSvn();
3094:             final Phone phone = getPhone(subId);
3095:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID : phone.getCarrierId();
3105:             final Phone phone = getPhone(subId);
3106:             return phone == null ? null : phone.getCarrierName();
3116:             final Phone phone = getPhone(subId);
3117:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID
3118:                     : phone.getSpecificCarrierId();
3128:             final Phone phone = getPhone(subId);
3129:             return phone == null ? null : phone.getSpecificCarrierName();
3140:         final Phone phone = PhoneFactory.getPhone(slotIndex);
3141:         if (phone == null) {
3146:             return CarrierResolver.getCarrierIdFromMccMnc(phone.getContext(), mccmnc);
3157:      * Make sure the caller has the MODIFY_PHONE_STATE permission.
3162:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE, null);
3182:      * Make sure the caller has the CALL_PHONE permission.
3187:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.CALL_PHONE, null);
3227:             final Phone phone = PhoneFactory.getPhone(slotIndex);
3228:             if (phone == null) {
3229:                 return PhoneConstants.PHONE_TYPE_NONE;
3231:                 return phone.getPhoneType();
3258:             final Phone phone = getPhone(subId);
3259:             if (phone != null) {
3260:                 return phone.getCdmaEriIconIndex();
3291:             final Phone phone = getPhone(subId);
3292:             if (phone != null) {
3293:                 return phone.getCdmaEriIconMode();
3322:             final Phone phone = getPhone(subId);
3323:             if (phone != null) {
3324:                 return phone.getCdmaEriText();
3343:             final Phone phone = getPhone(subId);
3344:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
3345:                 return phone.getLine1Number();
3347:                 loge("getCdmaMdn: no phone found. Invalid subId: " + subId);
3365:             final Phone phone = getPhone(subId);
3366:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
3367:                 return phone.getCdmaMin();
3379:         if (mApp.checkCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE)
3381:             throw new SecurityException("Caller must hold the MODIFY_PHONE_STATE permission");
3547:             final Phone phone = getPhone(subId);
3548:             if (phone != null) {
3549:                 phone.setVoiceActivationState(activationState);
3568:             final Phone phone = getPhone(subId);
3569:             if (phone != null) {
3570:                 phone.setDataActivationState(activationState);
3586:         final Phone phone = getPhone(subId);
3589:             if (phone != null) {
3590:                 return phone.getVoiceActivationState();
3606:         final Phone phone = getPhone(subId);
3609:             if (phone != null) {
3610:                 return phone.getDataActivationState();
3632:             final Phone phone = getPhone(subId);
3633:             if (phone != null) {
3634:                 return phone.getVoiceMessageCount();
3651:             final Phone phone = getPhone(subId);
3652:             return (phone == null ? false : phone.isConcurrentVoiceAndDataAllowed());
3665:         final Phone defaultPhone = getDefaultPhone();
3703:             for (Phone phone : PhoneFactory.getPhones()) {
3704:                 if (phone.isInEmergencySmsMode()) {
3715:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3742:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3780:             Phone phone = getPhone(subId);
3781:             if (phone == null) {
3786:             phone.getImsRegistrationState(regState -> {
3813:             Phone phone = getPhone(subId);
3814:             if (phone == null) {
3819:             phone.getImsRegistrationTech(regTech -> {
3838:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3864:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3915:             Phone phone = getPhone(subId);
3916:             if (phone == null) return false;
3917:             return phone.isImsCapabilityAvailable(capability, regTech);
3965:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4002:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4036:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4071:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4123:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4205:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
4272:         Phone phone = getPhone(subId);
4273:         if (phone == null) {
4274:             loge("phone instance null for subid " + subId);
4278:             if (!doesImsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4282:             if (!doesRcsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4729:             final Phone phone = getPhone(subId);
4730:             if (phone != null) {
4731:                 return phone.getServiceState().getDataNetworkType();
4763:             final Phone phone = getPhone(subId);
4764:             if (phone != null) {
4765:                 return phone.getServiceState().getDataNetworkType();
4788:             final Phone phone = getPhone(subId);
4789:             if (phone != null) {
4790:                 return phone.getServiceState().getVoiceNetworkType();
4815:             final Phone phone = PhoneFactory.getPhone(slotIndex);
4816:             if (phone != null) {
4817:                 return phone.getIccCard().hasIccCard();
4832:      * @return {@link Phone#LTE_ON_CDMA_UNKNOWN}, {@link Phone#LTE_ON_CDMA_FALSE}
4833:      * or {@link Phone#LTE_ON_CDMA_TRUE}
4852:             final Phone phone = getPhone(subId);
4853:             if (phone == null) {
4921:                     + " does not correspond to an active phone");
4952:     private IccOpenLogicalChannelResponse iccOpenLogicalChannelWithPermission(Phone phone,
4969:                     CMD_OPEN_CHANNEL, new Pair<String, Integer>(aid, p2), phone,
4994:     private boolean iccCloseLogicalChannelWithPermission(Phone phone, int channel) {
5000:             Boolean success = (Boolean) sendRequest(CMD_CLOSE_CHANNEL, channel, phone,
5037:     private String iccTransmitApduLogicalChannelWithPermission(Phone phone, int channel, int cla,
5046:                     new IccAPDUArgument(channel, cla, command, p1, p2, p3, data), phone,
5093:     private String iccTransmitApduBasicChannelWithPermission(Phone phone, String callingPackage,
5111:                     new IccAPDUArgument(0, cla, command, p1, p2, p3, data), phone,
5345:         Phone phone = PhoneFactory.getPhone(slotIndex);
5346:         if (phone != null) {
5348:                     mApp, phone.getSubId(), "resetModemConfig");
5371:         Phone phone = PhoneFactory.getPhone(slotIndex);
5372:         if (phone != null) {
5374:                     mApp, phone.getSubId(), "rebootModem");
5390:         final Phone defaultPhone = getDefaultPhone();
5668:      * Sets the ims registration state on all valid {@link Phone}s.
5675:             // NOTE: Before S, this method only set the default phone.
5676:             for (final Phone phone : PhoneFactory.getPhones()) {
5677:                 if (SubscriptionManager.isValidSubscriptionId(phone.getSubId())) {
5678:                     phone.setImsRegistrationState(registered);
5761:             final Phone phone = getPhone(subId);
5762:             if (phone == null) {
5765:             OperatorInfo networkSelection = phone.getSavedNetworkSelection();
5767:                 ? phone.getManualNetworkSelectionPlmn() : networkSelection.getOperatorNumeric();
5824:             Phone phone = getPhone(subId);
5825:             if (phone == null) {
5855:             sendRequestAsync(CMD_GET_CALL_FORWARDING, argument, phone, null);
5876:             Phone phone = getPhone(subId);
5877:             if (phone == null) {
5890:             sendRequestAsync(CMD_SET_CALL_FORWARDING, arguments, phone, null);
5904:             Phone phone = getPhone(subId);
5905:             if (phone == null) {
5913:             CarrierConfigManager configManager = new CarrierConfigManager(phone.getContext());
5920:                 CarrierXmlParser carrierXmlParser = new CarrierXmlParser(phone.getContext(),
5940:                 sendRequestAsync(CMD_GET_CALL_WAITING, argument, phone, null);
5957:             Phone phone = getPhone(subId);
5958:             if (phone == null) {
5967:             CarrierConfigManager configManager = new CarrierConfigManager(phone.getContext());
5974:                 CarrierXmlParser carrierXmlParser = new CarrierXmlParser(phone.getContext(),
5997:                 sendRequestAsync(CMD_SET_CALL_WAITING, arguments, phone, null);
6258:         final Phone phone = getPhone(subId);
6260:             if (phone != null) {
6261:                 return phone.hasMatchedTetherApnSetting();
6281:         final Phone phone = getPhone(subId);
6283:             if (phone != null) {
6288:                 phone.setAlwaysReportSignalStrength(isEnable);
6290:                 loge("setAlwaysReportSignalStrength: no phone found for subId="
6319:      * Accepts either ACCESS_NETWORK_STATE, MODIFY_PHONE_STATE or carrier privileges.
6337:             Phone phone = PhoneFactory.getPhone(phoneId);
6338:             if (phone != null) {
6339:                 boolean retVal = phone.isUserDataEnabled();
6343:                 if (DBG) loge("isUserDataEnabled: no phone subId=" + subId + " retVal=false");
6366:                 mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PHONE_STATE,
6377:             Phone phone = PhoneFactory.getPhone(phoneId);
6378:             if (phone != null) {
6379:                 boolean retVal = phone.getDataEnabledSettings().isDataEnabled();
6383:                 if (DBG) loge("isDataEnabled: no phone subId=" + subId + " retVal=false");
6404:             mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PHONE_STATE,
6416:             Phone phone = PhoneFactory.getPhone(phoneId);
6417:             if (phone != null) {
6420:                     retVal = phone.isUserDataEnabled();
6422:                     retVal = phone.getDataEnabledSettings().isDataEnabledForReason(reason);
6428:                     loge("isDataEnabledForReason: no phone subId="
6439:             Phone phone) {
6440:         if (uid == Process.PHONE_UID) {
6441:             // Skip the check if it's the phone UID (system UID removed in b/184713596)
6442:             // TODO (b/184954344): Check for system/phone UID at call site instead of here
6451:         PackageManager pkgMgr = phone.getContext().getPackageManager();
6456:             int subId = phone.getSubId();
6464:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
6476:     private int getCarrierPrivilegeStatusFromCarrierConfigRules(int privilegeFromSim, Phone phone,
6485:             int subId = phone.getSubId();
6493:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
6503:         final Phone phone = getPhone(subId);
6504:         if (phone == null) {
6508:         UiccCard card = UiccController.getInstance().getUiccCard(phone.getPhoneId());
6516:                 phone.getContext().getPackageManager()), Binder.getCallingUid(), phone);
6522:         final Phone phone = getPhone(subId);
6523:         if (phone == null) {
6528:                 UiccController.getInstance().getUiccProfileForPhone(phone.getPhoneId());
6535:                         phone.getContext().getPackageManager(), uid), uid, phone);
6640:         final Phone phone = getPhone(subId);
6641:         UiccCard card = phone == null ? null : phone.getUiccCard();
6658:             Phone phone = getPhone(subId);
6659:             if (phone != null) {
6660:                 Phone defaultPhone = phone.getImsPhone();
6661:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
6681:             Phone phone = getPhone(subId);
6682:             if (phone != null) {
6683:                 Phone defaultPhone = phone.getImsPhone();
6684:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
6704:             final Phone phone = getPhone(subId);
6705:             if (phone == null) {
6708:             final String subscriberId = phone.getSubscriberId();
6931:             final Phone phone = getPhone(subId);
6932:             return phone == null ? false : phone.setOperatorBrandOverride(brand);
6947:             final Phone phone = getPhone(subId);
6948:             if (phone == null) {
6951:             return phone.setRoamingOverride(gsmRoamingList, gsmNonRoamingList, cdmaRoamingList,
6993:         Phone phone = PhoneFactory.getPhone(phoneId);
6997:                             mApp, phone.getSubId(), "getRadioAccessFamily");
7003:         if (phone == null) {
7010:                             mApp, phone.getSubId(), "getRadioAccessFamily");
7020:         final Phone defaultPhone = getDefaultPhone();
7034:         final Phone defaultPhone = getDefaultPhone();
7088:                     .getBoolean(CarrierConfigManager.KEY_WORLD_PHONE_BOOL);
7119:         final Phone phone = getPhone(subscriptionId);
7120:         if (phone == null) {
7121:             loge("isRttSupported: no Phone found. Invalid subId:" + subscriptionId);
7128:                     phone.getContext().getResources().getBoolean(R.bool.config_support_rtt);
7161:      * Returns the unique device ID of phone, for example, the IMEI for
7165:      *   {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
7169:         final Phone phone = PhoneFactory.getPhone(0);
7170:         if (phone == null) {
7173:         int subId = phone.getSubId();
7181:             return phone.getDeviceId();
7194:         Phone phone = getPhone(subId);
7195:         if (phone != null) {
7196:             return phone.isImsRegistered();
7217:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
7233:             Phone phone = getPhone(subscriptionId);
7234:             if (phone == null) {
7237:             return PhoneUtils.makePstnPhoneAccountHandle(phone);
7249:             Phone phone = getPhone(subId);
7250:             if (phone != null) {
7251:                 return phone.isWifiCallingEnabled();
7266:             Phone phone = getPhone(subId);
7267:             if (phone != null) {
7268:                 return phone.isVideoEnabled();
7284:             Phone phone = getPhone(subId);
7285:             if (phone != null) {
7286:                 return phone.getImsRegistrationTech();
7310:                 Phone phone = getPhone(subId);
7311:                 cleanUpAllowedNetworkTypes(phone, subId);
7338:     void cleanUpAllowedNetworkTypes(Phone phone, int subId) {
7339:         if (phone == null || !SubscriptionManager.isUsableSubscriptionId(subId)) {
7347:         phone.loadAllowedNetworksFromSubscriptionDatabase();
7348:         phone.setAllowedNetworkTypes(TelephonyManager.ALLOWED_NETWORK_TYPES_REASON_USER,
7361:         final Phone phone = getPhone(subId);
7362:         if (phone == null) {
7369:                     phone.getContext().getOpPackageName(), phone.getContext().getAttributionTag());
7378:             final Locale localeFromDefaultSim = phone.getLocaleFromSimAndCarrierPrefs();
7510:             // isActiveSubId requires READ_PHONE_STATE, which we already check for above
7517:             final Phone phone = getPhone(subId);
7518:             if (phone == null) {
7522:             ServiceState ss = phone.getServiceState();
7535:      * Returns the URI for the per-account voicemail ringtone set in Phone settings.
7546:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
7547:             if (phone == null) {
7548:                 phone = getDefaultPhone();
7551:             return VoicemailNotificationSettingsUtil.getRingtoneUri(phone.getContext());
7561:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7571:         final Phone defaultPhone = getDefaultPhone();
7582:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
7583:             if (phone == null) {
7584:                 phone = defaultPhone;
7586:             VoicemailNotificationSettingsUtil.setRingtoneUri(phone.getContext(), uri);
7593:      * Returns whether vibration is set for voicemail notification in Phone settings.
7603:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
7604:             if (phone == null) {
7605:                 phone = getDefaultPhone();
7608:             return VoicemailNotificationSettingsUtil.isVibrationEnabled(phone.getContext());
7618:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7628:         final Phone defaultPhone = getDefaultPhone();
7639:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
7640:             if (phone == null) {
7641:                 phone = defaultPhone;
7643:             VoicemailNotificationSettingsUtil.setVibrationEnabled(phone.getContext(), enabled);
7650:      * Make sure either called from same process as self (phone) or IPC caller has read privilege.
7655:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE,
7660:      * Make sure either called from same process as self (phone) or IPC caller has send SMS
7703:         Phone phone = getPhone(subId);
7707:             if (phone == null) {
7712:                 aid = UiccController.getInstance().getUiccCard(phone.getPhoneId())
7732:         Phone phone = getPhone(subId);
7736:             if (phone == null) {
7741:                 esn = phone.getEsn();
7760:         Phone phone = getPhone(subId);
7764:             if (phone == null) {
7769:                 cdmaPrlVersion = phone.getCdmaPrlVersion();
7863:         final Phone phone = getPhone(subId);
7866:         if (phone == null) {
7871:             phone.carrierActionSetRadioEnabled(enabled);
7891:         final Phone phone = getPhone(subId);
7894:         if (phone == null) {
7899:             phone.carrierActionReportDefaultNetworkStatus(report);
7915:         final Phone phone = getPhone(subId);
7916:         if (phone == null) {
7921:             phone.carrierActionResetAll();
7928:      * Called when "adb shell dumpsys phone" is invoked. Dump is also automatically invoked when a
7935:             writer.println("Permission Denial: can't dump Phone from pid="
7978:             Phone phone = getPhone(subId);
7979:             if (phone != null) {
7981:                     phone.carrierActionSetMeteredApnsEnabled(enabled);
7983:                     phone.getDataEnabledSettings().setDataEnabled(reason, enabled);
8003:         Phone phone = getPhone(subId);
8007:             if (phone != null) {
8008:                 return phone.getClientRequestStats();
8035:         Phone phone = PhoneFactory.getPhone(slotIndex);
8041:             if (phone != null) {
8042:                 phone.setSimPowerState(state, null, workSource);
8064:         Phone phone = PhoneFactory.getPhone(slotIndex);
8070:             if (phone != null) {
8072:                 sendRequestAsync(CMD_SET_SIM_POWER, arguments, phone, workSource);
8094:      * Check if phone is in emergency callback mode
8095:      * @return true if phone is in emergency callback mode
8101:         final Phone phone = getPhone(subId);
8105:             if (phone != null) {
8106:                 return phone.isInEcm();
8126:             Phone p = getPhone(subId);
8146:         Phone phone = PhoneFactory.getPhone(slotIndex);
8147:         if (phone != null) {
8148:             if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, phone.getSubId(),
8155:                 return phone.getRadioPowerState();
8168:      * {@link android.Manifest.permission#READ_PHONE_STATE} or that the calling app has carrier
8188:             Phone phone = getPhone(subId);
8189:             isEnabled =  phone != null ? phone.getDataRoamingEnabled() : false;
8201:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE} or that the calling app has carrier
8214:             Phone phone = getPhone(subId);
8215:             if (phone != null) {
8216:                 phone.setDataRoamingEnabled(isEnabled);
8232:             Phone phone = getPhone(subId);
8233:             if (phone != null) {
8234:                 isAllowed = phone.isCspPlmnEnabled();
8253:             // even without READ_PRIVILEGED_PHONE_STATE, we allow the call to continue if the caller
8390:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
8399:             Phone phone = getPhone(subId);
8400:             if (phone == null) {
8403:             UiccCard uiccCard = phone.getUiccCard();
8440:      * not set, return {@link Phone#PREFERRED_NT_MODE}.
8448:         return Phone.PREFERRED_NT_MODE;
8458:             final Phone phone = getPhone(subId);
8459:             if (phone == null) {
8463:             phone.setCarrierTestOverride(mccmnc, imsi, iccid, gid1, gid2, plmn, spn,
8481:             final Phone phone = getPhone(subId);
8482:             if (phone == null) {
8486:             return phone.getCarrierIdListVersion();
8569:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8574:             for (Phone phone: PhoneFactory.getPhones()) {
8575:                 if (phone.getEmergencyNumberTracker() != null
8576:                         && phone.getEmergencyNumberTracker().getEmergencyNumberList() != null) {
8578:                             phone.getSubId(),
8579:                             phone.getEmergencyNumberTracker().getEmergencyNumberList());
8590:         final Phone defaultPhone = getDefaultPhone();
8598:             for (Phone phone: PhoneFactory.getPhones()) {
8599:                 if (phone.getEmergencyNumberTracker() != null
8600:                         && phone.getEmergencyNumberTracker()
8621:             for (Phone phone : PhoneFactory.getPhones()) {
8622:                 Rlog.d(LOG_TAG, "startEmergencyCallbackMode phone type: " + phone.getPhoneType());
8623:                 if (phone != null && ((phone.getPhoneType() == PHONE_TYPE_GSM)
8624:                         || (phone.getPhoneType() == PHONE_TYPE_CDMA))) {
8625:                     GsmCdmaPhone gsmCdmaPhone = (GsmCdmaPhone) phone;
8646:             for (Phone phone: PhoneFactory.getPhones()) {
8647:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8668:             for (Phone phone: PhoneFactory.getPhones()) {
8669:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8688:             final Phone phone = getPhone(subId);
8689:             if (phone == null) {
8693:             return phone.getEmergencyNumberDbVersion();
8705:             for (Phone phone: PhoneFactory.getPhones()) {
8706:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8722:             for (Phone phone: PhoneFactory.getPhones()) {
8723:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8739:             for (Phone phone: PhoneFactory.getPhones()) {
8740:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8753:         Phone phone = getPhone(subId);
8754:         if (phone == null) {
8760:                     .getUiccProfileForPhone(phone.getPhoneId());
8779:             Phone phone = PhoneFactory.getPhone(slotIndex);
8780:             if (phone == null) {
8783:                 return (Boolean) sendRequest(CMD_REQUEST_ENABLE_MODEM, enable, phone, null);
8796:         Phone phone = PhoneFactory.getPhone(slotIndex);
8797:         if (phone == null) return false;
8800:                 mApp, phone.getSubId(), callingPackage, callingFeatureId,
8802:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8808:                 return mPhoneConfigurationManager.getPhoneStatusFromCache(phone.getPhoneId());
8810:                 return (Boolean) sendRequest(CMD_GET_MODEM_STATUS, null, phone, null);
8878:      * Note: Switch from multi-sim to single-sim is only possible with MODIFY_PHONE_STATE
8879:      * permission, but the other way around is possible with either MODIFY_PHONE_STATE
8908:         Phone phone = getPhone(subId);
8909:         if (phone == null) {
8914:             UiccCard uiccCard = phone.getUiccCard();
8984:         Phone phone = getDefaultPhone();
8985:         if (phone == null) return -1;
8986:         HalVersion hv = phone.getHalVersion();
9016:         enforceReadPrivilegedPermission("Needs READ_PRIVILEGED_PHONE_STATE for "
9022:             Phone phone = getPhone(subId);
9023:             if (phone == null) return false;
9025:             boolean isMetered = ApnSettingUtils.isMeteredApnType(apnType, phone);
9026:             return !isMetered || phone.getDataEnabledSettings().isDataEnabled(apnType);
9039:             Phone phone = getPhone(subId);
9040:             if (phone == null) return true; // By default return true.
9042:             return ApnSettingUtils.isMeteredApnType(apnType, phone);
9054:             Phone phone = getPhone(subscriptionId);
9055:             if (phone == null) {
9075:             sendRequestAsync(CMD_SET_SYSTEM_SELECTION_CHANNELS, argument, phone, null);
9175:             Phone phone = getPhone(subscriptionId);
9176:             if (phone == null) return false;
9180:                     return phone.getDataEnabledSettings().isDataAllowedInVoiceCall();
9182:                     return phone.getDataEnabledSettings().isMmsAlwaysAllowed();
9198:             Phone phone = getPhone(subscriptionId);
9199:             if (phone == null) return;
9203:                     phone.getDataEnabledSettings().setAllowDataDuringVoiceCall(enabled);
9206:                     phone.getDataEnabledSettings().setAlwaysAllowMmsData(enabled);
9228:             for (Phone phone : PhoneFactory.getPhones()) {
9229:                 Phone defaultPhone = phone.getImsPhone();
9230:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
9279:             Phone phone = getPhone(subId);
9280:             if (phone != null && phone.getIccCard() != null) {
9281:                 return phone.getIccCard().getIccLockEnabled();
9305:         Phone phone = getPhone(subId);
9306:         if (phone == null) {
9313:                     new Pair<Boolean, String>(enabled, password), phone, null);
9337:         Phone phone = getPhone(subId);
9338:         if (phone == null) {
9345:                     new Pair<String, String>(oldPassword, newPassword), phone, null);
9404:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
9407:         Phone phone = getPhone(subId);
9408:         if (phone == null) {
9409:             throw new RuntimeException("phone is not available");
9414:             return phone.getEquivalentHomePlmns();
9439:                 Manifest.permission.MODIFY_PHONE_STATE);
9477:      * @param subId the subscription ID of the phone requesting to set the radio power state.
9479:      * @return {@code true} if phone setRadioPowerForReason was called. Otherwise, returns {@code
9483:         Phone phone = getPhone(subId);
9484:         if (phone != null) {
9485:             phone.setRadioPowerForReason(enable, Phone.RADIO_POWER_REASON_THERMAL);
9500:         // Ensure that radio is on. If not able to power on due to phone being unavailable, return
9539:             Log.e(LOG_TAG , "Phone state is not valid. One of the phones is in an emergency call");
9542:         for (Phone phone : PhoneFactory.getPhones()) {
9543:             if (phone.isInEmergencySmsMode() || phone.isInEcm()) {
9544:                 Log.e(LOG_TAG, "Phone state is not valid. isInEmergencySmsMode = "
9545:                     + phone.isInEmergencySmsMode() + " isInEmergencyCallbackMode = "
9546:                     + phone.isInEcm());
9616:                     // Ensure that radio is on. If not able to power on due to phone being
9636:                         Phone phone = getPhone(subId);
9637:                         if (phone == null) {
9661:                     // Turn radio off. If not able to power off due to phone being unavailable,
9785:                 permission.READ_PRIVILEGED_PHONE_STATE);
9816:                 permission.READ_PRIVILEGED_PHONE_STATE);
9847:                 permission.READ_PRIVILEGED_PHONE_STATE);
10292:         if (callingUid == Process.PHONE_UID || callingUid == Process.SYSTEM_UID) {
10293:             // phone/system process do not have further restriction on request
10346:      * Gets the current phone capability.
10348:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
10350:      * It's used to evaluate possible phone config change, for example from single
24: import static com.android.internal.telephony.PhoneConstants.SUBSCRIPTION_KEY;
66: import android.telecom.PhoneAccount;
67: import android.telecom.PhoneAccountHandle;
89: import android.telephony.PhoneCapability;
90: import android.telephony.PhoneNumberRange;
148: import com.android.internal.telephony.GsmCdmaPhone;
160: import com.android.internal.telephony.PhoneConfigurationManager;
161: import com.android.internal.telephony.PhoneConstantConversions;
162: import com.android.internal.telephony.PhoneConstants;
163: import com.android.internal.telephony.PhoneFactory;
178: import com.android.internal.telephony.imsphone.ImsPhone;
179: import com.android.internal.telephony.imsphone.ImsPhoneCallTracker;
224:     private static final String LOG_TAG = "PhoneInterfaceManager";
225:     private static final boolean DBG = (PhoneGlobals.DBG_LEVEL >= 2);
340:     private static PhoneInterfaceManager sInstance;
343:     private PhoneGlobals mApp;
746:                     defaultPhone.nvReadItem((Integer) request.argument, onCompleted,
773:                     defaultPhone.nvWriteItem(idValue.first, idValue.second, onCompleted,
784:                     defaultPhone.nvWriteCdmaPrl((byte[]) request.argument, onCompleted);
794:                     defaultPhone.resetModemConfig(onCompleted);
936:                     defaultPhone.invokeOemRilRequestRaw((byte[]) request.argument, onCompleted);
1217:                     if (defaultPhone != null) {
1218:                         defaultPhone.getModemActivityInfo(onCompleted, request.workSource);
1281:                     defaultPhone.setAllowedCarriers(argument, onCompleted, request.workSource);
1309:                     defaultPhone.getAllowedCarriers(onCompleted, request.workSource);
1533:                     defaultPhone.rebootModem(onCompleted);
1543:                     PhoneConfigurationManager.getInstance()
1553:                         mPhoneConfigurationManager.addToPhoneStatusCache(phoneId, msg.arg1 == 1);
1565:                     PhoneConfigurationManager.getInstance()
1682:                     defaultPhone.eraseModemConfig(onCompleted);
1702:                         int phoneId = getPhoneFromRequest(request).getPhoneId();
1704:                                 .storePin(passwords.second, phoneId);
1726:                         int phoneId = getPhoneFromRequest(request).getPhoneId();
1729:                                     .storePin(enabled.second, phoneId);
1731:                             UiccController.getInstance().getPinStorage().clearPin(phoneId);
1745:                     getDefaultPhone().getContext().sendBroadcastAsUser(
2082:      * Initialize the singleton PhoneInterfaceManager instance.
2083:      * This is only done once, at startup, from PhoneApp.onCreate().
2085:     /* package */ static PhoneInterfaceManager init(PhoneGlobals app) {
2086:         synchronized (PhoneInterfaceManager.class) {
2088:                 sInstance = new PhoneInterfaceManager(app);
2099:         mCM = PhoneGlobals.getInstance().mCM;
2108:         mPhoneConfigurationManager = PhoneConfigurationManager.getInstance();
2117:         return (thePhone != null) ? thePhone : PhoneFactory.getDefaultPhone();
2139:                 ? getDefaultPhone() : getPhone(subId);
2150:         return PhoneFactory.getPhone(mSubscriptionController.getPhoneId(subId));
2168:         PackageManager pm = getDefaultPhone().getContext().getPackageManager();
2195:             PhoneConstants.State state = mCM.getState(subId);
2196:             if (state != PhoneConstants.State.OFFHOOK && state != PhoneConstants.State.RINGING) {
2255:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
2260:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
2301:         private int mResult = PhoneConstants.PIN_GENERAL_FAILURE;
2310:         UnlockSim(int phoneId, IccCard simCard) {
2311:             mPhoneId = phoneId;
2332:                                             mResult = PhoneConstants.PIN_PASSWORD_INCORRECT;
2337:                                             mResult = PhoneConstants.PIN_OPERATION_ABORTED;
2339:                                             mResult = PhoneConstants.PIN_GENERAL_FAILURE;
2342:                                         mResult = PhoneConstants.PIN_RESULT_SUCCESS;
2394:             if (mResult == PhoneConstants.PIN_RESULT_SUCCESS && pin.length() > 0) {
2555:             logv(TelephonyManager.getDefault().getPhoneCount() + " Phones are shutdown.");
2590:             if (defaultPhone != null) {
2591:                 defaultPhone.setRadioPower(turnOn);
2737:                 return PhoneConstantConversions.convertDataState(
2738:                         PhoneConstants.DataState.DISCONNECTED);
2810:             final int subId = mSubscriptionController.getSubIdUsingPhoneId(phoneId);
2999:             getDefaultPhone().setCellInfoListRate(rateInMillis, workSource);
3207:         Log.d(LOG_TAG, "[PhoneIntfMgr] " + msg);
3211:         Log.v(LOG_TAG, "[PhoneIntfMgr] " + msg);
3215:         Log.e(LOG_TAG, "[PhoneIntfMgr] " + msg);
3377:     public void requestNumberVerification(PhoneNumberRange range, long timeoutMillis,
3408:             return getDefaultPhone().needsOtaServiceProvisioning();
3443:             PhoneAccountHandle phoneAccountHandle = PhoneAccountHandleConverter.fromSubId(subId);
3444:             if (phoneAccountHandle == null) {
3447:             return VisualVoicemailSettingsUtil.dump(mApp, phoneAccountHandle);
3532:         SmsController smsController = PhoneFactory.getSmsController();
3667:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
3676:             defaultPhone.sendDialerSpecialCode(inputCode);
3731:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3755:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3851:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3878:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3894:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3973:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3991:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4011:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4026:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4045:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4061:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4080:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4096:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4112:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4132:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4148:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4163:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4179:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4195:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4214:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4233:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4251:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4296:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4326:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4359:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4424:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4600:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4625:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4651:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4677:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4847:             return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4854:                 return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4857:                         .orElse(PhoneConstants.LTE_ON_CDMA_FALSE);
4918:         int phoneId = UiccController.getInstance().getPhoneIdFromSlotId(slotIndex);
4919:         if (phoneId == -1) {
4923:         return PhoneFactory.getPhone(phoneId);
4958:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
5100:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
5391:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
5398:             return defaultPhone.getPcscfAddress(apnType);
6045:                     request, messenger, binder, getPhone(subId),
6335:             int phoneId = mSubscriptionController.getPhoneId(subId);
6336:             if (DBG) log("isUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
6375:             int phoneId = mSubscriptionController.getPhoneId(subId);
6376:             if (DBG) log("isDataEnabled: subId=" + subId + " phoneId=" + phoneId);
6411:             int phoneId = mSubscriptionController.getPhoneId(subId);
6413:                 log("isDataEnabledForReason: subId=" + subId + " phoneId=" + phoneId
6544:         int phoneId = SubscriptionManager.getPhoneId(subId);
6545:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6552:             getPhone(phoneId), pkgName);
6569:                 getPhone(i), pkgName);
6580:         if (!SubscriptionManager.isValidPhoneId(phoneId)) {
6581:             loge("phoneId " + phoneId + " is not valid.");
6584:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6586:             loge("getCarrierPackageNamesForIntentAndPhone: No UICC");
6593:     public List<String> getPackagesWithCarrierPrivileges(int phoneId) {
6597:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6662:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
6663:                     imsPhone.setCallComposerStatus(status);
6685:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
6686:                     return imsPhone.getCallComposerStatus();
6992:     public int getRadioAccessFamily(int phoneId, String callingPackage) {
7011:             raf = ProxyController.getInstance().getRadioAccessFamily(phoneId);
7025:             ImsManager.getInstance(defaultPhone.getContext(),
7026:                     defaultPhone.getPhoneId()).setVtSetting(enable);
7035:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
7047:                     ImsManager.getInstance(defaultPhone.getContext(), defaultPhone.getPhoneId());
7162:      * GSM and the MEID for CDMA phones. Return null if device ID is not available.
7206:             return PhoneUtils.getSubIdForPhoneAccount(phoneAccount);
7214:             PhoneAccountHandle phoneAccountHandle, String callingPackage, String callingFeatureId) {
7221:             return PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle);
7319:             cleanUpSmsRawTable(getDefaultPhone().getContext());
7330:               sendEraseModemConfig(getDefaultPhone());
7537:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
7540:      * PhoneAccount.
7543:     public Uri getVoicemailRingtoneUri(PhoneAccountHandle accountHandle) {
7563:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
7566:      * PhoneAccount.
7570:             PhoneAccountHandle phoneAccountHandle, Uri uri) {
7573:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
7576:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7595:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
7597:      * @return {@code true} if the vibration is set for this PhoneAccount, {@code false} otherwise.
7600:     public boolean isVoicemailVibrationEnabled(PhoneAccountHandle accountHandle) {
7620:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
7623:      * specific PhoneAccount.
7627:             PhoneAccountHandle phoneAccountHandle, boolean enabled) {
7630:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
7633:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7949:         return new TelephonyShellCommand(this, getDefaultPhone().getContext()).exec(
8255:             if (checkCarrierPrivilegesForPackageAnyPhone(callingPackage)
8444:         int phoneId = mSubscriptionController.getPhoneId(subId);
8445:         if (phoneId >= 0 && phoneId < list.size() && list.get(phoneId) != null) {
8446:             return list.get(phoneId);
8594:                             mApp, defaultPhone.getSubId(), "isEmergencyNumber(Potential)");
8612:      * Start emergency callback mode for GsmCdmaPhone for testing.
8626:                     gsmCdmaPhone.obtainMessage(
8627:                             GsmCdmaPhone.EVENT_EMERGENCY_CALLBACK_MODE_ENTER).sendToTarget();
8835:                 getDefaultPhone().getSubId(), callingPackage, callingFeatureId,
8858:         PhoneCapability staticCapability =
8964:             int phoneCount = TelephonyManager.getDefault().getPhoneCount();
8966:             int[] logicalSlotsMapping = new int[phoneCount];
9119:         SmsPermissions permissions = new SmsPermissions(getDefaultPhone(), mApp,
9145:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
9162:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
9231:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
9233:                             (ImsPhoneCallTracker) imsPhone.getCallTracker();
9235:                     Rlog.i(LOG_TAG, "setCepEnabled isCepEnabled=" + isCepEnabled + ", for imsPhone "
9236:                             + imsPhone.getMsisdn());
9374:         // *  Inherited from PhoneWindowManager  *
9475:      * PhoneInternalInterface#setRadioPowerForReason} for more details.
9592:         if (!getThermalMitigationAllowlist(getDefaultPhone().getContext())
10051:             return getDefaultPhone().getMobileProvisioningUrl();
10066:             return EabUtil.getContactFromEab(getDefaultPhone().getContext(), contact);
10081:             return EabUtil.removeContactFromEab(subId, contacts, getDefaultPhone().getContext());
10349:      * @return the PhoneCapability which describes the data connection capability of modem.
146: import com.android.internal.telephony.DefaultPhoneNotifier;
529:                             getPhoneFromRequest(request).handlePinMmi((String) request.argument)
893:                     getPhoneFromRequest(request).getAllowedNetworkTypesBitmask(onCompleted);
923:                     getPhoneFromRequest(request).setAllowedNetworkTypes(
950:                     getPhoneFromRequest(request).setVoiceMailNumber(tagNum.first, tagNum.second,
962:                     getPhoneFromRequest(request).setNetworkSelectionModeAutomatic(onCompleted);
972:                     getPhoneFromRequest(request).getAvailableNetworks(onCompleted);
1085:                     getPhoneFromRequest(request).getCallWaiting(onCompleted);
1131:                     getPhoneFromRequest(request).setCallWaiting(enable, onCompleted);
1197:                     getPhoneFromRequest(request).selectNetworkManually(selArg.operatorInfo,
1392:                     getPhoneFromRequest(request).getNetworkSelectionMode(onCompleted);
1413:                     getPhoneFromRequest(request).queryCdmaRoamingPreference(onCompleted);
1429:                     getPhoneFromRequest(request).setCdmaRoamingPreference(mode, onCompleted);
1440:                     getPhoneFromRequest(request).queryCdmaSubscriptionMode(onCompleted);
1456:                     getPhoneFromRequest(request).setCdmaSubscriptionMode(
1575:                         mPhoneConfigurationManager.addToPhoneStatusCache(id,
1692:                     getPhoneFromRequest(request).getIccCard().changeIccLockPassword(
1715:                     getPhoneFromRequest(request).getIccCard().setIccLockEnabled(
2133:             return getPhoneFromSubId(request.subId);
2395:                 UiccController.getInstance().getPinStorage().storePin(pin, mPhoneId);
2476:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2551:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2568:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2570:                 shutdownRadioUsingPhoneId(i);
3076:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3220:         return getActivePhoneTypeForSlot(getSlotForDefaultSubscription());
3250:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3283:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3314:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3457:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3625:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3685:                     .enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3722:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3748:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3805:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3845:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3870:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3970:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4007:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4041:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4076:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4128:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4210:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
4292:         checkModifyPhoneStatePermission(subId, "setRcsProvisioningStatusForCapability");
4356:         checkModifyPhoneStatePermission(subId, "setImsProvisioningStatusForCapability");
4721:                 && !TelephonyPermissions.checkCallingOrSelfReadPhoneStateNoThrow(
4755:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4780:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4873:         return mSubscriptionController.getPhoneId(getDefaultSubscription());
4935:         return iccOpenLogicalChannelWithPermission(getPhoneFromSubId(subId), callingPackage, aid,
4948:         return iccOpenLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4983:         return iccCloseLogicalChannelWithPermission(getPhoneFromSubId(subId), channel);
4990:         return iccCloseLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
5019:         return iccTransmitApduLogicalChannelWithPermission(getPhoneFromSubId(subId), channel, cla,
5033:                 getPhoneFromSlotIdOrThrowException(slotIndex), channel, cla, command, p1, p2, p3,
5072:         return iccTransmitApduBasicChannelWithPermission(getPhoneFromSubId(subId), callingPackage,
5088:                 getPhoneFromSlotIdOrThrowException(slotIndex), callingPackage, cla, command, p1,
5173:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
5211:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, subId, callingPackage,
5615:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5752:                     .enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
6105:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6130:         TelephonyPermissions.enforceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
6134:             return getPhoneFromSubId(subId).getAllowedNetworkTypes(reason);
6183:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6229:         if (allowedNetworkTypes == getPhoneFromSubId(subId).getAllowedNetworkTypes(reason)) {
6560:         for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6624:         enforceReadPrivilegedPermission("getPackagesWithCarrierPrivilegesForAllPhones");
6630:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6751:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneNumber(
6778:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6801:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6996:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7009:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7059:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7078:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7215:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, getDefaultSubscription(),
7216:                 callingPackage, callingFeatureId, "getSubIdForPhoneAccountHandle")) {
7229:         enforceReadPrivilegedPermission("getPhoneAccountHandleForSubscriptionId, "
7470:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7999:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8181:             TelephonyPermissions.enforceCallingOrSelfReadPhoneStatePermissionOrCarrierPrivilege(
8226:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8354:                         slot.getPhoneId(),
8495:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8503:             return mPhoneConfigurationManager.getNumberOfModemsWithSimultaneousDataConnections();
8512:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8539:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8566:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8593:                     .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8799:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8834:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp,
8859:                 mPhoneConfigurationManager.getStaticPhoneCapability();
8899:             mPhoneConfigurationManager.switchMultiSimConfig(numOfSims);
8939:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8946:             return mPhoneConfigurationManager.isRebootRequiredForModemConfigChange();
8955:         metrics.updateEnabledModemBitmap((1 << TelephonyManager.from(mApp).getPhoneCount()) - 1);
8969:                 if (SubscriptionManager.isValidPhoneId(slotInfos[i].getLogicalSlotIdx())) {
9084:                 .enforceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
9105:                 SubscriptionManager.getPhoneId(subId), UiccController.APP_FAM_3GPP);
9232:                     ImsPhoneCallTracker imsPhoneCallTracker =
9234:                     imsPhoneCallTracker.setConferenceEventPackageEnabled(isCepEnabled);
9402:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
9650:                         } else if (isAnyPhoneInEmergencyState()) {
10355:         enforceReadPrivilegedPermission("getPhoneCapability");
10358:             return mPhoneConfigurationManager.getCurrentPhoneCapability();
android.googlesource.com/platform/superproject:packages/services/Telephony/src/com/android/phone/PhoneInterfaceManager.java: [ master, ]
384:         public Phone phone;
17: package com.android.phone;
198: public class PhoneInterfaceManager extends ITelephony.Stub {
1655:     private PhoneInterfaceManager(PhoneGlobals app) {
1672:     private Phone getDefaultPhone() {
1706:     private Phone getPhone(int subId) {
2347:     public String getNetworkCountryIsoForPhone(int phoneId) {
5936:     public int checkCarrierPrivilegesForPackageAnyPhone(String pkgName) {
5959:     public List<String> getCarrierPackageNamesForIntentAndPhone(Intent intent, int phoneId) {
6417:     public boolean isWorldPhone(int subId, String callingPackage, String callingFeatureId) {
308:     private PhoneConfigurationManager mPhoneConfigurationManager;
1686:     private Phone getPhoneFromRequest(MainThreadRequest request) {
1694:     private Phone getPhoneFromSubId(int subId) {
2125:     private void shutdownRadioUsingPhoneId(int phoneId) {
2780:     public int getActivePhoneType() {
2785:     public int getActivePhoneTypeForSlot(int slotIndex) {
3824:     private void checkModifyPhoneStatePermission(int subId, String message) {
4463:     private Phone getPhoneFromSlotIdOrThrowException(int slotIndex) {
6003:     public List<String> getPackagesWithCarrierPrivilegesForAllPhones() {
6543:     public int getSubIdForPhoneAccount(PhoneAccount phoneAccount) {
6553:     public int getSubIdForPhoneAccountHandle(
6568:     public @Nullable PhoneAccountHandle getPhoneAccountHandleForSubscriptionId(int subscriptionId) {
21: import static com.android.internal.telephony.PhoneConstants.PHONE_TYPE_IMS;
140: import com.android.internal.telephony.Phone;
174: import com.android.phone.settings.PickSmsSubscriptionActivity;
175: import com.android.phone.vvm.PhoneAccountHandleConverter;
176: import com.android.phone.vvm.RemoteVvmTaskManager;
177: import com.android.phone.vvm.VisualVoicemailSettingsUtil;
178: import com.android.phone.vvm.VisualVoicemailSmsFilterConfig;
383:         // In cases where subId is unavailable, the caller needs to specify the phone.
392:         MainThreadRequest(Object argument, Phone phone, WorkSource workSource) {
394:             if (phone != null) {
395:                 this.phone = phone;
423:      * A handler that processes messages on the main thread in the phone process. Since many
424:      * of the Phone calls are not thread safe this is needed to shuttle the requests from the
425:      * inbound binder threads to the main thread in the phone process.  The Binder thread
442:             final Phone defaultPhone = getDefaultPhone();
447:                     final Phone phone = getPhoneFromRequest(request);
466:                         request.result = phone != null
467:                                 ? phone.handleUssdRequest(ussdRequest, wrappedCallback) : false;
478:                     final Phone phone = getPhoneFromRequest(request);
479:                     request.result = phone != null ?
1266:                     request.phone.requestCellInfoUpdate(request.workSource, onCompleted);
1280:                     request.phone.requestCellInfoUpdate(request.workSource,
1308:                     Phone phone = getPhoneFromRequest(request);
1309:                     phone.getCellIdentity(ws, obtainMessage(EVENT_GET_CELL_LOCATION_DONE, request));
1317:                         phone = getPhoneFromRequest(request);
1318:                         request.result = (phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
1340:                             .enablePhone(request.phone, enable, onCompleted);
1346:                     int phoneId = request.phone.getPhoneId();
1361:                             .getPhoneStatusFromModem(request.phone, onCompleted);
1366:                     int id = request.phone.getPhoneId();
1389:                     request.phone.setSystemSelectionChannels(args.first, onCompleted);
1569:     private Object sendRequest(int command, Object argument, Phone phone, WorkSource workSource) {
1571:                 command, argument, SubscriptionManager.INVALID_SUBSCRIPTION_ID, phone, workSource);
1580:             int command, Object argument, Integer subId, Phone phone, WorkSource workSource) {
1586:         if (subId != SubscriptionManager.INVALID_SUBSCRIPTION_ID && phone != null) {
1587:             throw new IllegalArgumentException("subId and phone cannot both be specified!");
1588:         } else if (phone != null) {
1589:             request = new MainThreadRequest(argument, phone, workSource);
1629:      * Same as {@link #sendRequestAsync(int,Object)} except it takes a Phone and WorkSource.
1633:             int command, Object argument, Phone phone, WorkSource workSource) {
1634:         MainThreadRequest request = new MainThreadRequest(argument, phone, workSource);
1673:         Phone thePhone = getPhone(getDefaultSubscription());
1687:         if (request.phone != null) {
1688:             return request.phone;
1700:         Phone phone = getPhoneFromRequest(request);
1701:         return phone == null ? null :
1702:                 UiccController.getInstance().getUiccCard(phone.getPhoneId());
1705:     // returns phone associated with the subId.
1710:     private void sendEraseModemConfig(Phone phone) {
1711:         if (phone != null) {
1713:                   mApp, phone.getSubId(), "eraseModemConfig");
1751:             // PENDING: should we just silently fail if phone is offhook or ringing?
1772:         // from the context of the phone app.
1775:         if (mAppOps.noteOp(AppOpsManager.OPSTR_CALL_PHONE, Binder.getCallingUid(), callingPackage)
1993:             final Phone phone = getPhone(getDefaultSubscription());
1994:             if (phone != null) {
1995:                 phone.updateServiceLocation(workSource);
2040:             final Phone phone = getPhone(subId);
2041:             if (phone != null) {
2042:                 return phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF;
2060:             final Phone phone = getPhone(subId);
2061:             if (phone != null) {
2062:                 phone.setRadioPower(!isRadioOnForSubscriber(subId));
2078:             final Phone phone = getPhone(subId);
2079:             if (phone == null) {
2082:             if ((phone.getServiceState().getState() != ServiceState.STATE_POWER_OFF) != turnOn) {
2100:                 Phone phone = PhoneFactory.getPhone(i);
2101:                 if (phone != null && phone.isRadioAvailable()) return true;
2117:                 logv("Shutting down Phone " + i);
2126:         Phone phone = PhoneFactory.getPhone(phoneId);
2127:         if (phone != null && phone.isRadioAvailable()) {
2128:             phone.shutdownRadio();
2137:             final Phone defaultPhone = PhoneFactory.getDefaultPhone();
2142:                 loge("There's no default phone.");
2155:             final Phone phone = getPhone(subId);
2156:             if (phone != null) {
2157:                 phone.setRadioPower(turnOn);
2175:             final Phone phone = getPhone(subId);
2176:             if (phone != null) {
2177:                 phone.getDataEnabledSettings().setUserDataEnabled(true);
2195:             final Phone phone = getPhone(subId);
2196:             if (phone != null) {
2197:                 phone.getDataEnabledSettings().setUserDataEnabled(false);
2211:             final Phone phone = getPhone(subId);
2212:             if (phone != null) {
2213:                 return phone.isDataAllowed(ApnSetting.TYPE_DEFAULT);
2262:             Phone phone = PhoneFactory.getPhone(slotIndex);
2263:             return phone == null ? TelephonyManager.CALL_STATE_IDLE :
2264:                     PhoneConstantConversions.convertCallState(phone.getState());
2279:             final Phone phone = getPhone(subId);
2280:             if (phone != null) {
2281:                 return PhoneConstantConversions.convertDataState(phone.getDataConnectionState());
2300:             final Phone phone = getPhone(subId);
2301:             if (phone != null) {
2302:                 return DefaultPhoneNotifier.convertDataActivityState(phone.getDataActivityState());
2331:                 return (getDefaultPhone().getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA)
2352:             if (phoneId == SubscriptionManager.INVALID_PHONE_INDEX) {
2353:                 // Get default phone in this case.
2354:                 phoneId = SubscriptionManager.DEFAULT_PHONE_INDEX;
2357:             Phone phone = PhoneFactory.getPhone(phoneId);
2358:             if (phone == null) return "";
2359:             ServiceStateTracker sst = phone.getServiceStateTracker();
2364:             EmergencyNumberTracker ent = phone.getEmergencyNumberTracker();
2449:         for (Phone phone : PhoneFactory.getPhones()) {
2450:             List<CellInfo> info = phone.getAllCellInfo();
2489:             for (Phone phone : PhoneFactory.getPhones()) {
2491:                         CMD_GET_ALL_CELL_INFO, null, phone, workSource);
2551:         final Phone phone = getPhoneFromSubId(subId);
2552:         if (phone == null) throw new IllegalArgumentException("Invalid Subscription Id: " + subId);
2554:         sendRequestAsync(CMD_REQUEST_CELL_INFO_UPDATE, cb, phone, workSource);
2572:         Phone phone = PhoneFactory.getPhone(slotIndex);
2573:         if (phone == null) {
2576:         int subId = phone.getSubId();
2584:             return phone.getImei();
2592:         Phone phone = PhoneFactory.getPhone(slotIndex);
2594:         if (phone != null) {
2595:             String imei = phone.getImei();
2603:         Phone phone = PhoneFactory.getPhone(slotIndex);
2604:         if (phone == null) {
2608:         int subId = phone.getSubId();
2616:             return phone.getMeid();
2624:         Phone phone = PhoneFactory.getPhone(slotIndex);
2626:         if (phone != null) {
2627:             String meid = phone.getMeid();
2636:         Phone phone = PhoneFactory.getPhone(slotIndex);
2637:         if (phone == null) {
2640:         int subId = phone.getSubId();
2649:             return phone.getDeviceSvn();
2659:             final Phone phone = getPhone(subId);
2660:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID : phone.getCarrierId();
2670:             final Phone phone = getPhone(subId);
2671:             return phone == null ? null : phone.getCarrierName();
2681:             final Phone phone = getPhone(subId);
2682:             return phone == null ? TelephonyManager.UNKNOWN_CARRIER_ID
2683:                     : phone.getSpecificCarrierId();
2693:             final Phone phone = getPhone(subId);
2694:             return phone == null ? null : phone.getSpecificCarrierName();
2705:         final Phone phone = PhoneFactory.getPhone(slotIndex);
2706:         if (phone == null) {
2711:             return CarrierResolver.getCarrierIdFromMccMnc(phone.getContext(), mccmnc);
2722:      * Make sure the caller has the MODIFY_PHONE_STATE permission.
2727:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE, null);
2747:      * Make sure the caller has the CALL_PHONE permission.
2752:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.CALL_PHONE, null);
2788:             final Phone phone = PhoneFactory.getPhone(slotIndex);
2789:             if (phone == null) {
2790:                 return PhoneConstants.PHONE_TYPE_NONE;
2792:                 return phone.getPhoneType();
2819:             final Phone phone = getPhone(subId);
2820:             if (phone != null) {
2821:                 return phone.getCdmaEriIconIndex();
2852:             final Phone phone = getPhone(subId);
2853:             if (phone != null) {
2854:                 return phone.getCdmaEriIconMode();
2883:             final Phone phone = getPhone(subId);
2884:             if (phone != null) {
2885:                 return phone.getCdmaEriText();
2904:             final Phone phone = getPhone(subId);
2905:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2906:                 return phone.getLine1Number();
2908:                 loge("getCdmaMdn: no phone found. Invalid subId: " + subId);
2926:             final Phone phone = getPhone(subId);
2927:             if (phone != null && phone.getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2928:                 return phone.getCdmaMin();
2940:         if (mApp.checkCallingOrSelfPermission(android.Manifest.permission.MODIFY_PHONE_STATE)
2942:             throw new SecurityException("Caller must hold the MODIFY_PHONE_STATE permission");
3106:             final Phone phone = getPhone(subId);
3107:             if (phone != null) {
3108:                 phone.setVoiceActivationState(activationState);
3127:             final Phone phone = getPhone(subId);
3128:             if (phone != null) {
3129:                 phone.setDataActivationState(activationState);
3145:         final Phone phone = getPhone(subId);
3148:             if (phone != null) {
3149:                 return phone.getVoiceActivationState();
3165:         final Phone phone = getPhone(subId);
3168:             if (phone != null) {
3169:                 return phone.getDataActivationState();
3191:             final Phone phone = getPhone(subId);
3192:             if (phone != null) {
3193:                 return phone.getVoiceMessageCount();
3210:             final Phone phone = getPhone(subId);
3211:             return (phone == null ? false : phone.isConcurrentVoiceAndDataAllowed());
3224:         final Phone defaultPhone = getDefaultPhone();
3262:             for (Phone phone : PhoneFactory.getPhones()) {
3263:                 if (phone.isInEmergencySmsMode()) {
3274:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3301:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3339:             Phone phone = getPhone(subId);
3340:             if (phone == null) {
3345:             phone.getImsRegistrationState(regState -> {
3372:             Phone phone = getPhone(subId);
3373:             if (phone == null) {
3378:             phone.getImsRegistrationTech(regTech -> {
3397:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3423:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3474:             Phone phone = getPhone(subId);
3475:             if (phone == null) return false;
3476:             return phone.isImsCapabilityAvailable(capability, regTech);
3524:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3561:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3595:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3630:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3682:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3764:      * Requires carrier privileges or READ_PRECISE_PHONE_STATE permission.
3831:         Phone phone = getPhone(subId);
3832:         if (phone == null) {
3833:             loge("phone instance null for subid " + subId);
3837:             if (!doesImsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
3841:             if (!doesRcsCapabilityRequireProvisioning(phone.getContext(), subId, capability)) {
4275:             final Phone phone = getPhone(subId);
4276:             if (phone != null) {
4277:                 return phone.getServiceState().getDataNetworkType();
4309:             final Phone phone = getPhone(subId);
4310:             if (phone != null) {
4311:                 return phone.getServiceState().getDataNetworkType();
4334:             final Phone phone = getPhone(subId);
4335:             if (phone != null) {
4336:                 return phone.getServiceState().getVoiceNetworkType();
4361:             final Phone phone = PhoneFactory.getPhone(slotIndex);
4362:             if (phone != null) {
4363:                 return phone.getIccCard().hasIccCard();
4378:      * @return {@link Phone#LTE_ON_CDMA_UNKNOWN}, {@link Phone#LTE_ON_CDMA_FALSE}
4379:      * or {@link Phone#LTE_ON_CDMA_TRUE}
4398:             final Phone phone = getPhone(subId);
4399:             if (phone == null) {
4467:                     + " does not correspond to an active phone");
4498:     private IccOpenLogicalChannelResponse iccOpenLogicalChannelWithPermission(Phone phone,
4515:                     CMD_OPEN_CHANNEL, new Pair<String, Integer>(aid, p2), phone,
4540:     private boolean iccCloseLogicalChannelWithPermission(Phone phone, int channel) {
4546:             Boolean success = (Boolean) sendRequest(CMD_CLOSE_CHANNEL, channel, phone,
4583:     private String iccTransmitApduLogicalChannelWithPermission(Phone phone, int channel, int cla,
4592:                     new IccAPDUArgument(channel, cla, command, p1, p2, p3, data), phone,
4639:     private String iccTransmitApduBasicChannelWithPermission(Phone phone, String callingPackage,
4657:                     new IccAPDUArgument(0, cla, command, p1, p2, p3, data), phone,
4891:         Phone phone = PhoneFactory.getPhone(slotIndex);
4892:         if (phone != null) {
4894:                     mApp, phone.getSubId(), "resetModemConfig");
4917:         Phone phone = PhoneFactory.getPhone(slotIndex);
4918:         if (phone != null) {
4920:                     mApp, phone.getSubId(), "rebootModem");
4936:         final Phone defaultPhone = getDefaultPhone();
5268:             final Phone phone = getPhone(subId);
5269:             if (phone == null) {
5272:             OperatorInfo networkSelection = phone.getSavedNetworkSelection();
5274:                 ? phone.getManualNetworkSelectionPlmn() : networkSelection.getOperatorNumeric();
5484:         final Phone defaultPhone = getDefaultPhone();
5670:         final Phone phone = getPhone(subId);
5672:             if (phone != null) {
5673:                 return phone.hasMatchedTetherApnSetting();
5697:             Phone phone = PhoneFactory.getPhone(phoneId);
5698:             if (phone != null) {
5700:                 phone.getDataEnabledSettings().setUserDataEnabled(enable);
5702:                 loge("setUserDataEnabled: no phone found. Invalid subId=" + subId);
5720:         final Phone phone = getPhone(subId);
5722:             if (phone != null) {
5727:                 phone.setAlwaysReportSignalStrength(isEnable);
5729:                 loge("setAlwaysReportSignalStrength: no phone found for subId="
5758:      * Accepts either ACCESS_NETWORK_STATE, MODIFY_PHONE_STATE or carrier privileges.
5776:             Phone phone = PhoneFactory.getPhone(phoneId);
5777:             if (phone != null) {
5778:                 boolean retVal = phone.isUserDataEnabled();
5782:                 if (DBG) loge("isUserDataEnabled: no phone subId=" + subId + " retVal=false");
5805:             Phone phone = PhoneFactory.getPhone(phoneId);
5806:             if (phone != null) {
5807:                 boolean retVal = phone.getDataEnabledSettings().isDataEnabled();
5811:                 if (DBG) loge("isDataEnabled: no phone subId=" + subId + " retVal=false");
5820:             Phone phone) {
5821:         if (uid == Process.SYSTEM_UID || uid == Process.PHONE_UID) {
5831:         PackageManager pkgMgr = phone.getContext().getPackageManager();
5836:             int subId = phone.getSubId();
5844:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
5856:     private int getCarrierPrivilegeStatusFromCarrierConfigRules(int privilegeFromSim, Phone phone,
5865:             int subId = phone.getSubId();
5873:                     phone.getContext().getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
5883:         final Phone phone = getPhone(subId);
5884:         if (phone == null) {
5888:         UiccCard card = UiccController.getInstance().getUiccCard(phone.getPhoneId());
5896:                 phone.getContext().getPackageManager()), Binder.getCallingUid(), phone);
5902:         final Phone phone = getPhone(subId);
5903:         if (phone == null) {
5908:                 UiccController.getInstance().getUiccProfileForPhone(phone.getPhoneId());
5915:                         phone.getContext().getPackageManager(), uid), uid, phone);
6020:         final Phone phone = getPhone(subId);
6021:         UiccCard card = phone == null ? null : phone.getUiccCard();
6043:             final Phone phone = getPhone(subId);
6044:             if (phone == null) {
6047:             final String subscriberId = phone.getSubscriberId();
6270:             final Phone phone = getPhone(subId);
6271:             return phone == null ? false : phone.setOperatorBrandOverride(brand);
6286:             final Phone phone = getPhone(subId);
6287:             if (phone == null) {
6290:             return phone.setRoamingOverride(gsmRoamingList, gsmNonRoamingList, cdmaRoamingList,
6341:         Phone phone = PhoneFactory.getPhone(phoneId);
6343:         if (phone == null) {
6350:                             mApp, phone.getSubId(), "getRadioAccessFamily");
6360:         final Phone defaultPhone = getDefaultPhone();
6374:         final Phone defaultPhone = getDefaultPhone();
6428:                     .getBoolean(CarrierConfigManager.KEY_WORLD_PHONE_BOOL);
6459:         final Phone phone = getPhone(subscriptionId);
6460:         if (phone == null) {
6461:             loge("isRttSupported: no Phone found. Invalid subId:" + subscriptionId);
6468:                     phone.getContext().getResources().getBoolean(R.bool.config_support_rtt);
6501:      * Returns the unique device ID of phone, for example, the IMEI for
6505:      *   {@link android.Manifest.permission#READ_PHONE_STATE READ_PHONE_STATE}
6509:         final Phone phone = PhoneFactory.getPhone(0);
6510:         if (phone == null) {
6513:         int subId = phone.getSubId();
6521:             return phone.getDeviceId();
6534:         Phone phone = getPhone(subId);
6535:         if (phone != null) {
6536:             return phone.isImsRegistered();
6557:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
6573:             Phone phone = getPhone(subscriptionId);
6574:             if (phone == null) {
6577:             return PhoneUtils.makePstnPhoneAccountHandle(phone);
6589:             Phone phone = getPhone(subId);
6590:             if (phone != null) {
6591:                 return phone.isWifiCallingEnabled();
6606:             Phone phone = getPhone(subId);
6607:             if (phone != null) {
6608:                 return phone.isVideoEnabled();
6624:             Phone phone = getPhone(subId);
6625:             if (phone != null) {
6626:                 return phone.getImsRegistrationTech();
6684:         final Phone phone = getPhone(subId);
6685:         if (phone == null) {
6692:                     phone.getContext().getOpPackageName(), phone.getContext().getAttributionTag());
6701:             final Locale localeFromDefaultSim = phone.getLocaleFromSimAndCarrierPrefs();
6829:             final Phone phone = getPhone(subId);
6830:             if (phone == null) {
6834:             ServiceState ss = phone.getServiceState();
6847:      * Returns the URI for the per-account voicemail ringtone set in Phone settings.
6858:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
6859:             if (phone == null) {
6860:                 phone = getDefaultPhone();
6863:             return VoicemailNotificationSettingsUtil.getRingtoneUri(phone.getContext());
6873:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
6883:         final Phone defaultPhone = getDefaultPhone();
6894:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
6895:             if (phone == null) {
6896:                 phone = defaultPhone;
6898:             VoicemailNotificationSettingsUtil.setRingtoneUri(phone.getContext(), uri);
6905:      * Returns whether vibration is set for voicemail notification in Phone settings.
6915:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(accountHandle);
6916:             if (phone == null) {
6917:                 phone = getDefaultPhone();
6920:             return VoicemailNotificationSettingsUtil.isVibrationEnabled(phone.getContext());
6930:      * has permission {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
6940:         final Phone defaultPhone = getDefaultPhone();
6951:             Phone phone = PhoneUtils.getPhoneForPhoneAccountHandle(phoneAccountHandle);
6952:             if (phone == null) {
6953:                 phone = defaultPhone;
6955:             VoicemailNotificationSettingsUtil.setVibrationEnabled(phone.getContext(), enabled);
6962:      * Make sure either called from same process as self (phone) or IPC caller has read privilege.
6967:         mApp.enforceCallingOrSelfPermission(android.Manifest.permission.READ_PRIVILEGED_PHONE_STATE,
6972:      * Make sure either called from same process as self (phone) or IPC caller has send SMS
7015:         Phone phone = getPhone(subId);
7019:             if (phone == null) {
7024:                 aid = UiccController.getInstance().getUiccCard(phone.getPhoneId())
7044:         Phone phone = getPhone(subId);
7048:             if (phone == null) {
7053:                 esn = phone.getEsn();
7072:         Phone phone = getPhone(subId);
7076:             if (phone == null) {
7081:                 cdmaPrlVersion = phone.getCdmaPrlVersion();
7175:         final Phone phone = getPhone(subId);
7178:         if (phone == null) {
7183:             phone.carrierActionSetMeteredApnsEnabled(enabled);
7200:         final Phone phone = getPhone(subId);
7203:         if (phone == null) {
7208:             phone.carrierActionSetRadioEnabled(enabled);
7228:         final Phone phone = getPhone(subId);
7231:         if (phone == null) {
7236:             phone.carrierActionReportDefaultNetworkStatus(report);
7252:         final Phone phone = getPhone(subId);
7253:         if (phone == null) {
7258:             phone.carrierActionResetAll();
7265:      * Called when "adb shell dumpsys phone" is invoked. Dump is also automatically invoked when a
7272:             writer.println("Permission Denial: can't dump Phone from pid="
7303:             Phone phone = getPhone(subId);
7304:             if (phone != null) {
7305:                 phone.getDataEnabledSettings().setPolicyDataEnabled(enabled);
7324:         Phone phone = getPhone(subId);
7328:             if (phone != null) {
7329:                 return phone.getClientRequestStats();
7356:         Phone phone = PhoneFactory.getPhone(slotIndex);
7362:             if (phone != null) {
7363:                 phone.setSimPowerState(state, workSource);
7385:      * Check if phone is in emergency callback mode
7386:      * @return true if phone is in emergency callback mode
7392:         final Phone phone = getPhone(subId);
7396:             if (phone != null) {
7397:                 return phone.isInEcm();
7417:             Phone p = getPhone(subId);
7437:         Phone phone = PhoneFactory.getPhone(slotIndex);
7438:         if (phone != null) {
7439:             if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, phone.getSubId(),
7446:                 return phone.getRadioPowerState();
7459:      * {@link android.Manifest.permission#READ_PHONE_STATE} or that the calling app has carrier
7479:             Phone phone = getPhone(subId);
7480:             isEnabled =  phone != null ? phone.getDataRoamingEnabled() : false;
7492:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE} or that the calling app has carrier
7505:             Phone phone = getPhone(subId);
7506:             if (phone != null) {
7507:                 phone.setDataRoamingEnabled(isEnabled);
7523:             Phone phone = getPhone(subId);
7524:             if (phone != null) {
7525:                 isAllowed = phone.isCspPlmnEnabled();
7544:             // even without READ_PRIVILEGED_PHONE_STATE, we allow the call to continue if the caller
7681:      * {@link android.Manifest.permission#MODIFY_PHONE_STATE MODIFY_PHONE_STATE}.
7690:             Phone phone = getPhone(subId);
7691:             if (phone == null) {
7694:             UiccCard uiccCard = phone.getUiccCard();
7731:      * not set, return {@link Phone#PREFERRED_NT_MODE}.
7739:         return Phone.PREFERRED_NT_MODE;
7749:             final Phone phone = getPhone(subId);
7750:             if (phone == null) {
7754:             phone.setCarrierTestOverride(mccmnc, imsi, iccid, gid1, gid2, plmn, spn,
7772:             final Phone phone = getPhone(subId);
7773:             if (phone == null) {
7777:             return phone.getCarrierIdListVersion();
7846:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
7851:             for (Phone phone: PhoneFactory.getPhones()) {
7852:                 if (phone.getEmergencyNumberTracker() != null
7853:                         && phone.getEmergencyNumberTracker().getEmergencyNumberList() != null) {
7855:                             phone.getSubId(),
7856:                             phone.getEmergencyNumberTracker().getEmergencyNumberList());
7867:         final Phone defaultPhone = getDefaultPhone();
7875:             for (Phone phone: PhoneFactory.getPhones()) {
7876:                 if (phone.getEmergencyNumberTracker() != null
7877:                         && phone.getEmergencyNumberTracker()
7898:             for (Phone phone: PhoneFactory.getPhones()) {
7899:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7920:             for (Phone phone: PhoneFactory.getPhones()) {
7921:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7940:             final Phone phone = getPhone(subId);
7941:             if (phone == null) {
7945:             return phone.getEmergencyNumberDbVersion();
7957:             for (Phone phone: PhoneFactory.getPhones()) {
7958:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7974:             for (Phone phone: PhoneFactory.getPhones()) {
7975:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
7991:             for (Phone phone: PhoneFactory.getPhones()) {
7992:                 EmergencyNumberTracker tracker = phone.getEmergencyNumberTracker();
8005:         Phone phone = getPhone(subId);
8006:         if (phone == null) {
8012:                     .getUiccProfileForPhone(phone.getPhoneId());
8031:             Phone phone = PhoneFactory.getPhone(slotIndex);
8032:             if (phone == null) {
8035:                 return (Boolean) sendRequest(CMD_REQUEST_ENABLE_MODEM, enable, phone, null);
8048:         Phone phone = PhoneFactory.getPhone(slotIndex);
8049:         if (phone == null) return false;
8052:                 mApp, phone.getSubId(), callingPackage, callingFeatureId,
8054:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8060:                 return mPhoneConfigurationManager.getPhoneStatusFromCache(phone.getPhoneId());
8062:                 return (Boolean) sendRequest(CMD_GET_MODEM_STATUS, null, phone, null);
8130:      * Note: Switch from multi-sim to single-sim is only possible with MODIFY_PHONE_STATE
8131:      * permission, but the other way around is possible with either MODIFY_PHONE_STATE
8160:         Phone phone = getPhone(subId);
8161:         if (phone == null) {
8166:             UiccCard uiccCard = phone.getUiccCard();
8236:         Phone phone = getDefaultPhone();
8237:         if (phone == null) return -1;
8238:         HalVersion hv = phone.getHalVersion();
8268:         enforceReadPrivilegedPermission("Needs READ_PRIVILEGED_PHONE_STATE for "
8274:             Phone phone = getPhone(subId);
8275:             if (phone == null) return false;
8277:             boolean isMetered = ApnSettingUtils.isMeteredApnType(apnType, phone);
8278:             return !isMetered || phone.getDataEnabledSettings().isDataEnabled(apnType);
8291:             Phone phone = getPhone(subId);
8292:             if (phone == null) return true; // By default return true.
8294:             return ApnSettingUtils.isMeteredApnType(apnType, phone);
8306:             Phone phone = getPhone(subscriptionId);
8307:             if (phone == null) {
8327:             sendRequestAsync(CMD_SET_SYSTEM_SELECTION_CHANNELS, argument, phone, null);
8408:             Phone phone = getPhone(subId);
8409:             if (phone == null) return false;
8411:             return phone.getDataEnabledSettings().setAllowDataDuringVoiceCall(allow);
8424:             Phone phone = getPhone(subId);
8425:             if (phone == null) return false;
8427:             return phone.getDataEnabledSettings().isDataAllowedInVoiceCall();
8440:             Phone phone = getPhone(subId);
8441:             if (phone == null) return false;
8443:             return phone.getDataEnabledSettings().setAlwaysAllowMmsData(alwaysAllow);
8461:             for (Phone phone : PhoneFactory.getPhones()) {
8462:                 Phone defaultPhone = phone.getImsPhone();
8463:                 if (defaultPhone != null && defaultPhone.getPhoneType() == PHONE_TYPE_IMS) {
8508:             Phone phone = getPhone(subId);
8509:             if (phone != null && phone.getIccCard() != null) {
8510:                 return phone.getIccCard().getIccLockEnabled();
8534:         Phone phone = getPhone(subId);
8535:         if (phone == null) {
8542:                     new Pair<Boolean, String>(enabled, password), phone, null);
8566:         Phone phone = getPhone(subId);
8567:         if (phone == null) {
8574:                     new Pair<String, String>(oldPassword, newPassword), phone, null);
8633:             throw new SecurityException("Requires READ_PHONE_STATE permission.");
8636:         Phone phone = getPhone(subId);
8637:         if (phone == null) {
8638:             throw new RuntimeException("phone is not available");
8643:             return phone.getEquivalentHomePlmns();
22: import static com.android.internal.telephony.PhoneConstants.SUBSCRIPTION_KEY;
63: import android.telecom.PhoneAccount;
64: import android.telecom.PhoneAccountHandle;
83: import android.telephony.PhoneCapability;
84: import android.telephony.PhoneNumberRange;
141: import com.android.internal.telephony.PhoneConfigurationManager;
142: import com.android.internal.telephony.PhoneConstantConversions;
143: import com.android.internal.telephony.PhoneConstants;
144: import com.android.internal.telephony.PhoneFactory;
158: import com.android.internal.telephony.imsphone.ImsPhone;
159: import com.android.internal.telephony.imsphone.ImsPhoneCallTracker;
199:     private static final String LOG_TAG = "PhoneInterfaceManager";
200:     private static final boolean DBG = (PhoneGlobals.DBG_LEVEL >= 2);
298:     private static PhoneInterfaceManager sInstance;
300:     private PhoneGlobals mApp;
697:                     defaultPhone.nvReadItem((Integer) request.argument, onCompleted,
724:                     defaultPhone.nvWriteItem(idValue.first, idValue.second, onCompleted,
735:                     defaultPhone.nvWriteCdmaPrl((byte[]) request.argument, onCompleted);
745:                     defaultPhone.resetModemConfig(onCompleted);
793:                     defaultPhone.invokeOemRilRequestRaw((byte[]) request.argument, onCompleted);
1031:                     if (defaultPhone != null) {
1032:                         defaultPhone.getModemActivityInfo(onCompleted, request.workSource);
1095:                     defaultPhone.setAllowedCarriers(argument, onCompleted, request.workSource);
1123:                     defaultPhone.getAllowedCarriers(onCompleted, request.workSource);
1329:                     defaultPhone.rebootModem(onCompleted);
1339:                     PhoneConfigurationManager.getInstance()
1349:                         mPhoneConfigurationManager.addToPhoneStatusCache(phoneId, msg.arg1 == 1);
1360:                     PhoneConfigurationManager.getInstance()
1448:                     defaultPhone.eraseModemConfig(onCompleted);
1494:                     getDefaultPhone().getContext().sendBroadcastAsUser(
1640:      * Initialize the singleton PhoneInterfaceManager instance.
1641:      * This is only done once, at startup, from PhoneApp.onCreate().
1643:     /* package */ static PhoneInterfaceManager init(PhoneGlobals app) {
1644:         synchronized (PhoneInterfaceManager.class) {
1646:                 sInstance = new PhoneInterfaceManager(app);
1657:         mCM = PhoneGlobals.getInstance().mCM;
1658:         mImsResolver = PhoneGlobals.getInstance().getImsResolver();
1666:         mPhoneConfigurationManager = PhoneConfigurationManager.getInstance();
1674:         return (thePhone != null) ? thePhone : PhoneFactory.getDefaultPhone();
1696:                 ? getDefaultPhone() : getPhone(subId);
1707:         return PhoneFactory.getPhone(mSubscriptionController.getPhoneId(subId));
1725:         PackageManager pm = getDefaultPhone().getContext().getPackageManager();
1752:             PhoneConstants.State state = mCM.getState(subId);
1753:             if (state != PhoneConstants.State.OFFHOOK && state != PhoneConstants.State.RINGING) {
1812:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
1817:         return (resultArray[0] == PhoneConstants.PIN_RESULT_SUCCESS) ? true : false;
1825:             final UnlockSim checkSimPin = new UnlockSim(getPhone(subId).getIccCard());
1838:             final UnlockSim checkSimPuk = new UnlockSim(getPhone(subId).getIccCard());
1855:         private int mResult = PhoneConstants.PIN_GENERAL_FAILURE;
1885:                                             mResult = PhoneConstants.PIN_PASSWORD_INCORRECT;
1890:                                             mResult = PhoneConstants.PIN_OPERATION_ABORTED;
1892:                                             mResult = PhoneConstants.PIN_GENERAL_FAILURE;
1895:                                         mResult = PhoneConstants.PIN_RESULT_SUCCESS;
2103:             logv(TelephonyManager.getDefault().getPhoneCount() + " Phones are shutdown.");
2138:             if (defaultPhone != null) {
2139:                 defaultPhone.setRadioPower(turnOn);
2283:                 return PhoneConstantConversions.convertDataState(
2284:                         PhoneConstants.DataState.DISCONNECTED);
2356:             final int subId = mSubscriptionController.getSubIdUsingPhoneId(phoneId);
2564:             getDefaultPhone().setCellInfoListRate(rateInMillis, workSource);
2768:         Log.d(LOG_TAG, "[PhoneIntfMgr] " + msg);
2772:         Log.v(LOG_TAG, "[PhoneIntfMgr] " + msg);
2776:         Log.e(LOG_TAG, "[PhoneIntfMgr] " + msg);
2938:     public void requestNumberVerification(PhoneNumberRange range, long timeoutMillis,
2967:             return getDefaultPhone().needsOtaServiceProvisioning();
3002:             PhoneAccountHandle phoneAccountHandle = PhoneAccountHandleConverter.fromSubId(subId);
3003:             if (phoneAccountHandle == null) {
3006:             return VisualVoicemailSettingsUtil.dump(mApp, phoneAccountHandle);
3091:         SmsController smsController = PhoneFactory.getSmsController();
3226:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
3235:             defaultPhone.sendDialerSpecialCode(inputCode);
3290:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3314:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3410:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3437:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone.
3453:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3532:         // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3550:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3570:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3585:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3604:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3620:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3639:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3655:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3671:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3691:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3707:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3722:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3738:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3754:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3773:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3792:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3810:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3855:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3885:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3918:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
3977:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4146:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4171:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4197:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4223:             // TODO: Refactor to remove ImsManager dependence and query through ImsPhone directly.
4393:             return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4400:                 return PhoneConstants.LTE_ON_CDMA_UNKNOWN;
4403:                         .orElse(PhoneConstants.LTE_ON_CDMA_FALSE);
4464:         int phoneId = UiccController.getInstance().getPhoneIdFromSlotId(slotIndex);
4465:         if (phoneId == -1) {
4469:         return PhoneFactory.getPhone(phoneId);
4504:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
4646:                 ComponentInfo bestComponent = EuiccConnector.findBestComponent(getDefaultPhone()
4937:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
4944:             return defaultPhone.getPcscfAddress(apnType);
5188:             getDefaultPhone().setImsRegistrationState(registered);
5424:                     request, messenger, binder, getPhone(subId),
5485:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
5493:             return PhoneFactory.calculatePreferredNetworkType(defaultPhone.getContext(), 0);
5695:             int phoneId = mSubscriptionController.getPhoneId(subId);
5696:             if (DBG) log("setUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5774:             int phoneId = mSubscriptionController.getPhoneId(subId);
5775:             if (DBG) log("isUserDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5803:             int phoneId = mSubscriptionController.getPhoneId(subId);
5804:             if (DBG) log("isDataEnabled: subId=" + subId + " phoneId=" + phoneId);
5924:         int phoneId = SubscriptionManager.getPhoneId(subId);
5925:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
5932:             getPhone(phoneId), pkgName);
5949:                 getPhone(i), pkgName);
5960:         if (!SubscriptionManager.isValidPhoneId(phoneId)) {
5961:             loge("phoneId " + phoneId + " is not valid.");
5964:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
5966:             loge("getCarrierPackageNamesForIntentAndPhone: No UICC");
5973:     public List<String> getPackagesWithCarrierPrivileges(int phoneId) {
5977:         UiccCard card = UiccController.getInstance().getUiccCard(phoneId);
6340:     public int getRadioAccessFamily(int phoneId, String callingPackage) {
6351:             raf = ProxyController.getInstance().getRadioAccessFamily(phoneId);
6365:             ImsManager.getInstance(defaultPhone.getContext(),
6366:                     defaultPhone.getPhoneId()).setVtSetting(enable);
6375:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, defaultPhone.getSubId(),
6387:                     ImsManager.getInstance(defaultPhone.getContext(), defaultPhone.getPhoneId());
6502:      * GSM and the MEID for CDMA phones. Return null if device ID is not available.
6546:             return PhoneUtils.getSubIdForPhoneAccount(phoneAccount);
6554:             PhoneAccountHandle phoneAccountHandle, String callingPackage, String callingFeatureId) {
6561:             return PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle);
6657:             cleanUpSmsRawTable(getDefaultPhone().getContext());
6668:               sendEraseModemConfig(getDefaultPhone());
6849:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
6852:      * PhoneAccount.
6855:     public Uri getVoicemailRingtoneUri(PhoneAccountHandle accountHandle) {
6875:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
6878:      * PhoneAccount.
6882:             PhoneAccountHandle phoneAccountHandle, Uri uri) {
6885:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
6888:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
6907:      * @param accountHandle The handle for the {@link PhoneAccount} for which to retrieve the
6909:      * @return {@code true} if the vibration is set for this PhoneAccount, {@code false} otherwise.
6912:     public boolean isVoicemailVibrationEnabled(PhoneAccountHandle accountHandle) {
6932:      * @param phoneAccountHandle The handle for the {@link PhoneAccount} for which to set the
6935:      * specific PhoneAccount.
6939:             PhoneAccountHandle phoneAccountHandle, boolean enabled) {
6942:         TelecomManager tm = defaultPhone.getContext().getSystemService(TelecomManager.class);
6945:                     mApp, PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle),
7286:         return new TelephonyShellCommand(this, getDefaultPhone().getContext()).exec(
7546:             if (checkCarrierPrivilegesForPackageAnyPhone(callingPackage)
7735:         int phoneId = mSubscriptionController.getPhoneId(subId);
7736:         if (phoneId >= 0 && phoneId < list.size() && list.get(phoneId) != null) {
7737:             return list.get(phoneId);
7871:                             mApp, defaultPhone.getSubId(), "isEmergencyNumber(Potential)");
8087:                 getDefaultPhone().getSubId(), callingPackage, callingFeatureId,
8110:         PhoneCapability staticCapability =
8216:             int phoneCount = TelephonyManager.getDefault().getPhoneCount();
8218:             int[] logicalSlotsMapping = new int[phoneCount];
8351:         SmsPermissions permissions = new SmsPermissions(getDefaultPhone(), mApp,
8377:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
8394:             return SubscriptionManager.getResourcesForSubId(getDefaultPhone().getContext(), subId)
8464:                     ImsPhone imsPhone = (ImsPhone) defaultPhone;
8466:                             (ImsPhoneCallTracker) imsPhone.getCallTracker();
8468:                     Rlog.i(LOG_TAG, "setCepEnabled isCepEnabled=" + isCepEnabled + ", for imsPhone "
8469:                             + imsPhone.getMsisdn());
8603:         // *  Inherited from PhoneWindowManager  *
130: import com.android.internal.telephony.DefaultPhoneNotifier;
480:                             getPhoneFromRequest(request).handlePinMmi((String) request.argument)
755:                     getPhoneFromRequest(request).getPreferredNetworkType(onCompleted);
783:                     getPhoneFromRequest(request).setPreferredNetworkType(networkType, onCompleted);
807:                     getPhoneFromRequest(request).setVoiceMailNumber(tagNum.first, tagNum.second,
819:                     getPhoneFromRequest(request).setNetworkSelectionModeAutomatic(onCompleted);
829:                     getPhoneFromRequest(request).getAvailableNetworks(onCompleted);
836:                     getPhoneFromRequest(request).getCallForwardingOption(
893:                     getPhoneFromRequest(request).setCallForwardingOption(
915:                     getPhoneFromRequest(request).getCallWaiting(onCompleted);
959:                     getPhoneFromRequest(request).setCallWaiting(isEnable, onCompleted);
1011:                     getPhoneFromRequest(request).selectNetworkManually(selArg.operatorInfo,
1206:                     getPhoneFromRequest(request).getNetworkSelectionMode(onCompleted);
1227:                     getPhoneFromRequest(request).queryCdmaRoamingPreference(onCompleted);
1243:                     getPhoneFromRequest(request).setCdmaRoamingPreference(mode, onCompleted);
1255:                     getPhoneFromRequest(request).setCdmaSubscription(subscriptionMode, onCompleted);
1370:                         mPhoneConfigurationManager.addToPhoneStatusCache(id,
1458:                     getPhoneFromRequest(request).getIccCard().changeIccLockPassword(
1476:                     getPhoneFromRequest(request).getIccCard().setIccLockEnabled(
1690:             return getPhoneFromSubId(request.subId);
2024:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2099:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2116:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
2118:                 shutdownRadioUsingPhoneId(i);
2641:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2781:         return getActivePhoneTypeForSlot(getSlotForDefaultSubscription());
2811:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2844:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
2875:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3016:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3184:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
3244:                     .enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3281:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3307:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3364:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3404:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3429:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3529:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3566:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3600:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3635:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3687:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3769:         TelephonyPermissions.enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
3851:         checkModifyPhoneStatePermission(subId, "setRcsProvisioningStatusForCapability");
3915:         checkModifyPhoneStatePermission(subId, "setImsProvisioningStatusForCapability");
4267:                 && !TelephonyPermissions.checkCallingOrSelfReadPhoneStateNoThrow(
4301:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4326:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4419:         return mSubscriptionController.getPhoneId(getDefaultSubscription());
4481:         return iccOpenLogicalChannelWithPermission(getPhoneFromSubId(subId), callingPackage, aid,
4494:         return iccOpenLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4529:         return iccCloseLogicalChannelWithPermission(getPhoneFromSubId(subId), channel);
4536:         return iccCloseLogicalChannelWithPermission(getPhoneFromSlotIdOrThrowException(slotIndex),
4565:         return iccTransmitApduLogicalChannelWithPermission(getPhoneFromSubId(subId), channel, cla,
4579:                 getPhoneFromSlotIdOrThrowException(slotIndex), channel, cla, command, p1, p2, p3,
4618:         return iccTransmitApduBasicChannelWithPermission(getPhoneFromSubId(subId), callingPackage,
4634:                 getPhoneFromSlotIdOrThrowException(slotIndex), callingPackage, cla, command, p1,
4719:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
4757:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, subId, callingPackage,
5131:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5259:                     .enforeceCallingOrSelfReadPrecisePhoneStatePermissionOrCarrierPrivilege(
5508:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5557:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5602:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5606:             return getPhoneFromSubId(subId).getAllowedNetworkTypes(reason);
5623:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
5627:             return getPhoneFromSubId(subId).getEffectiveAllowedNetworkTypes();
5649:             getPhoneFromSubId(subId).setAllowedNetworkTypes(reason, allowedNetworkTypes);
5940:         for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6004:         enforceReadPrivilegedPermission("getPackagesWithCarrierPrivilegesForAllPhones");
6010:             for (int i = 0; i < TelephonyManager.getDefault().getPhoneCount(); i++) {
6090:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneNumber(
6117:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6140:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6349:                     .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
6399:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6418:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
6555:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp, getDefaultSubscription(),
6556:                 callingPackage, callingFeatureId, "getSubIdForPhoneAccountHandle")) {
6569:         enforceReadPrivilegedPermission("getPhoneAccountHandleForSubscriptionId, "
6793:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7320:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7472:             TelephonyPermissions.enforeceCallingOrSelfReadPhoneStatePermissionOrCarrierPrivilege(
7517:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7645:                         slot.getPhoneId(),
7786:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7794:             return mPhoneConfigurationManager.getNumberOfModemsWithSimultaneousDataConnections();
7803:                 .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
7843:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
7870:                     .enforeceCallingOrSelfReadPrivilegedPhoneStatePermissionOrCarrierPrivilege(
8051:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8086:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(mApp,
8111:                 mPhoneConfigurationManager.getStaticPhoneCapability();
8151:             mPhoneConfigurationManager.switchMultiSimConfig(numOfSims);
8191:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
8198:             return mPhoneConfigurationManager.isRebootRequiredForModemConfigChange();
8207:         metrics.updateEnabledModemBitmap((1 << TelephonyManager.from(mApp).getPhoneCount()) - 1);
8221:                 if (SubscriptionManager.isValidPhoneId(slotInfos[i].getLogicalSlotIdx())) {
8337:                 SubscriptionManager.getPhoneId(subId), UiccController.APP_FAM_3GPP);
8465:                     ImsPhoneCallTracker imsPhoneCallTracker =
8467:                     imsPhoneCallTracker.setConferenceEventPackageEnabled(isCepEnabled);
8631:         if (!TelephonyPermissions.checkCallingOrSelfReadPhoneState(
android.googlesource.com/platform/frameworks/opt/telephony:src/java/com/android/internal/telephony/Phone.java: [ master, ]
133: public abstract class Phone extends Handler implements PhoneInternalInterface {
530:     protected Phone(String name, PhoneNotifier notifier, Context context, CommandsInterface ci,
547:     protected Phone(String name, PhoneNotifier notifier, Context context, CommandsInterface ci,
349:     protected Phone mImsPhone = null;
627:     public void createImsPhone() {
3922:     public Phone getImsPhone() {
4600:     public Phone getDefaultPhone() {
212:     protected static final int EVENT_UPDATE_PHONE_OBJECT            = 42;
315:     protected boolean mIsPhoneInEcmState = false;
346:     protected int mPhoneId;
470:     public String getPhoneName() {
474:     protected void setPhoneName(String name) {
1834:     public void updatePhoneObject(int voiceRadioTech) {
2952:     public abstract int getPhoneType();
4054:     public int getPhoneId() {
4062:     public int getVoicePhoneServiceState() {
123:  * A base implementation for the com.android.internal.telephony.Phone interface.
125:  * Note that implementations of Phone.java are expected to be used
134:     private static final String LOG_TAG = "Phone";
263:      * This method is invoked when the Phone exits Emergency Callback Mode.
313:     // Keep track of whether or not the phone is in Emergency Callback Mode for Phone and
465:      * Returns a string identifier for this phone interface for parties
466:      *  outside the phone app process.
521:      * Constructs a Phone in normal (non-unit test) mode.
532:         this(name, notifier, context, ci, unitTestMode, SubscriptionManager.DEFAULT_PHONE_INDEX,
537:      * Constructs a Phone in normal (non-unit test) mode.
545:      * @param phoneId the phone-id of this phone.
573:         * (i.e. voice) phone calls over the telephony network, and is allowed
601:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_IMS) {
616:         if (getPhoneType() != PhoneConstants.PHONE_TYPE_SIP) {
628:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_SIP) {
632:         synchronized(Phone.lockForRadioTechnologyChange) {
695:         // messages to be handled whether or not the phone is being destroyed
697:         // resources of the phone being destroyed
820:         Phone imsPhone = mImsPhone;
859:      * Gets the context for the phone, as set at initialization time.
915:      * Subclasses of Phone probably want to replace this with a
941:      * Subclasses of Phone probably want to replace this with a
965:      * Subclasses of Phone probably want to replace this with a
977:      * Notify the phone that an SMS has been sent. This will be used determine if the SMS was sent
991:      * Determine if the Phone has recently sent an emergency SMS and is still in the interval of
1032:     protected void migrateFrom(Phone from) {
1045:         // The emergency state of IMS phone will be cleared in ImsPhone#notifySrvccState after
1108:      *   Connection.getCall() == Phone.getRingingCall()
1128:      * Notifies when phone's video capabilities changes <p>
1133:      *  AsyncResult.result = true if phone supports video calling <p>
1272:      * Example: If Phone.dial is called with "*#31#", then the app will
1595:      * For unit tests; don't send notifications to "Phone"
1612:      * Subclasses of Phone probably want to replace this with a
1717:         // no need for regular phone
1721:      * Subclasses of Phone probably want to replace this with a
1733:      * we send out a final ServiceState update when a phone's subId becomes invalid.
1743:      * If this is a simulated phone interface, returns a SimulatedRadioControl.
1757:      * the thread that originally obtained this Phone instance.
1762:                     "com.android.internal.telephony.Phone must be used from within one thread");
1794:      * If the phone has an active call and call waiting occurs,
1795:      * then the phone state is RINGING not OFFHOOK
1804:      * Retrieves the IccFileHandler of the Phone instance
1823:      * Retrieves the Handler of the Phone instance
1830:      * Update the phone object if the voice radio technology has changed
1838:     * Retrieves the ServiceStateTracker of the phone instance.
1853:                 .contains(Phone.RADIO_POWER_REASON_THERMAL);
1857:      * Retrieves the EmergencyNumberTracker of the phone instance.
1879:      * Retrieves the DeviceStateMonitor of the phone instance.
1886:      * Retrieves the DisplayInfoController of the phone instance.
1934:      * Returns the ICC card interface for this phone, or null
1940:         //throw new Exception("getIccCard Shouldn't be called from Phone");
2127:         if (getPhoneType() == PhoneConstants.PHONE_TYPE_CDMA) {
2534:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
2535:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
2536:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
2537:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
2548:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
2549:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
2550:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
2551:      * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
2857:     // This property is used to handle phone process crashes, and is the same for CDMA and IMS
2864:      * @return {@code true} if we are in emergency call back mode. This is a period where the phone
2884:      * @return true if this Phone is in an emergency call that caused emergency callback mode to be
2892:      * Set whether or not this Phone has an active emergency call that was placed during emergency
2948:      * Return a numerical identifier for the phone radio interface.
2949:      * @return PHONE_TYPE_XXX as defined above.
2962:     /** sets the voice mail count of the phone and notifies listeners. */
3613:         // Populate the iccid, imei and phone number in the provisioning url.
3622:                     phoneNumber /* Phone number */);
3743:      * Subclasses of Phone probably want to replace this with a
3761:      * Notify registrants if phone is video capable.
3875:         Rlog.e(LOG_TAG, "Error! This function should never be executed, inactive Phone.");
3888:      * Gets the Uicc card corresponding to this phone.
3889:      * @return the UiccCard object corresponding to the phone ID.
3919:      * Return an instance of a IMS phone
4051:      * Returns the phone id.
4063:         Phone imsPhone = mImsPhone;
4137:         Phone imsPhone = mImsPhone;
4156:         Phone imsPhone = mImsPhone;
4170:         Phone imsPhone = mImsPhone;
4194:         Phone imsPhone = mImsPhone;
4204:      * @return the IMS MmTel Registration technology for this Phone, defined in
4208:         Phone imsPhone = mImsPhone;
4218:      * Get the IMS MmTel Registration technology for this Phone, defined in
4222:         Phone imsPhone = mImsPhone;
4231:      * Asynchronously get the IMS MmTel Registration state for this Phone.
4234:         Phone imsPhone = mImsPhone;
4292:      *  Set phone radio capability
4294:      *  @param rc the phone radio capability defined in
4303:      *  Get phone radio access family
4323:      *  Get phone radio capability
4337:      *  @param rc the phone radio capability currently in effect for this phone.
4352:         // When radio capability switch is done, query IMEI value and update it in Phone objects
4378:      * Registers the handler when phone radio  capability is changed.
4389:      * Unregister for notifications when phone radio type and access technology is changed.
4410:      * Determines if video calling is enabled for the phone.
4416:         Phone imsPhone = mImsPhone;
4555:     public static void checkWfcWifiOnlyModeBeforeDial(Phone imsPhone, int phoneId, Context context)
4595:      * This function returns the parent phone of the current phone. It is applicable
4596:      * only for IMS phone (function is overridden by ImsPhone). For others the phone
4634:      * none of the phone is in service, and one of them has the capability to make the emergency
4641:         for (Phone phone : PhoneFactory.getPhones()) {
4642:             if (phone != null) {
4643:                 ServiceStateTracker sst = phone.getServiceStateTracker();
4706:     /** Returns the {@link VoiceCallSessionStats} for this phone ID. */
4711:     /** Sets the {@link VoiceCallSessionStats} mock for this phone ID during unit testing. */
4717:     /** Returns the {@link SmsStats} for this phone ID. */
4722:     /** Sets the {@link SmsStats} mock for this phone ID during unit testing. */
4778:         pw.println("Phone: subId=" + getSubId());
4953:         pw.println("Phone Local Log: ");
53: import android.telephony.PhoneStateListener;
83: import com.android.internal.telephony.imsphone.ImsPhoneCall;
127:  * originally called PhoneFactory to obtain the interface.
438:      * PhoneNotifier is an abstraction for all system-wide
443:     protected PhoneNotifier mNotifier;
479:      * Retrieves Nai for phones. Returns null if Nai is not set.
548:                     boolean unitTestMode, int phoneId,
550:         mPhoneId = phoneId;
587:          * By default old phones won't have the property set but do generate
624:      * Start setup of ImsPhone, which will start trying to connect to the ImsResolver. Will not be
633:             if (mImsPhone == null) {
634:                 mImsPhone = PhoneFactory.makeImsPhone(mNotifier, this);
635:                 CallManager.getInstance().registerPhone(mImsPhone);
636:                 mImsPhone.registerForSilentRedial(
711:                     PhoneConstants.State state = getState();
713:                             && ((state == PhoneConstants.State.RINGING) ||
714:                                     (state == PhoneConstants.State.IDLE))) {
725:                 if (getState() == PhoneConstants.State.RINGING) {
746:                         if (mImsPhone != null) {
748:                             mImsPhone.notifyRedialConnectionChanged(cn);
752:                         if (mImsPhone != null) {
753:                             mImsPhone.notifyRedialConnectionChanged(null);
827:                     if (imsPhone != null) {
828:                         conn = imsPhone.getHandoverConnection();
829:                         migrateFrom(imsPhone);
831:                         Rlog.d(LOG_TAG, "HANDOVER_STARTED: mImsPhone null");
836:                     if (imsPhone != null) {
837:                         imsPhone.notifySrvccState(srvccState);
839:                         Rlog.d(LOG_TAG, "HANDOVER_COMPLETED: mImsPhone null");
892:      * {@link PhoneConstants.State} which can be obtained using the {@link PhoneStateListener}
1062:             // Since CallManager has already registered with both CS and IMS phones,
1801:     public abstract PhoneConstants.State getState();
2010:      * Sets the minimum time in milli-seconds between {@link PhoneStateListener#onCellInfoChanged
2011:      * PhoneStateListener.onCellInfoChanged} will be invoked.
2026:      * available on this interface. Use PhoneStateNotifier or similar instead.
2122:      * available on this interface. Use PhoneStateNotifier or similar instead.
2173:      * interface. Use <code>PhoneStateNotifier</code> or an equivalent.
2774:     public PhoneConstants.DataState getDataConnectionState(String apnType) {
2775:         return PhoneConstants.DataState.DISCONNECTED;
2858:     // phones
2938:         if (mImsPhone != null) {
2939:             isPresent = isVideoCallOrConference(mImsPhone.getForegroundCall()) ||
2940:                     isVideoCallOrConference(mImsPhone.getBackgroundCall()) ||
2941:                     isVideoCallOrConference(mImsPhone.getRingingCall());
3083:      * Retrieves the MIN for CDMA phones.
3099:      *  Retrieves PRL Version for CDMA phones
3615:             String phoneNumber = getLine1Number();
3616:             if (TextUtils.isEmpty(phoneNumber)) {
3617:                 phoneNumber = "0000000000";
3837:      * Retrieves the MSISDN from the UICC. For GSM/UMTS phones, this is equivalent to
3838:      * {@link #getLine1Number()}. For CDMA phones, {@link #getLine1Number()} returns
3839:      * the MDN, so this method is provided to return the MSISDN on CDMA/LTE phones.
3847:      * Retrieves the EF_PNN from the UICC For GSM/UMTS phones.
3856:      * {@link android.telephony.PhoneStateListener} instead.
3859:     public PhoneConstants.DataState getDataConnectionState() {
3874:         // This function should be overridden by class GsmCdmaPhone.
3923:         return mImsPhone;
3998:      * Return if UT capability of ImsPhone is enabled or not
4002:         if (mImsPhone != null) {
4003:             return mImsPhone.isUtEnabled();
4022:         // dialInternal shall be overriden by GsmCdmaPhone
4027:      * This function is for CSFB SS. GsmCdmaPhone overrides this function.
4059:      * Return the service state of mImsPhone if it is STATE_IN_SERVICE
4064:         if (imsPhone != null
4065:                 && imsPhone.getServiceState().getState() == ServiceState.STATE_IN_SERVICE) {
4139:         if (imsPhone != null) {
4140:             isImsRegistered = imsPhone.isImsRegistered();
4158:         if (imsPhone != null) {
4159:             isWifiCallingEnabled = imsPhone.isWifiCallingEnabled();
4172:         if (imsPhone != null) {
4173:             isAvailable = imsPhone.isImsCapabilityAvailable(capability, regTech);
4196:         if (imsPhone != null) {
4197:             isVolteEnabled = imsPhone.isVoiceOverCellularImsEnabled();
4210:         if (imsPhone != null) {
4211:             regTech = imsPhone.getImsRegistrationTech();
4223:         if (imsPhone != null) {
4224:             imsPhone.getImsRegistrationTech(callback);
4235:         if (imsPhone != null) {
4236:             imsPhone.getImsRegistrationState(callback);
4402:         if (mImsPhone == null) {
4406:         return mImsPhone.isImsAvailable();
4417:         if (imsPhone != null) {
4418:             return imsPhone.isVideoEnabled();
4557:         if (imsPhone == null || !imsPhone.isWifiCallingEnabled()) {
4558:             ImsManager imsManager = ImsManager.getInstance(context, phoneId);
4817:         if (mImsPhone != null) {
4819:                 mImsPhone.dump(fd, pw, args);
439:      * state change notification. DefaultPhoneNotifier is
523:      * @param notifier An instance of DefaultPhoneNotifier,
539:      * @param notifier An instance of DefaultPhoneNotifier,
2739:         // This function is added to send the notification to DefaultPhoneNotifier.
2869:         return mIsPhoneInEcmState;
2880:         mIsPhoneInEcmState = isInEcm;
2924:         if (call instanceof ImsPhoneCall) {
2925:             ImsPhoneCall imsPhoneCall = (ImsPhoneCall) call;
2926:             ImsCall imsCall = imsPhoneCall.getImsCall();
2980:                 mPhoneId, UiccController.APP_FAM_3GPP);
3813:      * A fucntion of type getPhoneProp(propType) where propType is an
3893:         return mUiccController.getUiccCard(mPhoneId);
4047:         return SubscriptionController.getInstance().getSubIdUsingPhoneId(mPhoneId);
4055:         return mPhoneId;
4779:         pw.println(" mPhoneId=" + mPhoneId);
4806:         pw.println(" getPhoneName()=" + getPhoneName());
4807:         pw.println(" getPhoneType()=" + getPhoneType());
4966:         Rlog.d(LOG_TAG, "[" + mPhoneId + "] " + s);
4970:         Rlog.i(LOG_TAG, "[" + mPhoneId + "] " + s);
4974:         Rlog.e(LOG_TAG, "[" + mPhoneId + "] " + s);
android.googlesource.com/platform/external/guice:examples/src/example/xml/Phone.java: [ master, ]
3: public class Phone {
android.googlesource.com/platform/frameworks/proto_logging:stats/atoms.proto: [ master, ]
6852:         PHONE = 9;
140:         PhoneSignalStrengthChanged phone_signal_strength_changed =
201:         PhoneServiceStateChanged phone_service_state_changed = 94 [(module) = "framework"];
202:         PhoneStateChanged phone_state_changed = 95 [(module) = "framework"];
2901:         HARDWARE_FAILED_MICROPHONE = 1;
3071: message PhoneSignalStrengthChanged {
3083: message PhoneServiceStateChanged {
3095: message PhoneStateChanged {
1618:  *   frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/phone/StatusBarKeyguardViewManager.java
1623:         // The keyguard is hidden when the phone is unlocked.
1625:         // The keyguard is shown when the phone is locked (screen turns off).
1639:  *   frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardBouncer.java
3066:  * Logs phone signal strength changes.
3078:  * Logs when the phone state, sim state or signal strength changes
3090:  * Logs when the phone becomes on or off.
3156:                 statusbar/phone/NavigationBarView.java
3760:  *      frameworks/base/packages/SystemUI/src/com/android/systemui/pip/phone/PipTouchHandler.java
1786:     // For multi-sim phones, this distinguishes between the sim cards.
1808:     // For multi-sim phones, this distinguishes between the sim cards.
6637:  * time_in_state files not being present on some phones, have not been addressed. These should be
8153:  * Track how we arbitrate between microphone/input requests.
8168:  * Track how we arbitrate between microphone requests.
8183:  * Track how we arbitrate between microphone/input requests.
8198:  * Track how we arbitrate between microphone/input requests.
android.googlesource.com/platform/external/valgrind:include/vki/vki-linux.h: [ master, ]
1643:   char phone[VKI_ISDN_MSNLEN];
1645: } vki_isdn_net_ioctl_phone;
android.googlesource.com/platform/frameworks/opt/vcard:java/com/android/vcard/VCardEntry.java: [ master, ]
101:         PHONE,
315:     public static class PhoneData implements EntryElement {
325:         public PhoneData(String data, int type, String label, boolean isPrimary) {
1779:     private void addPhone(int type, String data, String label, boolean isPrimary) {
143:         private String mPhoneticFamily;
144:         private String mPhoneticGiven;
145:         private String mPhoneticMiddle;
167:         public boolean emptyPhoneticStructuredName() {
750:         private final String mPhoneticName; // We won't have this in "TITLE" property.
870:         public String getPhoneticName() {
1555:     private List<PhoneData> mPhoneList;
1865:     private String buildSinglePhoneticNameFromSortAsParam(Map<String, Collection<String>> paramMap) {
2078:     private void handlePhoneticNameFromSound(List<String> elems) {
2633:     public final List<PhoneData> getPhoneList() {
33: import android.provider.ContactsContract.CommonDataKinds.Phone;
337:             builder.withValueBackReference(Phone.RAW_CONTACT_ID, backReferenceIndex);
338:             builder.withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
340:             builder.withValue(Phone.TYPE, mType);
341:             if (mType == Phone.TYPE_CUSTOM) {
342:                 builder.withValue(Phone.LABEL, mLabel);
344:             builder.withValue(Phone.NUMBER, mNumber);
346:                 builder.withValue(Phone.IS_PRIMARY, 1);
388:             return EntryLabel.PHONE;
1786:         if (type == Phone.TYPE_PAGER || VCardConfig.refrainPhoneNumberFormatting(mVCardType)) {
1790:             // Note that some other codes (like the phone number formatter) or modules expect this
2307:                 // Given propValue is in URI format, not in phone number format used until
2315:                     // we may still have non-URI phone number. To keep given data as much as
2340:                     type = Phone.TYPE_CUSTOM;
2355:             // The phone number available via Skype.
2357:             final int type = Phone.TYPE_OTHER;
19: import com.android.vcard.VCardUtils.PhoneNumberUtilsPort;
42: import android.telephony.PhoneNumberUtils;
196:             boolean phoneticNameSpecified = false;
199:                 builder.withValue(StructuredName.PHONETIC_GIVEN_NAME, mPhoneticGiven);
200:                 phoneticNameSpecified = true;
203:                 builder.withValue(StructuredName.PHONETIC_FAMILY_NAME, mPhoneticFamily);
204:                 phoneticNameSpecified = true;
207:                 builder.withValue(StructuredName.PHONETIC_MIDDLE_NAME, mPhoneticMiddle);
208:                 phoneticNameSpecified = true;
211:             // SORT-STRING is used only when phonetic names aren't specified in
213:             if (!phoneticNameSpecified) {
214:                 builder.withValue(StructuredName.PHONETIC_GIVEN_NAME, mSortString);
361:             if (!(obj instanceof PhoneData)) {
364:             PhoneData phoneData = (PhoneData) obj;
365:             return (mType == phoneData.mType
366:                     && TextUtils.equals(mNumber, phoneData.mNumber)
367:                     && TextUtils.equals(mLabel, phoneData.mLabel)
368:                     && (mIsPrimary == phoneData.mIsPrimary));
755:                 final String titleName, final String phoneticName, int type,
761:             mPhoneticName = phoneticName;
806:                 builder.withValue(Organization.PHONETIC_NAME, mPhoneticName);
1781:             mPhoneList = new ArrayList<PhoneData>();
1797:                 // See RFC 3601 and docs for PhoneNumberUtils for more info.
1799:                     builder.append(PhoneNumberUtils.PAUSE);
1802:                     builder.append(PhoneNumberUtils.WAIT);
1804:                 } else if (PhoneNumberUtils.is12Key(ch) || (i == 0 && ch == '+')) {
1810:                 formattedNumber = PhoneNumberUtilsPort.formatNumber(
1816:         PhoneData phoneData = new PhoneData(formattedNumber, type, label, isPrimary);
1817:         mPhoneList.add(phoneData);
1854:             final String titleName, final String phoneticName, int type, final boolean isPrimary) {
1859:                 phoneticName, type, isPrimary));
1894:         final String phoneticName = buildSinglePhoneticNameFromSortAsParam(paramMap);
1929:             addNewOrganization(organizationName, departmentName, null, phoneticName, type,
1948:         addNewOrganization(organizationName, departmentName, null, phoneticName, type, isPrimary);
2001:      * them in appropriate phonetic name variables. This method does not care
2072:      * Note: Some Japanese mobile phones use this field for phonetic name, since
2082:             // This means the other properties like "X-PHONETIC-FIRST-NAME" was already found.
2094:         // phones use this order.
2117:                     // phones' preference.
2177:                 final List<String> phoneticNameList = VCardUtils.constructListFromValue(propValue,
2179:                 handlePhoneticNameFromSound(phoneticNameList);
2304:             String phoneNumber = null;
2312:                     phoneNumber = propValue.substring(4);
2317:                     phoneNumber = propValue;
2320:                 phoneNumber = propValue;
2333:                         phoneNumber);
2352:                 addPhone(type, phoneNumber, label, isPrimary);
2365:             addPhone(type, propValue, null, isPrimary);
2399:         } else if (propertyName.equals(VCardConstants.PROPERTY_X_PHONETIC_FIRST_NAME)) {
2401:         } else if (propertyName.equals(VCardConstants.PROPERTY_X_PHONETIC_MIDDLE_NAME)) {
2403:         } else if (propertyName.equals(VCardConstants.PROPERTY_X_PHONETIC_LAST_NAME)) {
168:             return TextUtils.isEmpty(mPhoneticFamily) && TextUtils.isEmpty(mPhoneticGiven)
169:                     && TextUtils.isEmpty(mPhoneticMiddle);
198:             if (!TextUtils.isEmpty(mPhoneticGiven)) {
202:             if (!TextUtils.isEmpty(mPhoneticFamily)) {
206:             if (!TextUtils.isEmpty(mPhoneticMiddle)) {
226:                     && TextUtils.isEmpty(mPhoneticFamily) && TextUtils.isEmpty(mPhoneticMiddle)
227:                     && TextUtils.isEmpty(mPhoneticGiven) && TextUtils.isEmpty(mSortString));
246:                     && TextUtils.equals(mPhoneticFamily, nameData.mPhoneticFamily)
247:                     && TextUtils.equals(mPhoneticMiddle, nameData.mPhoneticMiddle)
248:                     && TextUtils.equals(mPhoneticGiven, nameData.mPhoneticGiven)
255:                     mFormatted, mPhoneticFamily, mPhoneticMiddle,
256:                     mPhoneticGiven, mSortString};
805:             if (mPhoneticName != null) {
817:                     && TextUtils.isEmpty(mTitle) && TextUtils.isEmpty(mPhoneticName);
871:             return mPhoneticName;
1604:         iterateOneList(mPhoneList, iterator);
1780:         if (mPhoneList == null) {
1809:                 final int formattingType = VCardUtils.getPhoneNumberFormat(mVCardType);
2010:                 && !(TextUtils.isEmpty(mNameData.mPhoneticFamily)
2011:                         && TextUtils.isEmpty(mNameData.mPhoneticMiddle) && TextUtils
2012:                         .isEmpty(mNameData.mPhoneticGiven))) {
2031:                 mNameData.mPhoneticMiddle = sortNames.get(2); //$FALL-THROUGH$
2033:                 mNameData.mPhoneticGiven = sortNames.get(1); //$FALL-THROUGH$
2035:                 mNameData.mPhoneticFamily = sortNames.get(0);
2079:         if (!(TextUtils.isEmpty(mNameData.mPhoneticFamily)
2080:                 && TextUtils.isEmpty(mNameData.mPhoneticMiddle) && TextUtils
2081:                 .isEmpty(mNameData.mPhoneticGiven))) {
2112:                     mNameData.mPhoneticFamily = namesArray[0];
2113:                     mNameData.mPhoneticMiddle = namesArray[1];
2114:                     mNameData.mPhoneticGiven = namesArray[2];
2118:                     mNameData.mPhoneticFamily = namesArray[0];
2119:                     mNameData.mPhoneticGiven = namesArray[1];
2121:                     mNameData.mPhoneticGiven = elems.get(0);
2130:             mNameData.mPhoneticMiddle = elems.get(2);
2132:             mNameData.mPhoneticGiven = elems.get(1);
2134:             mNameData.mPhoneticFamily = elems.get(0);
2332:                 final Object typeObject = VCardUtils.getPhoneTypeFromStrings(typeCollection,
2400:             mNameData.mPhoneticGiven = propValue;
2402:             mNameData.mPhoneticMiddle = propValue;
2404:             mNameData.mPhoneticFamily = propValue;
2500:         } else if (!mNameData.emptyPhoneticStructuredName()) {
2502:                     mNameData.mPhoneticFamily, mNameData.mPhoneticMiddle, mNameData.mPhoneticGiven);
2505:         } else if (mPhoneList != null && mPhoneList.size() > 0) {
2506:             displayName = mPhoneList.get(0).mNumber;
2634:         return mPhoneList;
chromium.googlesource.com/android_tools:sdk/sources/android-25/android/provider/ContactsContract.java: [ master, ]
1117:         public static final int PHONE = 20;
5941:         public static final class Phone implements DataColumnsWithJoins, CommonColumns,
5946:             private Phone() {}
9101:             public static final String PHONE = "phone";
9109:             public static final String PHONE_TYPE = "phone_type";
9115:             public static final String PHONE_ISPRIMARY = "phone_isprimary";
9121:             public static final String SECONDARY_PHONE = "secondary_phone";
9135:             public static final String TERTIARY_PHONE = "tertiary_phone";
1087:     public interface PhoneticNameStyle {
1185:         public static final String PHONETIC_NAME_STYLE = "phonetic_name_style";
1198:         public static final String PHONETIC_NAME = "phonetic_name";
5009:     protected interface PhoneLookupColumns {
5168:     public static final class PhoneLookup implements BaseColumns, PhoneLookupColumns,
5173:         private PhoneLookup() {}
5763:             public static final String PHONETIC_GIVEN_NAME = DATA7;
5769:             public static final String PHONETIC_MIDDLE_NAME = DATA8;
5775:             public static final String PHONETIC_FAMILY_NAME = DATA9;
5787:             public static final String PHONETIC_NAME_STYLE = DATA11;
6834:             public static final String PHONETIC_NAME = DATA8;
6846:             public static final String PHONETIC_NAME_STYLE = DATA10;
9077:             public static final String PHONETIC_NAME = "phonetic_name";
183:     public static final String STREQUENT_PHONE_ONLY = "strequent_phone_only";
990:         public static final String HAS_PHONE_NUMBER = "has_phone_number";
6008:             public static final String SEARCH_PHONE_NUMBER_KEY = "search_phone_number";
8995:         public static final String EXTRA_PHONE_URIS =
9129:             public static final String SECONDARY_PHONE_TYPE = "secondary_phone_type";
9143:             public static final String TERTIARY_PHONE_TYPE = "tertiary_phone_type";
1121:         public static final int STRUCTURED_PHONETIC_NAME = 37;
7637:         public static final String SUMMARY_WITH_PHONES = "summ_phones";
8023:         public static final String UNGROUPED_WITH_PHONES = "summ_phones";
8948:         public static final String ACTION_GET_MULTIPLE_PHONES =
68:  * as a phone number or email addresses.  The set of data kinds that can be
149:      * {@link CommonDataKinds.Phone#CONTENT_URI},
180:      * return only phone-related results. For example, frequently contacted person list should
181:      * include persons contacted via phone (not email, sms, etc.)
203:      * A boolean parameter for {@link CommonDataKinds.Phone#CONTENT_URI Phone.CONTENT_URI},
281:      * in email and phone lookup functionalities, it should also implement
284:      * {@link CommonDataKinds.Phone#CONTENT_FILTER_URI CommonDataKinds.Phone.CONTENT_FILTER_URI}.
581:          * allow creation of shortcuts for data items like email, phone or postal address,
986:          * An indicator of whether this contact has at least one phone number. "1" if there is
987:          * at least one phone number, "0" otherwise.
1110:      * of increasing priority: {@link #EMAIL}, {@link #PHONE},
1295:      * <li>If you need to look up a contact by the phone number, use
1376:      * <td>{@link #HAS_PHONE_NUMBER}</td>
1378:      * <td>An indicator of whether this contact has at least one phone number.
1379:      * "1" if there is at least one phone number, "0" otherwise.</td>
2409:      * Changes to the structured name, organization, phone number, email address,
2493:      * finalizes phone-side deletion by calling {@code resolver.delete(...)}
2496:      * changes to the phone, but not the reverse.  If one of those raw contacts
2497:      * is marked for deletion, it will remain on the phone.  However it will be
2710:      * SOURCE_ID field on the phone.
2731:      * the sync adapter updates the contact on the phone (without the
3234:          * camera that can be used for video chat (e.g. a front-facing camera on a phone).
4244:      * information (such as a phone number) and its
4255:      * {@link CommonDataKinds.Phone Phone.CONTENT_ITEM_TYPE}, then the column
4257:      * phone number, but if the data kind is
4264:      * {@link CommonDataKinds.Phone}, {@link CommonDataKinds.Email} etc. As a
4266:      * For example, {@link CommonDataKinds.Phone Phone.NUMBER} is the same as
4299:      * single transaction, which ensures that the phone-side and server-side
4337:      * values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
4338:      * values.put(Phone.NUMBER, "1-800-GOOG-411");
4339:      * values.put(Phone.TYPE, Phone.TYPE_CUSTOM);
4340:      * values.put(Phone.LABEL, "free directory assistance");
4351:      *          .withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE)
4352:      *          .withValue(Phone.NUMBER, "1-800-GOOG-411")
4353:      *          .withValue(Phone.TYPE, Phone.TYPE_CUSTOM)
4354:      *          .withValue(Phone.LABEL, "free directory assistance")
4400:      *          new String[] {Data._ID, Phone.NUMBER, Phone.TYPE, Phone.LABEL},
4402:      *                  + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'",
4412:      *          new String[] {Data._ID, Phone.NUMBER, Phone.TYPE, Phone.LABEL},
4414:      *                  + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'",
4454:      * <li>{@link CommonDataKinds.Phone Phone.CONTENT_ITEM_TYPE}</li>
4493:      * the default phone number to use for the contact).</td>
4677:      * <td>{@link #HAS_PHONE_NUMBER}</td>
5022:          * The phone number as the user entered it.
5028:          * The type of phone number, for example Home or Work.
5034:          * The user defined label for the phone number.
5040:          * The phone number's E164 representation.
5047:      * A table that represents the result of looking up a phone number, for
5066:      * <td>Phone number.</td>
5072:      * <td>Phone number type. See {@link CommonDataKinds.Phone}.</td>
5078:      * <td>Custom label for the phone number. See {@link CommonDataKinds.Phone}.</td>
5132:      * <td>{@link #HAS_PHONE_NUMBER}</td>
5176:          * The content:// style URI for this table. Append the phone number you want to lookup
5184:                 "phone_lookup");
5233:                 "phone_lookup_enterprise");
5236:          * The MIME type of {@link #CONTENT_FILTER_URI} providing a directory of phone lookup rows.
5240:         public static final String CONTENT_TYPE = "vnd.android.cursor.dir/phone_lookup";
5949:             public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/phone_v2";
5955:             public static final String CONTENT_TYPE = "vnd.android.cursor.dir/phone_v2";
5980:              * The content:// style URL for phone lookup using a filter. The filter returns
5982:              * to display names as well as phone numbers. The filter argument should be passed
6005:              * If "1" or "true", phone numbers are searched.  If "0" or "false", phone numbers
6032:              * The phone number as the user entered it.
6038:              * The phone number's E164 representation. This value can be omitted in which
7466:          * that users can use for calling purposes. {@link Phone} and {@link SipAddress} are the
7471:          * each column. For example the meaning for {@link Phone}'s type is different than
7478:              * Similar to {@link Phone#CONTENT_URI}, but returns callable data instead of only
7479:              * phone numbers.
7484:              * Similar to {@link Phone#CONTENT_FILTER_URI}, but allows users to filter callable
7491:              * Similar to {@link Phone#ENTERPRISE_CONTENT_FILTER_URI}, but allows users to filter
7501:          * to start communicating with a person ({@link Phone} and {@link Email}). Note that this
7505:          * can use to initiate communications with another contact. {@link Phone} and {@link Email}
7631:          * {@link CommonDataKinds.GroupMembership} in this group, and also have phone numbers.
7763:      * phone numbers. Read-only value that is only present when querying
8019:          * no {@link CommonDataKinds.GroupMembership} entries, and also have phone numbers.
8083:      * no {@link CommonDataKinds.GroupMembership} entries, and also have phone
8170:      * {@link ContactsContract.CommonDataKinds.Phone#CONTENT_FILTER_URI}, and users can benefit
8185:      * interactions using the same contact data field (for example a phone number can be used to
8186:      * make phone calls or send SMS).
8241:          * Type of usage for voice interaction, which includes phone call, voice chat, and
8371:          * For example, passing the value {@link CommonDataKinds.Phone#CONTENT_ITEM_TYPE} can
8372:          * cause phone numbers to be displayed more prominently in QuickContacts.
8581:          *             {@link CommonDataKinds.Phone#CONTENT_ITEM_TYPE} can cause phone numbers to be
8621:          *             {@link CommonDataKinds.Phone#CONTENT_ITEM_TYPE} can cause phone numbers to be
8813:          * phone number or human readable username/user_id like "a_super_cool_user_name". This label