Phone.java revision e64a413b850aae224e2f56e7dfc6e0bcd667643e
1/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *      http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.internal.telephony;
18
19import android.content.Context;
20import android.net.LinkProperties;
21import android.net.NetworkCapabilities;
22import android.os.Handler;
23import android.os.Message;
24import android.telephony.CellInfo;
25import android.telephony.CellLocation;
26import android.telephony.PhoneStateListener;
27import android.telephony.ServiceState;
28import android.telephony.SignalStrength;
29
30import com.android.internal.telephony.imsphone.ImsPhone;
31import com.android.internal.telephony.test.SimulatedRadioControl;
32import com.android.internal.telephony.uicc.IsimRecords;
33import com.android.internal.telephony.uicc.UiccCard;
34import com.android.internal.telephony.uicc.UsimServiceTable;
35
36import com.android.internal.telephony.PhoneConstants.*; // ????
37
38import java.util.List;
39
40/**
41 * Internal interface used to control the phone; SDK developers cannot
42 * obtain this interface.
43 *
44 * {@hide}
45 *
46 */
47public interface Phone {
48
49    /** used to enable additional debug messages */
50    static final boolean DEBUG_PHONE = true;
51
52    public enum DataActivityState {
53        /**
54         * The state of a data activity.
55         * <ul>
56         * <li>NONE = No traffic</li>
57         * <li>DATAIN = Receiving IP ppp traffic</li>
58         * <li>DATAOUT = Sending IP ppp traffic</li>
59         * <li>DATAINANDOUT = Both receiving and sending IP ppp traffic</li>
60         * <li>DORMANT = The data connection is still active,
61                                     but physical link is down</li>
62         * </ul>
63         */
64        NONE, DATAIN, DATAOUT, DATAINANDOUT, DORMANT;
65    }
66
67    enum SuppService {
68      UNKNOWN, SWITCH, SEPARATE, TRANSFER, CONFERENCE, REJECT, HANGUP;
69    }
70
71    // "Features" accessible through the connectivity manager
72    static final String FEATURE_ENABLE_MMS = "enableMMS";
73    static final String FEATURE_ENABLE_SUPL = "enableSUPL";
74    static final String FEATURE_ENABLE_DUN = "enableDUN";
75    static final String FEATURE_ENABLE_HIPRI = "enableHIPRI";
76    static final String FEATURE_ENABLE_DUN_ALWAYS = "enableDUNAlways";
77    static final String FEATURE_ENABLE_FOTA = "enableFOTA";
78    static final String FEATURE_ENABLE_IMS = "enableIMS";
79    static final String FEATURE_ENABLE_CBS = "enableCBS";
80    static final String FEATURE_ENABLE_EMERGENCY = "enableEmergency";
81
82    /**
83     * Optional reasons for disconnect and connect
84     */
85    static final String REASON_ROAMING_ON = "roamingOn";
86    static final String REASON_ROAMING_OFF = "roamingOff";
87    static final String REASON_DATA_DISABLED = "dataDisabled";
88    static final String REASON_DATA_ENABLED = "dataEnabled";
89    static final String REASON_DATA_ATTACHED = "dataAttached";
90    static final String REASON_DATA_DETACHED = "dataDetached";
91    static final String REASON_CDMA_DATA_ATTACHED = "cdmaDataAttached";
92    static final String REASON_CDMA_DATA_DETACHED = "cdmaDataDetached";
93    static final String REASON_APN_CHANGED = "apnChanged";
94    static final String REASON_APN_SWITCHED = "apnSwitched";
95    static final String REASON_APN_FAILED = "apnFailed";
96    static final String REASON_RESTORE_DEFAULT_APN = "restoreDefaultApn";
97    static final String REASON_RADIO_TURNED_OFF = "radioTurnedOff";
98    static final String REASON_PDP_RESET = "pdpReset";
99    static final String REASON_VOICE_CALL_ENDED = "2GVoiceCallEnded";
100    static final String REASON_VOICE_CALL_STARTED = "2GVoiceCallStarted";
101    static final String REASON_PS_RESTRICT_ENABLED = "psRestrictEnabled";
102    static final String REASON_PS_RESTRICT_DISABLED = "psRestrictDisabled";
103    static final String REASON_SIM_LOADED = "simLoaded";
104    static final String REASON_NW_TYPE_CHANGED = "nwTypeChanged";
105    static final String REASON_DATA_DEPENDENCY_MET = "dependencyMet";
106    static final String REASON_DATA_DEPENDENCY_UNMET = "dependencyUnmet";
107    static final String REASON_LOST_DATA_CONNECTION = "lostDataConnection";
108    static final String REASON_CONNECTED = "connected";
109    static final String REASON_SINGLE_PDN_ARBITRATION = "SinglePdnArbitration";
110    static final String REASON_DATA_SPECIFIC_DISABLED = "specificDisabled";
111
112    // Used for band mode selection methods
113    static final int BM_UNSPECIFIED = 0; // selected by baseband automatically
114    static final int BM_EURO_BAND   = 1; // GSM-900 / DCS-1800 / WCDMA-IMT-2000
115    static final int BM_US_BAND     = 2; // GSM-850 / PCS-1900 / WCDMA-850 / WCDMA-PCS-1900
116    static final int BM_JPN_BAND    = 3; // WCDMA-800 / WCDMA-IMT-2000
117    static final int BM_AUS_BAND    = 4; // GSM-900 / DCS-1800 / WCDMA-850 / WCDMA-IMT-2000
118    static final int BM_AUS2_BAND   = 5; // GSM-900 / DCS-1800 / WCDMA-850
119    static final int BM_BOUNDARY    = 6; // upper band boundary
120
121    // Used for preferred network type
122    // Note NT_* substitute RILConstants.NETWORK_MODE_* above the Phone
123    int NT_MODE_WCDMA_PREF   = RILConstants.NETWORK_MODE_WCDMA_PREF;
124    int NT_MODE_GSM_ONLY     = RILConstants.NETWORK_MODE_GSM_ONLY;
125    int NT_MODE_WCDMA_ONLY   = RILConstants.NETWORK_MODE_WCDMA_ONLY;
126    int NT_MODE_GSM_UMTS     = RILConstants.NETWORK_MODE_GSM_UMTS;
127
128    int NT_MODE_CDMA         = RILConstants.NETWORK_MODE_CDMA;
129
130    int NT_MODE_CDMA_NO_EVDO = RILConstants.NETWORK_MODE_CDMA_NO_EVDO;
131    int NT_MODE_EVDO_NO_CDMA = RILConstants.NETWORK_MODE_EVDO_NO_CDMA;
132    int NT_MODE_GLOBAL       = RILConstants.NETWORK_MODE_GLOBAL;
133
134    int NT_MODE_LTE_CDMA_AND_EVDO        = RILConstants.NETWORK_MODE_LTE_CDMA_EVDO;
135    int NT_MODE_LTE_GSM_WCDMA            = RILConstants.NETWORK_MODE_LTE_GSM_WCDMA;
136    int NT_MODE_LTE_CDMA_EVDO_GSM_WCDMA  = RILConstants.NETWORK_MODE_LTE_CDMA_EVDO_GSM_WCDMA;
137    int NT_MODE_LTE_ONLY                 = RILConstants.NETWORK_MODE_LTE_ONLY;
138    int NT_MODE_LTE_WCDMA                = RILConstants.NETWORK_MODE_LTE_WCDMA;
139    int PREFERRED_NT_MODE                = RILConstants.PREFERRED_NETWORK_MODE;
140
141    // Used for CDMA roaming mode
142    static final int CDMA_RM_HOME        = 0;  // Home Networks only, as defined in PRL
143    static final int CDMA_RM_AFFILIATED  = 1;  // Roaming an Affiliated networks, as defined in PRL
144    static final int CDMA_RM_ANY         = 2;  // Roaming on Any Network, as defined in PRL
145
146    // Used for CDMA subscription mode
147    static final int CDMA_SUBSCRIPTION_UNKNOWN  =-1; // Unknown
148    static final int CDMA_SUBSCRIPTION_RUIM_SIM = 0; // RUIM/SIM (default)
149    static final int CDMA_SUBSCRIPTION_NV       = 1; // NV -> non-volatile memory
150
151    static final int PREFERRED_CDMA_SUBSCRIPTION = CDMA_SUBSCRIPTION_NV;
152
153    static final int TTY_MODE_OFF = 0;
154    static final int TTY_MODE_FULL = 1;
155    static final int TTY_MODE_HCO = 2;
156    static final int TTY_MODE_VCO = 3;
157
158     /**
159     * CDMA OTA PROVISION STATUS, the same as RIL_CDMA_OTA_Status in ril.h
160     */
161
162    public static final int CDMA_OTA_PROVISION_STATUS_SPL_UNLOCKED = 0;
163    public static final int CDMA_OTA_PROVISION_STATUS_SPC_RETRIES_EXCEEDED = 1;
164    public static final int CDMA_OTA_PROVISION_STATUS_A_KEY_EXCHANGED = 2;
165    public static final int CDMA_OTA_PROVISION_STATUS_SSD_UPDATED = 3;
166    public static final int CDMA_OTA_PROVISION_STATUS_NAM_DOWNLOADED = 4;
167    public static final int CDMA_OTA_PROVISION_STATUS_MDN_DOWNLOADED = 5;
168    public static final int CDMA_OTA_PROVISION_STATUS_IMSI_DOWNLOADED = 6;
169    public static final int CDMA_OTA_PROVISION_STATUS_PRL_DOWNLOADED = 7;
170    public static final int CDMA_OTA_PROVISION_STATUS_COMMITTED = 8;
171    public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_STARTED = 9;
172    public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_STOPPED = 10;
173    public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_ABORTED = 11;
174
175
176    /**
177     * Get the current ServiceState. Use
178     * <code>registerForServiceStateChanged</code> to be informed of
179     * updates.
180     */
181    ServiceState getServiceState();
182
183    /**
184     * Get the current CellLocation.
185     */
186    CellLocation getCellLocation();
187
188    /**
189     * @return all available cell information or null if none.
190     */
191    public List<CellInfo> getAllCellInfo();
192
193    /**
194     * Sets the minimum time in milli-seconds between {@link PhoneStateListener#onCellInfoChanged
195     * PhoneStateListener.onCellInfoChanged} will be invoked.
196     *
197     * The default, 0, means invoke onCellInfoChanged when any of the reported
198     * information changes. Setting the value to INT_MAX(0x7fffffff) means never issue
199     * A onCellInfoChanged.
200     *
201     * @param rateInMillis the rate
202     */
203    public void setCellInfoListRate(int rateInMillis);
204
205    /**
206     * Get the current for the default apn DataState. No change notification
207     * exists at this interface -- use
208     * {@link android.telephony.PhoneStateListener} instead.
209     */
210    DataState getDataConnectionState();
211
212    /**
213     * Get the current DataState. No change notification exists at this
214     * interface -- use
215     * {@link android.telephony.PhoneStateListener} instead.
216     * @param apnType specify for which apn to get connection state info.
217     */
218    DataState getDataConnectionState(String apnType);
219
220    /**
221     * Get the current DataActivityState. No change notification exists at this
222     * interface -- use
223     * {@link android.telephony.TelephonyManager} instead.
224     */
225    DataActivityState getDataActivityState();
226
227    /**
228     * Gets the context for the phone, as set at initialization time.
229     */
230    Context getContext();
231
232    /**
233     * Disables the DNS check (i.e., allows "0.0.0.0").
234     * Useful for lab testing environment.
235     * @param b true disables the check, false enables.
236     */
237    void disableDnsCheck(boolean b);
238
239    /**
240     * Returns true if the DNS check is currently disabled.
241     */
242    boolean isDnsCheckDisabled();
243
244    /**
245     * Get current coarse-grained voice call state.
246     * Use {@link #registerForPreciseCallStateChanged(Handler, int, Object)
247     * registerForPreciseCallStateChanged()} for change notification. <p>
248     * If the phone has an active call and call waiting occurs,
249     * then the phone state is RINGING not OFFHOOK
250     * <strong>Note:</strong>
251     * This registration point provides notification of finer-grained
252     * changes.<p>
253     *
254     */
255    State getState();
256
257    /**
258     * Returns a string identifier for this phone interface for parties
259     *  outside the phone app process.
260     *  @return The string name.
261     */
262    String getPhoneName();
263
264    /**
265     * Return a numerical identifier for the phone radio interface.
266     * @return PHONE_TYPE_XXX as defined above.
267     */
268    int getPhoneType();
269
270    /**
271     * Returns an array of string identifiers for the APN types serviced by the
272     * currently active.
273     *  @return The string array will always return at least one entry, Phone.APN_TYPE_DEFAULT.
274     * TODO: Revisit if we always should return at least one entry.
275     */
276    String[] getActiveApnTypes();
277
278    /**
279     * Returns string for the active APN host.
280     *  @return type as a string or null if none.
281     */
282    String getActiveApnHost(String apnType);
283
284    /**
285     * Return the LinkProperties for the named apn or null if not available
286     */
287    LinkProperties getLinkProperties(String apnType);
288
289    /**
290     * Return the NetworkCapabilities
291     */
292    NetworkCapabilities getNetworkCapabilities(String apnType);
293
294    /**
295     * Get current signal strength. No change notification available on this
296     * interface. Use <code>PhoneStateNotifier</code> or an equivalent.
297     * An ASU is 0-31 or -1 if unknown (for GSM, dBm = -113 - 2 * asu).
298     * The following special values are defined:</p>
299     * <ul><li>0 means "-113 dBm or less".</li>
300     * <li>31 means "-51 dBm or greater".</li></ul>
301     *
302     * @return Current signal strength as SignalStrength
303     */
304    SignalStrength getSignalStrength();
305
306    /**
307     * Notifies when a previously untracked non-ringing/waiting connection has appeared.
308     * This is likely due to some other entity (eg, SIM card application) initiating a call.
309     */
310    void registerForUnknownConnection(Handler h, int what, Object obj);
311
312    /**
313     * Unregisters for unknown connection notifications.
314     */
315    void unregisterForUnknownConnection(Handler h);
316
317    /**
318     * Notifies when a Handover happens due to SRVCC or Silent Redial
319     */
320    void registerForHandoverStateChanged(Handler h, int what, Object obj);
321
322    /**
323     * Unregisters for handover state notifications
324     */
325    void unregisterForHandoverStateChanged(Handler h);
326
327    /**
328     * Register for getting notifications for change in the Call State {@link Call.State}
329     * This is called PreciseCallState because the call state is more precise than the
330     * {@link PhoneConstants.State} which can be obtained using the {@link PhoneStateListener}
331     *
332     * Resulting events will have an AsyncResult in <code>Message.obj</code>.
333     * AsyncResult.userData will be set to the obj argument here.
334     * The <em>h</em> parameter is held only by a weak reference.
335     */
336    void registerForPreciseCallStateChanged(Handler h, int what, Object obj);
337
338    /**
339     * Unregisters for voice call state change notifications.
340     * Extraneous calls are tolerated silently.
341     */
342    void unregisterForPreciseCallStateChanged(Handler h);
343
344    /**
345     * Notifies when a new ringing or waiting connection has appeared.<p>
346     *
347     *  Messages received from this:
348     *  Message.obj will be an AsyncResult
349     *  AsyncResult.userObj = obj
350     *  AsyncResult.result = a Connection. <p>
351     *  Please check Connection.isRinging() to make sure the Connection
352     *  has not dropped since this message was posted.
353     *  If Connection.isRinging() is true, then
354     *   Connection.getCall() == Phone.getRingingCall()
355     */
356    void registerForNewRingingConnection(Handler h, int what, Object obj);
357
358    /**
359     * Unregisters for new ringing connection notification.
360     * Extraneous calls are tolerated silently
361     */
362
363    void unregisterForNewRingingConnection(Handler h);
364
365    /**
366     * Notifies when an incoming call rings.<p>
367     *
368     *  Messages received from this:
369     *  Message.obj will be an AsyncResult
370     *  AsyncResult.userObj = obj
371     *  AsyncResult.result = a Connection. <p>
372     */
373    void registerForIncomingRing(Handler h, int what, Object obj);
374
375    /**
376     * Unregisters for ring notification.
377     * Extraneous calls are tolerated silently
378     */
379
380    void unregisterForIncomingRing(Handler h);
381
382    /**
383     * Notifies when out-band ringback tone is needed.<p>
384     *
385     *  Messages received from this:
386     *  Message.obj will be an AsyncResult
387     *  AsyncResult.userObj = obj
388     *  AsyncResult.result = boolean, true to start play ringback tone
389     *                       and false to stop. <p>
390     */
391    void registerForRingbackTone(Handler h, int what, Object obj);
392
393    /**
394     * Unregisters for ringback tone notification.
395     */
396
397    void unregisterForRingbackTone(Handler h);
398
399    /**
400     * Notifies when out-band on-hold tone is needed.<p>
401     *
402     *  Messages received from this:
403     *  Message.obj will be an AsyncResult
404     *  AsyncResult.userObj = obj
405     *  AsyncResult.result = boolean, true to start play on-hold tone
406     *                       and false to stop. <p>
407     */
408    void registerForOnHoldTone(Handler h, int what, Object obj);
409
410    /**
411     * Unregisters for on-hold tone notification.
412     */
413
414    void unregisterForOnHoldTone(Handler h);
415
416    /**
417     * Registers the handler to reset the uplink mute state to get
418     * uplink audio.
419     */
420    void registerForResendIncallMute(Handler h, int what, Object obj);
421
422    /**
423     * Unregisters for resend incall mute notifications.
424     */
425    void unregisterForResendIncallMute(Handler h);
426
427    /**
428     * Notifies when a voice connection has disconnected, either due to local
429     * or remote hangup or error.
430     *
431     *  Messages received from this will have the following members:<p>
432     *  <ul><li>Message.obj will be an AsyncResult</li>
433     *  <li>AsyncResult.userObj = obj</li>
434     *  <li>AsyncResult.result = a Connection object that is
435     *  no longer connected.</li></ul>
436     */
437    void registerForDisconnect(Handler h, int what, Object obj);
438
439    /**
440     * Unregisters for voice disconnection notification.
441     * Extraneous calls are tolerated silently
442     */
443    void unregisterForDisconnect(Handler h);
444
445
446    /**
447     * Register for notifications of initiation of a new MMI code request.
448     * MMI codes for GSM are discussed in 3GPP TS 22.030.<p>
449     *
450     * Example: If Phone.dial is called with "*#31#", then the app will
451     * be notified here.<p>
452     *
453     * The returned <code>Message.obj</code> will contain an AsyncResult.
454     *
455     * <code>obj.result</code> will be an "MmiCode" object.
456     */
457    void registerForMmiInitiate(Handler h, int what, Object obj);
458
459    /**
460     * Unregisters for new MMI initiate notification.
461     * Extraneous calls are tolerated silently
462     */
463    void unregisterForMmiInitiate(Handler h);
464
465    /**
466     * Register for notifications that an MMI request has completed
467     * its network activity and is in its final state. This may mean a state
468     * of COMPLETE, FAILED, or CANCELLED.
469     *
470     * <code>Message.obj</code> will contain an AsyncResult.
471     * <code>obj.result</code> will be an "MmiCode" object
472     */
473    void registerForMmiComplete(Handler h, int what, Object obj);
474
475    /**
476     * Unregisters for MMI complete notification.
477     * Extraneous calls are tolerated silently
478     */
479    void unregisterForMmiComplete(Handler h);
480
481    /**
482     * Registration point for Ecm timer reset
483     * @param h handler to notify
484     * @param what user-defined message code
485     * @param obj placed in Message.obj
486     */
487    public void registerForEcmTimerReset(Handler h, int what, Object obj);
488
489    /**
490     * Unregister for notification for Ecm timer reset
491     * @param h Handler to be removed from the registrant list.
492     */
493    public void unregisterForEcmTimerReset(Handler h);
494
495    /**
496     * Returns a list of MMI codes that are pending. (They have initiated
497     * but have not yet completed).
498     * Presently there is only ever one.
499     * Use <code>registerForMmiInitiate</code>
500     * and <code>registerForMmiComplete</code> for change notification.
501     */
502    public List<? extends MmiCode> getPendingMmiCodes();
503
504    /**
505     * Sends user response to a USSD REQUEST message.  An MmiCode instance
506     * representing this response is sent to handlers registered with
507     * registerForMmiInitiate.
508     *
509     * @param ussdMessge    Message to send in the response.
510     */
511    public void sendUssdResponse(String ussdMessge);
512
513    /**
514     * Register for ServiceState changed.
515     * Message.obj will contain an AsyncResult.
516     * AsyncResult.result will be a ServiceState instance
517     */
518    void registerForServiceStateChanged(Handler h, int what, Object obj);
519
520    /**
521     * Unregisters for ServiceStateChange notification.
522     * Extraneous calls are tolerated silently
523     */
524    void unregisterForServiceStateChanged(Handler h);
525
526    /**
527     * Register for Supplementary Service notifications from the network.
528     * Message.obj will contain an AsyncResult.
529     * AsyncResult.result will be a SuppServiceNotification instance.
530     *
531     * @param h Handler that receives the notification message.
532     * @param what User-defined message code.
533     * @param obj User object.
534     */
535    void registerForSuppServiceNotification(Handler h, int what, Object obj);
536
537    /**
538     * Unregisters for Supplementary Service notifications.
539     * Extraneous calls are tolerated silently
540     *
541     * @param h Handler to be removed from the registrant list.
542     */
543    void unregisterForSuppServiceNotification(Handler h);
544
545    /**
546     * Register for notifications when a supplementary service attempt fails.
547     * Message.obj will contain an AsyncResult.
548     *
549     * @param h Handler that receives the notification message.
550     * @param what User-defined message code.
551     * @param obj User object.
552     */
553    void registerForSuppServiceFailed(Handler h, int what, Object obj);
554
555    /**
556     * Unregister for notifications when a supplementary service attempt fails.
557     * Extraneous calls are tolerated silently
558     *
559     * @param h Handler to be removed from the registrant list.
560     */
561    void unregisterForSuppServiceFailed(Handler h);
562
563    /**
564     * Register for notifications when a sInCall VoicePrivacy is enabled
565     *
566     * @param h Handler that receives the notification message.
567     * @param what User-defined message code.
568     * @param obj User object.
569     */
570    void registerForInCallVoicePrivacyOn(Handler h, int what, Object obj);
571
572    /**
573     * Unegister for notifications when a sInCall VoicePrivacy is enabled
574     *
575     * @param h Handler to be removed from the registrant list.
576     */
577    void unregisterForInCallVoicePrivacyOn(Handler h);
578
579    /**
580     * Register for notifications when a sInCall VoicePrivacy is disabled
581     *
582     * @param h Handler that receives the notification message.
583     * @param what User-defined message code.
584     * @param obj User object.
585     */
586    void registerForInCallVoicePrivacyOff(Handler h, int what, Object obj);
587
588    /**
589     * Unregister for notifications when a sInCall VoicePrivacy is disabled
590     *
591     * @param h Handler to be removed from the registrant list.
592     */
593    void unregisterForInCallVoicePrivacyOff(Handler h);
594
595    /**
596     * Register for notifications when CDMA OTA Provision status change
597     *
598     * @param h Handler that receives the notification message.
599     * @param what User-defined message code.
600     * @param obj User object.
601     */
602    void registerForCdmaOtaStatusChange(Handler h, int what, Object obj);
603
604    /**
605     * Unregister for notifications when CDMA OTA Provision status change
606     * @param h Handler to be removed from the registrant list.
607     */
608    void unregisterForCdmaOtaStatusChange(Handler h);
609
610    /**
611     * Registration point for subscription info ready
612     * @param h handler to notify
613     * @param what what code of message when delivered
614     * @param obj placed in Message.obj
615     */
616    public void registerForSubscriptionInfoReady(Handler h, int what, Object obj);
617
618    /**
619     * Unregister for notifications for subscription info
620     * @param h Handler to be removed from the registrant list.
621     */
622    public void unregisterForSubscriptionInfoReady(Handler h);
623
624    /**
625     * Registration point for Sim records loaded
626     * @param h handler to notify
627     * @param what what code of message when delivered
628     * @param obj placed in Message.obj
629     */
630    public void registerForSimRecordsLoaded(Handler h, int what, Object obj);
631
632    /**
633     * Unregister for notifications for Sim records loaded
634     * @param h Handler to be removed from the registrant list.
635     */
636    public void unregisterForSimRecordsLoaded(Handler h);
637
638    /**
639     * Returns SIM record load state. Use
640     * <code>getSimCard().registerForReady()</code> for change notification.
641     *
642     * @return true if records from the SIM have been loaded and are
643     * available (if applicable). If not applicable to the underlying
644     * technology, returns true as well.
645     */
646    boolean getIccRecordsLoaded();
647
648    /**
649     * Returns the ICC card interface for this phone, or null
650     * if not applicable to underlying technology.
651     */
652    IccCard getIccCard();
653
654    /**
655     * Answers a ringing or waiting call. Active calls, if any, go on hold.
656     * Answering occurs asynchronously, and final notification occurs via
657     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
658     * java.lang.Object) registerForPreciseCallStateChanged()}.
659     *
660     * @param videoState The video state in which to answer the call.
661     * @exception CallStateException when no call is ringing or waiting
662     */
663    void acceptCall(int videoState) throws CallStateException;
664
665    /**
666     * Reject (ignore) a ringing call. In GSM, this means UDUB
667     * (User Determined User Busy). Reject occurs asynchronously,
668     * and final notification occurs via
669     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
670     * java.lang.Object) registerForPreciseCallStateChanged()}.
671     *
672     * @exception CallStateException when no call is ringing or waiting
673     */
674    void rejectCall() throws CallStateException;
675
676    /**
677     * Places any active calls on hold, and makes any held calls
678     *  active. Switch occurs asynchronously and may fail.
679     * Final notification occurs via
680     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
681     * java.lang.Object) registerForPreciseCallStateChanged()}.
682     *
683     * @exception CallStateException if a call is ringing, waiting, or
684     * dialing/alerting. In these cases, this operation may not be performed.
685     */
686    void switchHoldingAndActive() throws CallStateException;
687
688    /**
689     * Whether or not the phone can conference in the current phone
690     * state--that is, one call holding and one call active.
691     * @return true if the phone can conference; false otherwise.
692     */
693    boolean canConference();
694
695    /**
696     * Conferences holding and active. Conference occurs asynchronously
697     * and may fail. Final notification occurs via
698     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
699     * java.lang.Object) registerForPreciseCallStateChanged()}.
700     *
701     * @exception CallStateException if canConference() would return false.
702     * In these cases, this operation may not be performed.
703     */
704    void conference() throws CallStateException;
705
706    /**
707     * Enable or disable enhanced Voice Privacy (VP). If enhanced VP is
708     * disabled, normal VP is enabled.
709     *
710     * @param enable whether true or false to enable or disable.
711     * @param onComplete a callback message when the action is completed.
712     */
713    void enableEnhancedVoicePrivacy(boolean enable, Message onComplete);
714
715    /**
716     * Get the currently set Voice Privacy (VP) mode.
717     *
718     * @param onComplete a callback message when the action is completed.
719     */
720    void getEnhancedVoicePrivacy(Message onComplete);
721
722    /**
723     * Whether or not the phone can do explicit call transfer in the current
724     * phone state--that is, one call holding and one call active.
725     * @return true if the phone can do explicit call transfer; false otherwise.
726     */
727    boolean canTransfer();
728
729    /**
730     * Connects the two calls and disconnects the subscriber from both calls
731     * Explicit Call Transfer occurs asynchronously
732     * and may fail. Final notification occurs via
733     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
734     * java.lang.Object) registerForPreciseCallStateChanged()}.
735     *
736     * @exception CallStateException if canTransfer() would return false.
737     * In these cases, this operation may not be performed.
738     */
739    void explicitCallTransfer() throws CallStateException;
740
741    /**
742     * Clears all DISCONNECTED connections from Call connection lists.
743     * Calls that were in the DISCONNECTED state become idle. This occurs
744     * synchronously.
745     */
746    void clearDisconnected();
747
748
749    /**
750     * Gets the foreground call object, which represents all connections that
751     * are dialing or active (all connections
752     * that have their audio path connected).<p>
753     *
754     * The foreground call is a singleton object. It is constant for the life
755     * of this phone. It is never null.<p>
756     *
757     * The foreground call will only ever be in one of these states:
758     * IDLE, ACTIVE, DIALING, ALERTING, or DISCONNECTED.
759     *
760     * State change notification is available via
761     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
762     * java.lang.Object) registerForPreciseCallStateChanged()}.
763     */
764    Call getForegroundCall();
765
766    /**
767     * Gets the background call object, which represents all connections that
768     * are holding (all connections that have been accepted or connected, but
769     * do not have their audio path connected). <p>
770     *
771     * The background call is a singleton object. It is constant for the life
772     * of this phone object . It is never null.<p>
773     *
774     * The background call will only ever be in one of these states:
775     * IDLE, HOLDING or DISCONNECTED.
776     *
777     * State change notification is available via
778     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
779     * java.lang.Object) registerForPreciseCallStateChanged()}.
780     */
781    Call getBackgroundCall();
782
783    /**
784     * Gets the ringing call object, which represents an incoming
785     * connection (if present) that is pending answer/accept. (This connection
786     * may be RINGING or WAITING, and there may be only one.)<p>
787
788     * The ringing call is a singleton object. It is constant for the life
789     * of this phone. It is never null.<p>
790     *
791     * The ringing call will only ever be in one of these states:
792     * IDLE, INCOMING, WAITING or DISCONNECTED.
793     *
794     * State change notification is available via
795     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
796     * java.lang.Object) registerForPreciseCallStateChanged()}.
797     */
798    Call getRingingCall();
799
800    /**
801     * Initiate a new voice connection. This happens asynchronously, so you
802     * cannot assume the audio path is connected (or a call index has been
803     * assigned) until PhoneStateChanged notification has occurred.
804     *
805     * @param dialString The dial string.
806     * @param videoState The desired video state for the connection.
807     * @exception CallStateException if a new outgoing call is not currently
808     * possible because no more call slots exist or a call exists that is
809     * dialing, alerting, ringing, or waiting.  Other errors are
810     * handled asynchronously.
811     */
812    Connection dial(String dialString, int videoState) throws CallStateException;
813
814    /**
815     * Initiate a new voice connection with supplementary User to User
816     * Information. This happens asynchronously, so you cannot assume the audio
817     * path is connected (or a call index has been assigned) until
818     * PhoneStateChanged notification has occurred.
819     *
820     * @param dialString The dial string.
821     * @param uusInfo The UUSInfo.
822     * @param videoState The desired video state for the connection.
823     * @exception CallStateException if a new outgoing call is not currently
824     *                possible because no more call slots exist or a call exists
825     *                that is dialing, alerting, ringing, or waiting. Other
826     *                errors are handled asynchronously.
827     */
828    Connection dial(String dialString, UUSInfo uusInfo, int videoState) throws CallStateException;
829
830    /**
831     * Handles PIN MMI commands (PIN/PIN2/PUK/PUK2), which are initiated
832     * without SEND (so <code>dial</code> is not appropriate).
833     *
834     * @param dialString the MMI command to be executed.
835     * @return true if MMI command is executed.
836     */
837    boolean handlePinMmi(String dialString);
838
839    /**
840     * Handles in-call MMI commands. While in a call, or while receiving a
841     * call, use this to execute MMI commands.
842     * see 3GPP 20.030, section 6.5.5.1 for specs on the allowed MMI commands.
843     *
844     * @param command the MMI command to be executed.
845     * @return true if the MMI command is executed.
846     * @throws CallStateException
847     */
848    boolean handleInCallMmiCommands(String command) throws CallStateException;
849
850    /**
851     * Play a DTMF tone on the active call. Ignored if there is no active call.
852     * @param c should be one of 0-9, '*' or '#'. Other values will be
853     * silently ignored.
854     */
855    void sendDtmf(char c);
856
857    /**
858     * Start to paly a DTMF tone on the active call. Ignored if there is no active call
859     * or there is a playing DTMF tone.
860     * @param c should be one of 0-9, '*' or '#'. Other values will be
861     * silently ignored.
862     */
863    void startDtmf(char c);
864
865    /**
866     * Stop the playing DTMF tone. Ignored if there is no playing DTMF
867     * tone or no active call.
868     */
869    void stopDtmf();
870
871    /**
872     * send burst DTMF tone, it can send the string as single character or multiple character
873     * ignore if there is no active call or not valid digits string.
874     * Valid digit means only includes characters ISO-LATIN characters 0-9, *, #
875     * The difference between sendDtmf and sendBurstDtmf is sendDtmf only sends one character,
876     * this api can send single character and multiple character, also, this api has response
877     * back to caller.
878     *
879     * @param dtmfString is string representing the dialing digit(s) in the active call
880     * @param on the DTMF ON length in milliseconds, or 0 for default
881     * @param off the DTMF OFF length in milliseconds, or 0 for default
882     * @param onComplete is the callback message when the action is processed by BP
883     *
884     */
885    void sendBurstDtmf(String dtmfString, int on, int off, Message onComplete);
886
887    /**
888     * Sets the radio power on/off state (off is sometimes
889     * called "airplane mode"). Current state can be gotten via
890     * {@link #getServiceState()}.{@link
891     * android.telephony.ServiceState#getState() getState()}.
892     * <strong>Note: </strong>This request is asynchronous.
893     * getServiceState().getState() will not change immediately after this call.
894     * registerForServiceStateChanged() to find out when the
895     * request is complete.
896     *
897     * @param power true means "on", false means "off".
898     */
899    void setRadioPower(boolean power);
900
901    /**
902     * Get voice message waiting indicator status. No change notification
903     * available on this interface. Use PhoneStateNotifier or similar instead.
904     *
905     * @return true if there is a voice message waiting
906     */
907    boolean getMessageWaitingIndicator();
908
909    /**
910     * Get voice call forwarding indicator status. No change notification
911     * available on this interface. Use PhoneStateNotifier or similar instead.
912     *
913     * @return true if there is a voice call forwarding
914     */
915    boolean getCallForwardingIndicator();
916
917    /**
918     * Get the line 1 phone number (MSISDN). For CDMA phones, the MDN is returned
919     * and {@link #getMsisdn()} will return the MSISDN on CDMA/LTE phones.<p>
920     *
921     * @return phone number. May return null if not
922     * available or the SIM is not ready
923     */
924    String getLine1Number();
925
926    /**
927     * Returns the alpha tag associated with the msisdn number.
928     * If there is no alpha tag associated or the record is not yet available,
929     * returns a default localized string. <p>
930     */
931    String getLine1AlphaTag();
932
933    /**
934     * Sets the MSISDN phone number in the SIM card.
935     *
936     * @param alphaTag the alpha tag associated with the MSISDN phone number
937     *        (see getMsisdnAlphaTag)
938     * @param number the new MSISDN phone number to be set on the SIM.
939     * @param onComplete a callback message when the action is completed.
940     */
941    void setLine1Number(String alphaTag, String number, Message onComplete);
942
943    /**
944     * Get the voice mail access phone number. Typically dialed when the
945     * user holds the "1" key in the phone app. May return null if not
946     * available or the SIM is not ready.<p>
947     */
948    String getVoiceMailNumber();
949
950    /**
951     * Returns unread voicemail count. This count is shown when the  voicemail
952     * notification is expanded.<p>
953     */
954    int getVoiceMessageCount();
955
956    /**
957     * Returns the alpha tag associated with the voice mail number.
958     * If there is no alpha tag associated or the record is not yet available,
959     * returns a default localized string. <p>
960     *
961     * Please use this value instead of some other localized string when
962     * showing a name for this number in the UI. For example, call log
963     * entries should show this alpha tag. <p>
964     *
965     * Usage of this alpha tag in the UI is a common carrier requirement.
966     */
967    String getVoiceMailAlphaTag();
968
969    /**
970     * setVoiceMailNumber
971     * sets the voicemail number in the SIM card.
972     *
973     * @param alphaTag the alpha tag associated with the voice mail number
974     *        (see getVoiceMailAlphaTag)
975     * @param voiceMailNumber the new voicemail number to be set on the SIM.
976     * @param onComplete a callback message when the action is completed.
977     */
978    void setVoiceMailNumber(String alphaTag,
979                            String voiceMailNumber,
980                            Message onComplete);
981
982    /**
983     * getCallForwardingOptions
984     * gets a call forwarding option. The return value of
985     * ((AsyncResult)onComplete.obj) is an array of CallForwardInfo.
986     *
987     * @param commandInterfaceCFReason is one of the valid call forwarding
988     *        CF_REASONS, as defined in
989     *        <code>com.android.internal.telephony.CommandsInterface.</code>
990     * @param onComplete a callback message when the action is completed.
991     *        @see com.android.internal.telephony.CallForwardInfo for details.
992     */
993    void getCallForwardingOption(int commandInterfaceCFReason,
994                                  Message onComplete);
995
996    /**
997     * setCallForwardingOptions
998     * sets a call forwarding option.
999     *
1000     * @param commandInterfaceCFReason is one of the valid call forwarding
1001     *        CF_REASONS, as defined in
1002     *        <code>com.android.internal.telephony.CommandsInterface.</code>
1003     * @param commandInterfaceCFAction is one of the valid call forwarding
1004     *        CF_ACTIONS, as defined in
1005     *        <code>com.android.internal.telephony.CommandsInterface.</code>
1006     * @param dialingNumber is the target phone number to forward calls to
1007     * @param timerSeconds is used by CFNRy to indicate the timeout before
1008     *        forwarding is attempted.
1009     * @param onComplete a callback message when the action is completed.
1010     */
1011    void setCallForwardingOption(int commandInterfaceCFReason,
1012                                 int commandInterfaceCFAction,
1013                                 String dialingNumber,
1014                                 int timerSeconds,
1015                                 Message onComplete);
1016
1017    /**
1018     * getOutgoingCallerIdDisplay
1019     * gets outgoing caller id display. The return value of
1020     * ((AsyncResult)onComplete.obj) is an array of int, with a length of 2.
1021     *
1022     * @param onComplete a callback message when the action is completed.
1023     *        @see com.android.internal.telephony.CommandsInterface#getCLIR for details.
1024     */
1025    void getOutgoingCallerIdDisplay(Message onComplete);
1026
1027    /**
1028     * setOutgoingCallerIdDisplay
1029     * sets a call forwarding option.
1030     *
1031     * @param commandInterfaceCLIRMode is one of the valid call CLIR
1032     *        modes, as defined in
1033     *        <code>com.android.internal.telephony.CommandsInterface./code>
1034     * @param onComplete a callback message when the action is completed.
1035     */
1036    void setOutgoingCallerIdDisplay(int commandInterfaceCLIRMode,
1037                                    Message onComplete);
1038
1039    /**
1040     * getCallWaiting
1041     * gets call waiting activation state. The return value of
1042     * ((AsyncResult)onComplete.obj) is an array of int, with a length of 1.
1043     *
1044     * @param onComplete a callback message when the action is completed.
1045     *        @see com.android.internal.telephony.CommandsInterface#queryCallWaiting for details.
1046     */
1047    void getCallWaiting(Message onComplete);
1048
1049    /**
1050     * setCallWaiting
1051     * sets a call forwarding option.
1052     *
1053     * @param enable is a boolean representing the state that you are
1054     *        requesting, true for enabled, false for disabled.
1055     * @param onComplete a callback message when the action is completed.
1056     */
1057    void setCallWaiting(boolean enable, Message onComplete);
1058
1059    /**
1060     * Scan available networks. This method is asynchronous; .
1061     * On completion, <code>response.obj</code> is set to an AsyncResult with
1062     * one of the following members:.<p>
1063     *<ul>
1064     * <li><code>response.obj.result</code> will be a <code>List</code> of
1065     * <code>OperatorInfo</code> objects, or</li>
1066     * <li><code>response.obj.exception</code> will be set with an exception
1067     * on failure.</li>
1068     * </ul>
1069     */
1070    void getAvailableNetworks(Message response);
1071
1072    /**
1073     * Switches network selection mode to "automatic", re-scanning and
1074     * re-selecting a network if appropriate.
1075     *
1076     * @param response The message to dispatch when the network selection
1077     * is complete.
1078     *
1079     * @see #selectNetworkManually(OperatorInfo, android.os.Message )
1080     */
1081    void setNetworkSelectionModeAutomatic(Message response);
1082
1083    /**
1084     * Manually selects a network. <code>response</code> is
1085     * dispatched when this is complete.  <code>response.obj</code> will be
1086     * an AsyncResult, and <code>response.obj.exception</code> will be non-null
1087     * on failure.
1088     *
1089     * @see #setNetworkSelectionModeAutomatic(Message)
1090     */
1091    void selectNetworkManually(OperatorInfo network,
1092                            Message response);
1093
1094    /**
1095     *  Requests to set the preferred network type for searching and registering
1096     * (CS/PS domain, RAT, and operation mode)
1097     * @param networkType one of  NT_*_TYPE
1098     * @param response is callback message
1099     */
1100    void setPreferredNetworkType(int networkType, Message response);
1101
1102    /**
1103     *  Query the preferred network type setting
1104     *
1105     * @param response is callback message to report one of  NT_*_TYPE
1106     */
1107    void getPreferredNetworkType(Message response);
1108
1109    /**
1110     * Gets the default SMSC address.
1111     *
1112     * @param result Callback message contains the SMSC address.
1113     */
1114    void getSmscAddress(Message result);
1115
1116    /**
1117     * Sets the default SMSC address.
1118     *
1119     * @param address new SMSC address
1120     * @param result Callback message is empty on completion
1121     */
1122    void setSmscAddress(String address, Message result);
1123
1124    /**
1125     * Query neighboring cell IDs.  <code>response</code> is dispatched when
1126     * this is complete.  <code>response.obj</code> will be an AsyncResult,
1127     * and <code>response.obj.exception</code> will be non-null on failure.
1128     * On success, <code>AsyncResult.result</code> will be a <code>String[]</code>
1129     * containing the neighboring cell IDs.  Index 0 will contain the count
1130     * of available cell IDs.  Cell IDs are in hexadecimal format.
1131     *
1132     * @param response callback message that is dispatched when the query
1133     * completes.
1134     */
1135    void getNeighboringCids(Message response);
1136
1137    /**
1138     * Sets an event to be fired when the telephony system processes
1139     * a post-dial character on an outgoing call.<p>
1140     *
1141     * Messages of type <code>what</code> will be sent to <code>h</code>.
1142     * The <code>obj</code> field of these Message's will be instances of
1143     * <code>AsyncResult</code>. <code>Message.obj.result</code> will be
1144     * a Connection object.<p>
1145     *
1146     * Message.arg1 will be the post dial character being processed,
1147     * or 0 ('\0') if end of string.<p>
1148     *
1149     * If Connection.getPostDialState() == WAIT,
1150     * the application must call
1151     * {@link com.android.internal.telephony.Connection#proceedAfterWaitChar()
1152     * Connection.proceedAfterWaitChar()} or
1153     * {@link com.android.internal.telephony.Connection#cancelPostDial()
1154     * Connection.cancelPostDial()}
1155     * for the telephony system to continue playing the post-dial
1156     * DTMF sequence.<p>
1157     *
1158     * If Connection.getPostDialState() == WILD,
1159     * the application must call
1160     * {@link com.android.internal.telephony.Connection#proceedAfterWildChar
1161     * Connection.proceedAfterWildChar()}
1162     * or
1163     * {@link com.android.internal.telephony.Connection#cancelPostDial()
1164     * Connection.cancelPostDial()}
1165     * for the telephony system to continue playing the
1166     * post-dial DTMF sequence.<p>
1167     *
1168     * Only one post dial character handler may be set. <p>
1169     * Calling this method with "h" equal to null unsets this handler.<p>
1170     */
1171    void setOnPostDialCharacter(Handler h, int what, Object obj);
1172
1173
1174    /**
1175     * Mutes or unmutes the microphone for the active call. The microphone
1176     * is automatically unmuted if a call is answered, dialed, or resumed
1177     * from a holding state.
1178     *
1179     * @param muted true to mute the microphone,
1180     * false to activate the microphone.
1181     */
1182
1183    void setMute(boolean muted);
1184
1185    /**
1186     * Gets current mute status. Use
1187     * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
1188     * java.lang.Object) registerForPreciseCallStateChanged()}
1189     * as a change notifcation, although presently phone state changed is not
1190     * fired when setMute() is called.
1191     *
1192     * @return true is muting, false is unmuting
1193     */
1194    boolean getMute();
1195
1196    /**
1197     * Enables or disables echo suppression.
1198     */
1199    void setEchoSuppressionEnabled();
1200
1201    /**
1202     * Invokes RIL_REQUEST_OEM_HOOK_RAW on RIL implementation.
1203     *
1204     * @param data The data for the request.
1205     * @param response <strong>On success</strong>,
1206     * (byte[])(((AsyncResult)response.obj).result)
1207     * <strong>On failure</strong>,
1208     * (((AsyncResult)response.obj).result) == null and
1209     * (((AsyncResult)response.obj).exception) being an instance of
1210     * com.android.internal.telephony.gsm.CommandException
1211     *
1212     * @see #invokeOemRilRequestRaw(byte[], android.os.Message)
1213     */
1214    void invokeOemRilRequestRaw(byte[] data, Message response);
1215
1216    /**
1217     * Invokes RIL_REQUEST_OEM_HOOK_Strings on RIL implementation.
1218     *
1219     * @param strings The strings to make available as the request data.
1220     * @param response <strong>On success</strong>, "response" bytes is
1221     * made available as:
1222     * (String[])(((AsyncResult)response.obj).result).
1223     * <strong>On failure</strong>,
1224     * (((AsyncResult)response.obj).result) == null and
1225     * (((AsyncResult)response.obj).exception) being an instance of
1226     * com.android.internal.telephony.gsm.CommandException
1227     *
1228     * @see #invokeOemRilRequestStrings(java.lang.String[], android.os.Message)
1229     */
1230    void invokeOemRilRequestStrings(String[] strings, Message response);
1231
1232    /**
1233     * Get the current active Data Call list
1234     *
1235     * @param response <strong>On success</strong>, "response" bytes is
1236     * made available as:
1237     * (String[])(((AsyncResult)response.obj).result).
1238     * <strong>On failure</strong>,
1239     * (((AsyncResult)response.obj).result) == null and
1240     * (((AsyncResult)response.obj).exception) being an instance of
1241     * com.android.internal.telephony.gsm.CommandException
1242     */
1243    void getDataCallList(Message response);
1244
1245    /**
1246     * Update the ServiceState CellLocation for current network registration.
1247     */
1248    void updateServiceLocation();
1249
1250    /**
1251     * Enable location update notifications.
1252     */
1253    void enableLocationUpdates();
1254
1255    /**
1256     * Disable location update notifications.
1257     */
1258    void disableLocationUpdates();
1259
1260    /**
1261     * For unit tests; don't send notifications to "Phone"
1262     * mailbox registrants if true.
1263     */
1264    void setUnitTestMode(boolean f);
1265
1266    /**
1267     * @return true If unit test mode is enabled
1268     */
1269    boolean getUnitTestMode();
1270
1271    /**
1272     * Assign a specified band for RF configuration.
1273     *
1274     * @param bandMode one of BM_*_BAND
1275     * @param response is callback message
1276     */
1277    void setBandMode(int bandMode, Message response);
1278
1279    /**
1280     * Query the list of band mode supported by RF.
1281     *
1282     * @param response is callback message
1283     *        ((AsyncResult)response.obj).result  is an int[] where int[0] is
1284     *        the size of the array and the rest of each element representing
1285     *        one available BM_*_BAND
1286     */
1287    void queryAvailableBandMode(Message response);
1288
1289    /**
1290     * @return true if enable data connection on roaming
1291     */
1292    boolean getDataRoamingEnabled();
1293
1294    /**
1295     * @param enable set true if enable data connection on roaming
1296     */
1297    void setDataRoamingEnabled(boolean enable);
1298
1299    /**
1300     * @return true if user has enabled data
1301     */
1302    boolean getDataEnabled();
1303
1304    /**
1305     * @param @enable set {@code true} if enable data connection
1306     */
1307    void setDataEnabled(boolean enable);
1308
1309    /**
1310     *  Query the CDMA roaming preference setting
1311     *
1312     * @param response is callback message to report one of  CDMA_RM_*
1313     */
1314    void queryCdmaRoamingPreference(Message response);
1315
1316    /**
1317     *  Requests to set the CDMA roaming preference
1318     * @param cdmaRoamingType one of  CDMA_RM_*
1319     * @param response is callback message
1320     */
1321    void setCdmaRoamingPreference(int cdmaRoamingType, Message response);
1322
1323    /**
1324     *  Requests to set the CDMA subscription mode
1325     * @param cdmaSubscriptionType one of  CDMA_SUBSCRIPTION_*
1326     * @param response is callback message
1327     */
1328    void setCdmaSubscription(int cdmaSubscriptionType, Message response);
1329
1330    /**
1331     * If this is a simulated phone interface, returns a SimulatedRadioControl.
1332     * @return SimulatedRadioControl if this is a simulated interface;
1333     * otherwise, null.
1334     */
1335    SimulatedRadioControl getSimulatedRadioControl();
1336
1337    /**
1338     * Report on whether data connectivity is allowed.
1339     */
1340    boolean isDataConnectivityPossible();
1341
1342    /**
1343     * Report on whether data connectivity is allowed for an APN.
1344     */
1345    boolean isDataConnectivityPossible(String apnType);
1346
1347    /**
1348     * Retrieves the unique device ID, e.g., IMEI for GSM phones and MEID for CDMA phones.
1349     */
1350    String getDeviceId();
1351
1352    /**
1353     * Retrieves the software version number for the device, e.g., IMEI/SV
1354     * for GSM phones.
1355     */
1356    String getDeviceSvn();
1357
1358    /**
1359     * Retrieves the unique subscriber ID, e.g., IMSI for GSM phones.
1360     */
1361    String getSubscriberId();
1362
1363    /**
1364     * Retrieves the Group Identifier Level1 for GSM phones.
1365     */
1366    String getGroupIdLevel1();
1367
1368    /**
1369     * Retrieves the serial number of the ICC, if applicable.
1370     */
1371    String getIccSerialNumber();
1372
1373    /* CDMA support methods */
1374
1375    /**
1376     * Retrieves the MIN for CDMA phones.
1377     */
1378    String getCdmaMin();
1379
1380    /**
1381     * Check if subscription data has been assigned to mMin
1382     *
1383     * return true if MIN info is ready; false otherwise.
1384     */
1385    boolean isMinInfoReady();
1386
1387    /**
1388     *  Retrieves PRL Version for CDMA phones
1389     */
1390    String getCdmaPrlVersion();
1391
1392    /**
1393     * Retrieves the ESN for CDMA phones.
1394     */
1395    String getEsn();
1396
1397    /**
1398     * Retrieves MEID for CDMA phones.
1399     */
1400    String getMeid();
1401
1402    /**
1403     * Retrieves the MSISDN from the UICC. For GSM/UMTS phones, this is equivalent to
1404     * {@link #getLine1Number()}. For CDMA phones, {@link #getLine1Number()} returns
1405     * the MDN, so this method is provided to return the MSISDN on CDMA/LTE phones.
1406     */
1407    String getMsisdn();
1408
1409    /**
1410     * Retrieves IMEI for phones. Returns null if IMEI is not set.
1411     */
1412    String getImei();
1413
1414    /**
1415     * Retrieves the PhoneSubInfo of the Phone
1416     */
1417    public PhoneSubInfo getPhoneSubInfo();
1418
1419    /**
1420     * Retrieves the IccPhoneBookInterfaceManager of the Phone
1421     */
1422    public IccPhoneBookInterfaceManager getIccPhoneBookInterfaceManager();
1423
1424    /**
1425     * setTTYMode
1426     * sets a TTY mode option.
1427     * @param ttyMode is a one of the following:
1428     * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
1429     * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
1430     * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
1431     * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
1432     * @param onComplete a callback message when the action is completed
1433     */
1434    void setTTYMode(int ttyMode, Message onComplete);
1435
1436    /**
1437     * queryTTYMode
1438     * query the status of the TTY mode
1439     *
1440     * @param onComplete a callback message when the action is completed.
1441     */
1442    void queryTTYMode(Message onComplete);
1443
1444    /**
1445     * Activate or deactivate cell broadcast SMS.
1446     *
1447     * @param activate
1448     *            0 = activate, 1 = deactivate
1449     * @param response
1450     *            Callback message is empty on completion
1451     */
1452    void activateCellBroadcastSms(int activate, Message response);
1453
1454    /**
1455     * Query the current configuration of cdma cell broadcast SMS.
1456     *
1457     * @param response
1458     *            Callback message is empty on completion
1459     */
1460    void getCellBroadcastSmsConfig(Message response);
1461
1462    /**
1463     * Configure cell broadcast SMS.
1464     *
1465     * TODO: Change the configValuesArray to a RIL_BroadcastSMSConfig
1466     *
1467     * @param response
1468     *            Callback message is empty on completion
1469     */
1470    public void setCellBroadcastSmsConfig(int[] configValuesArray, Message response);
1471
1472    public void notifyDataActivity();
1473
1474    /**
1475     * Returns the CDMA ERI icon index to display
1476     */
1477    public int getCdmaEriIconIndex();
1478
1479    /**
1480     * Returns the CDMA ERI icon mode,
1481     * 0 - ON
1482     * 1 - FLASHING
1483     */
1484    public int getCdmaEriIconMode();
1485
1486    /**
1487     * Returns the CDMA ERI text,
1488     */
1489    public String getCdmaEriText();
1490
1491    /**
1492     * request to exit emergency call back mode
1493     * the caller should use setOnECMModeExitResponse
1494     * to receive the emergency callback mode exit response
1495     */
1496    void exitEmergencyCallbackMode();
1497
1498    /**
1499     * this decides if the dial number is OTA(Over the air provision) number or not
1500     * @param dialStr is string representing the dialing digit(s)
1501     * @return  true means the dialStr is OTA number, and false means the dialStr is not OTA number
1502     */
1503    boolean isOtaSpNumber(String dialStr);
1504
1505    /**
1506     * Returns true if OTA Service Provisioning needs to be performed.
1507     */
1508    boolean needsOtaServiceProvisioning();
1509
1510    /**
1511     * Register for notifications when CDMA call waiting comes
1512     *
1513     * @param h Handler that receives the notification message.
1514     * @param what User-defined message code.
1515     * @param obj User object.
1516     */
1517    void registerForCallWaiting(Handler h, int what, Object obj);
1518
1519    /**
1520     * Unegister for notifications when CDMA Call waiting comes
1521     * @param h Handler to be removed from the registrant list.
1522     */
1523    void unregisterForCallWaiting(Handler h);
1524
1525
1526    /**
1527     * Register for signal information notifications from the network.
1528     * Message.obj will contain an AsyncResult.
1529     * AsyncResult.result will be a SuppServiceNotification instance.
1530     *
1531     * @param h Handler that receives the notification message.
1532     * @param what User-defined message code.
1533     * @param obj User object.
1534     */
1535
1536    void registerForSignalInfo(Handler h, int what, Object obj) ;
1537    /**
1538     * Unregisters for signal information notifications.
1539     * Extraneous calls are tolerated silently
1540     *
1541     * @param h Handler to be removed from the registrant list.
1542     */
1543    void unregisterForSignalInfo(Handler h);
1544
1545    /**
1546     * Register for display information notifications from the network.
1547     * Message.obj will contain an AsyncResult.
1548     * AsyncResult.result will be a SuppServiceNotification instance.
1549     *
1550     * @param h Handler that receives the notification message.
1551     * @param what User-defined message code.
1552     * @param obj User object.
1553     */
1554    void registerForDisplayInfo(Handler h, int what, Object obj);
1555
1556    /**
1557     * Unregisters for display information notifications.
1558     * Extraneous calls are tolerated silently
1559     *
1560     * @param h Handler to be removed from the registrant list.
1561     */
1562    void unregisterForDisplayInfo(Handler h) ;
1563
1564    /**
1565     * Register for CDMA number information record notification from the network.
1566     * Message.obj will contain an AsyncResult.
1567     * AsyncResult.result will be a CdmaInformationRecords.CdmaNumberInfoRec
1568     * instance.
1569     *
1570     * @param h Handler that receives the notification message.
1571     * @param what User-defined message code.
1572     * @param obj User object.
1573     */
1574    void registerForNumberInfo(Handler h, int what, Object obj);
1575
1576    /**
1577     * Unregisters for number information record notifications.
1578     * Extraneous calls are tolerated silently
1579     *
1580     * @param h Handler to be removed from the registrant list.
1581     */
1582    void unregisterForNumberInfo(Handler h);
1583
1584    /**
1585     * Register for CDMA redirected number information record notification
1586     * from the network.
1587     * Message.obj will contain an AsyncResult.
1588     * AsyncResult.result will be a CdmaInformationRecords.CdmaRedirectingNumberInfoRec
1589     * instance.
1590     *
1591     * @param h Handler that receives the notification message.
1592     * @param what User-defined message code.
1593     * @param obj User object.
1594     */
1595    void registerForRedirectedNumberInfo(Handler h, int what, Object obj);
1596
1597    /**
1598     * Unregisters for redirected number information record notification.
1599     * Extraneous calls are tolerated silently
1600     *
1601     * @param h Handler to be removed from the registrant list.
1602     */
1603    void unregisterForRedirectedNumberInfo(Handler h);
1604
1605    /**
1606     * Register for CDMA line control information record notification
1607     * from the network.
1608     * Message.obj will contain an AsyncResult.
1609     * AsyncResult.result will be a CdmaInformationRecords.CdmaLineControlInfoRec
1610     * instance.
1611     *
1612     * @param h Handler that receives the notification message.
1613     * @param what User-defined message code.
1614     * @param obj User object.
1615     */
1616    void registerForLineControlInfo(Handler h, int what, Object obj);
1617
1618    /**
1619     * Unregisters for line control information notifications.
1620     * Extraneous calls are tolerated silently
1621     *
1622     * @param h Handler to be removed from the registrant list.
1623     */
1624    void unregisterForLineControlInfo(Handler h);
1625
1626    /**
1627     * Register for CDMA T53 CLIR information record notifications
1628     * from the network.
1629     * Message.obj will contain an AsyncResult.
1630     * AsyncResult.result will be a CdmaInformationRecords.CdmaT53ClirInfoRec
1631     * instance.
1632     *
1633     * @param h Handler that receives the notification message.
1634     * @param what User-defined message code.
1635     * @param obj User object.
1636     */
1637    void registerFoT53ClirlInfo(Handler h, int what, Object obj);
1638
1639    /**
1640     * Unregisters for T53 CLIR information record notification
1641     * Extraneous calls are tolerated silently
1642     *
1643     * @param h Handler to be removed from the registrant list.
1644     */
1645    void unregisterForT53ClirInfo(Handler h);
1646
1647    /**
1648     * Register for CDMA T53 audio control information record notifications
1649     * from the network.
1650     * Message.obj will contain an AsyncResult.
1651     * AsyncResult.result will be a CdmaInformationRecords.CdmaT53AudioControlInfoRec
1652     * instance.
1653     *
1654     * @param h Handler that receives the notification message.
1655     * @param what User-defined message code.
1656     * @param obj User object.
1657     */
1658    void registerForT53AudioControlInfo(Handler h, int what, Object obj);
1659
1660    /**
1661     * Unregisters for T53 audio control information record notifications.
1662     * Extraneous calls are tolerated silently
1663     *
1664     * @param h Handler to be removed from the registrant list.
1665     */
1666    void unregisterForT53AudioControlInfo(Handler h);
1667
1668    /**
1669     * registers for exit emergency call back mode request response
1670     *
1671     * @param h Handler that receives the notification message.
1672     * @param what User-defined message code.
1673     * @param obj User object.
1674     */
1675
1676    void setOnEcbModeExitResponse(Handler h, int what, Object obj);
1677
1678    /**
1679     * Unregisters for exit emergency call back mode request response
1680     *
1681     * @param h Handler to be removed from the registrant list.
1682     */
1683    void unsetOnEcbModeExitResponse(Handler h);
1684
1685    /**
1686     * Return if the current radio is LTE on CDMA. This
1687     * is a tri-state return value as for a period of time
1688     * the mode may be unknown.
1689     *
1690     * @return {@link PhoneConstants#LTE_ON_CDMA_UNKNOWN}, {@link PhoneConstants#LTE_ON_CDMA_FALSE}
1691     * or {@link PhoneConstants#LTE_ON_CDMA_TRUE}
1692     */
1693    public int getLteOnCdmaMode();
1694
1695    /**
1696     * TODO: Adding a function for each property is not good.
1697     * A fucntion of type getPhoneProp(propType) where propType is an
1698     * enum of GSM+CDMA+LTE props would be a better approach.
1699     *
1700     * Get "Restriction of menu options for manual PLMN selection" bit
1701     * status from EF_CSP data, this belongs to "Value Added Services Group".
1702     * @return true if this bit is set or EF_CSP data is unavailable,
1703     * false otherwise
1704     */
1705    boolean isCspPlmnEnabled();
1706
1707    /**
1708     * Return an interface to retrieve the ISIM records for IMS, if available.
1709     * @return the interface to retrieve the ISIM records, or null if not supported
1710     */
1711    IsimRecords getIsimRecords();
1712
1713    /**
1714     * Sets the SIM voice message waiting indicator records.
1715     * @param line GSM Subscriber Profile Number, one-based. Only '1' is supported
1716     * @param countWaiting The number of messages waiting, if known. Use
1717     *                     -1 to indicate that an unknown number of
1718     *                      messages are waiting
1719     */
1720    void setVoiceMessageWaiting(int line, int countWaiting);
1721
1722    /**
1723     * Gets the USIM service table from the UICC, if present and available.
1724     * @return an interface to the UsimServiceTable record, or null if not available
1725     */
1726    UsimServiceTable getUsimServiceTable();
1727
1728    /**
1729     * Gets the Uicc card corresponding to this phone.
1730     * @return the UiccCard object corresponding to the phone ID.
1731     */
1732    UiccCard getUiccCard();
1733
1734    /**
1735     * Unregister from all events it registered for and dispose objects
1736     * created by this object.
1737     */
1738    void dispose();
1739
1740    /**
1741     * Remove references to external object stored in this object.
1742     */
1743    void removeReferences();
1744
1745    /**
1746     * Update the phone object if the voice radio technology has changed
1747     *
1748     * @param voiceRadioTech The new voice radio technology
1749     */
1750    void updatePhoneObject(int voiceRadioTech);
1751
1752    /**
1753     * Read one of the NV items defined in {@link RadioNVItems} / {@code ril_nv_items.h}.
1754     * Used for device configuration by some CDMA operators.
1755     *
1756     * @param itemID the ID of the item to read
1757     * @param response callback message with the String response in the obj field
1758     */
1759    void nvReadItem(int itemID, Message response);
1760
1761    /**
1762     * Write one of the NV items defined in {@link RadioNVItems} / {@code ril_nv_items.h}.
1763     * Used for device configuration by some CDMA operators.
1764     *
1765     * @param itemID the ID of the item to read
1766     * @param itemValue the value to write, as a String
1767     * @param response Callback message.
1768     */
1769    void nvWriteItem(int itemID, String itemValue, Message response);
1770
1771    /**
1772     * Update the CDMA Preferred Roaming List (PRL) in the radio NV storage.
1773     * Used for device configuration by some CDMA operators.
1774     *
1775     * @param preferredRoamingList byte array containing the new PRL
1776     * @param response Callback message.
1777     */
1778    void nvWriteCdmaPrl(byte[] preferredRoamingList, Message response);
1779
1780    /**
1781     * Perform the specified type of NV config reset. The radio will be taken offline
1782     * and the device must be rebooted after erasing the NV. Used for device
1783     * configuration by some CDMA operators.
1784     *
1785     * @param resetType reset type: 1: reload NV reset, 2: erase NV reset, 3: factory NV reset
1786     * @param response Callback message.
1787     */
1788    void nvResetConfig(int resetType, Message response);
1789
1790    /*
1791     * Returns the subscription id.
1792     */
1793    public long getSubId();
1794
1795    /*
1796     * Returns the phone id.
1797     */
1798    public int getPhoneId();
1799
1800    /**
1801     * Get P-CSCF address from PCO after data connection is established or modified.
1802     * @param apnType the apnType, "ims" for IMS APN, "emergency" for EMERGENCY APN
1803     */
1804    public String[] getPcscfAddress(String apnType);
1805
1806    /**
1807     * Set IMS registration state
1808     */
1809    public void setImsRegistrationState(boolean registered);
1810
1811    /**
1812     * Return the ImsPhone phone co-managed with this phone
1813     * @return an instance of an ImsPhone phone
1814     */
1815    public Phone getImsPhone();
1816
1817    /**
1818     * Release the local instance of the ImsPhone and disconnect from
1819     * the phone.
1820     * @return the instance of the ImsPhone phone previously owned
1821     */
1822    public ImsPhone relinquishOwnershipOfImsPhone();
1823
1824    /**
1825     * Take ownership and wire-up the input ImsPhone
1826     * @param imsPhone ImsPhone to be used.
1827     */
1828    public void acquireOwnershipOfImsPhone(ImsPhone imsPhone);
1829
1830    /**
1831     * Return the service state of mImsPhone if it is STATE_IN_SERVICE
1832     * otherwise return the current voice service state
1833     */
1834    int getVoicePhoneServiceState();
1835
1836    /**
1837     * Override the service provider name and the operator name for the input ICCID.
1838     */
1839    public boolean setOperatorBrandOverride(String iccId, String brand);
1840
1841    /**
1842     * Is Radio Present on the device and is it accessible
1843     */
1844    public boolean isRadioAvailable();
1845
1846    /**
1847     * shutdown Radio gracefully
1848     */
1849    public void shutdownRadio();
1850}
1851