OSDN Git Service

Merge "DO NOT MERGE Fix security vulnerability in pre-O rild code." into mnc-dev...
[android-x86/hardware-ril.git] / include / telephony / ril.h
1 /*
2  * Copyright (C) 2006 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
17 #ifndef ANDROID_RIL_H
18 #define ANDROID_RIL_H 1
19
20 #include <stdlib.h>
21 #include <stdint.h>
22 #include <telephony/ril_cdma_sms.h>
23 #include <telephony/ril_nv_items.h>
24 #include <telephony/ril_msim.h>
25
26 #ifndef FEATURE_UNIT_TEST
27 #include <sys/time.h>
28 #endif /* !FEATURE_UNIT_TEST */
29
30 #ifdef __cplusplus
31 extern "C" {
32 #endif
33
34 #ifndef SIM_COUNT
35 #if defined(ANDROID_SIM_COUNT_2)
36 #define SIM_COUNT 2
37 #elif defined(ANDROID_SIM_COUNT_3)
38 #define SIM_COUNT 3
39 #elif defined(ANDROID_SIM_COUNT_4)
40 #define SIM_COUNT 4
41 #else
42 #define SIM_COUNT 1
43 #endif
44
45 #ifndef ANDROID_MULTI_SIM
46 #define SIM_COUNT 1
47 #endif
48 #endif
49
50 /*
51  * RIL version.
52  * Value of RIL_VERSION should not be changed in future. Here onwards,
53  * when a new change is supposed to be introduced  which could involve new
54  * schemes added like Wakelocks, data structures added/updated, etc, we would
55  * just document RIL version associated with that change below. When OEM updates its
56  * RIL with those changes, they would return that new RIL version during RIL_REGISTER.
57  * We should make use of the returned version by vendor to identify appropriate scheme
58  * or data structure version to use.
59  *
60  * Documentation of RIL version and associated changes
61  * RIL_VERSION = 12 : This version corresponds to updated data structures namely
62  *                    RIL_Data_Call_Response_v11, RIL_SIM_IO_v6, RIL_CardStatus_v6,
63  *                    RIL_SimRefreshResponse_v7, RIL_CDMA_CallWaiting_v6,
64  *                    RIL_LTE_SignalStrength_v8, RIL_SignalStrength_v10, RIL_CellIdentityGsm_v12
65  *                    RIL_CellIdentityWcdma_v12, RIL_CellIdentityLte_v12,RIL_CellInfoGsm_v12,
66  *                    RIL_CellInfoWcdma_v12, RIL_CellInfoLte_v12, RIL_CellInfo_v12.
67  *
68  * RIL_VERSION = 13 : This version includes new wakelock semantics and as the first
69  *                    strongly versioned version it enforces structure use.
70  *
71  * RIL_VERSION = 14 : New data structures are added, namely RIL_CarrierMatchType,
72  *                    RIL_Carrier, RIL_CarrierRestrictions and RIL_PCO_Data.
73  *                    New commands added: RIL_REQUEST_SET_CARRIER_RESTRICTIONS,
74  *                    RIL_REQUEST_SET_CARRIER_RESTRICTIONS and RIL_UNSOL_PCO_DATA.
75  *
76  * RIL_VERSION = 15 : New commands added:
77  *                    RIL_UNSOL_MODEM_RESTART,
78  *                    RIL_REQUEST_SEND_DEVICE_STATE,
79  *                    RIL_REQUEST_SET_UNSOLICITED_RESPONSE_FILTER,
80  *                    RIL_REQUEST_SET_SIM_CARD_POWER
81  *                    The new parameters for RIL_REQUEST_SETUP_DATA_CALL,
82  *                    Updated data structures: RIL_DataProfileInfo_v15, RIL_InitialAttachApn_v15
83  *                    New data structure RIL_DataRegistrationStateResponse,
84  *                    RIL_VoiceRegistrationStateResponse same is
85  *                    used in RIL_REQUEST_DATA_REGISTRATION_STATE and
86  *                    RIL_REQUEST_VOICE_REGISTRATION_STATE respectively.
87  *                    New data structure RIL_OpenChannelParams.
88  */
89 #define RIL_VERSION 12
90 #define LAST_IMPRECISE_RIL_VERSION 12 // Better self-documented name
91 #define RIL_VERSION_MIN 6 /* Minimum RIL_VERSION supported */
92
93 #define CDMA_ALPHA_INFO_BUFFER_LENGTH 64
94 #define CDMA_NUMBER_INFO_BUFFER_LENGTH 81
95
96 #define MAX_RILDS 3
97 #define MAX_SERVICE_NAME_LENGTH 6
98 #define MAX_CLIENT_ID_LENGTH 2
99 #define MAX_DEBUG_SOCKET_NAME_LENGTH 12
100 #define MAX_QEMU_PIPE_NAME_LENGTH  11
101 #define MAX_UUID_LENGTH 64
102
103
104 typedef void * RIL_Token;
105
106 typedef enum {
107     RIL_SOCKET_1,
108 #if (SIM_COUNT >= 2)
109     RIL_SOCKET_2,
110 #if (SIM_COUNT >= 3)
111     RIL_SOCKET_3,
112 #endif
113 #if (SIM_COUNT >= 4)
114     RIL_SOCKET_4,
115 #endif
116 #endif
117     RIL_SOCKET_NUM
118 } RIL_SOCKET_ID;
119
120
121 typedef enum {
122     RIL_E_SUCCESS = 0,
123     RIL_E_RADIO_NOT_AVAILABLE = 1,     /* If radio did not start or is resetting */
124     RIL_E_GENERIC_FAILURE = 2,
125     RIL_E_PASSWORD_INCORRECT = 3,      /* for PIN/PIN2 methods only! */
126     RIL_E_SIM_PIN2 = 4,                /* Operation requires SIM PIN2 to be entered */
127     RIL_E_SIM_PUK2 = 5,                /* Operation requires SIM PIN2 to be entered */
128     RIL_E_REQUEST_NOT_SUPPORTED = 6,
129     RIL_E_CANCELLED = 7,
130     RIL_E_OP_NOT_ALLOWED_DURING_VOICE_CALL = 8, /* data ops are not allowed during voice
131                                                    call on a Class C GPRS device */
132     RIL_E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW = 9,  /* data ops are not allowed before device
133                                                    registers in network */
134     RIL_E_SMS_SEND_FAIL_RETRY = 10,             /* fail to send sms and need retry */
135     RIL_E_SIM_ABSENT = 11,                      /* fail to set the location where CDMA subscription
136                                                    shall be retrieved because of SIM or RUIM
137                                                    card absent */
138     RIL_E_SUBSCRIPTION_NOT_AVAILABLE = 12,      /* fail to find CDMA subscription from specified
139                                                    location */
140     RIL_E_MODE_NOT_SUPPORTED = 13,              /* HW does not support preferred network type */
141     RIL_E_FDN_CHECK_FAILURE = 14,               /* command failed because recipient is not on FDN list */
142     RIL_E_ILLEGAL_SIM_OR_ME = 15,               /* network selection failed due to
143                                                    illegal SIM or ME */
144     RIL_E_MISSING_RESOURCE = 16,                /* no logical channel available */
145     RIL_E_NO_SUCH_ELEMENT = 17,                  /* application not found on SIM */
146     RIL_E_DIAL_MODIFIED_TO_USSD = 18,           /* DIAL request modified to USSD */
147     RIL_E_DIAL_MODIFIED_TO_SS = 19,             /* DIAL request modified to SS */
148     RIL_E_DIAL_MODIFIED_TO_DIAL = 20,           /* DIAL request modified to DIAL with different
149                                                    data */
150     RIL_E_USSD_MODIFIED_TO_DIAL = 21,           /* USSD request modified to DIAL */
151     RIL_E_USSD_MODIFIED_TO_SS = 22,             /* USSD request modified to SS */
152     RIL_E_USSD_MODIFIED_TO_USSD = 23,           /* USSD request modified to different USSD
153                                                    request */
154     RIL_E_SS_MODIFIED_TO_DIAL = 24,             /* SS request modified to DIAL */
155     RIL_E_SS_MODIFIED_TO_USSD = 25,             /* SS request modified to USSD */
156     RIL_E_SUBSCRIPTION_NOT_SUPPORTED = 26,      /* Subscription not supported by RIL */
157     RIL_E_SS_MODIFIED_TO_SS = 27,               /* SS request modified to different SS request */
158     RIL_E_LCE_NOT_SUPPORTED = 36,               /* LCE service not supported(36 in RILConstants.java) */
159     RIL_E_NO_MEMORY = 37,                       /* Not sufficient memory to process the request */
160     RIL_E_INTERNAL_ERR = 38,                    /* Modem hit unexpected error scenario while handling
161                                                    this request */
162     RIL_E_SYSTEM_ERR = 39,                      /* Hit platform or system error */
163     RIL_E_MODEM_ERR = 40,                       /* Vendor RIL got unexpected or incorrect response
164                                                    from modem for this request */
165     RIL_E_INVALID_STATE = 41,                   /* Unexpected request for the current state */
166     RIL_E_NO_RESOURCES = 42,                    /* Not sufficient resource to process the request */
167     RIL_E_SIM_ERR = 43,                         /* Received error from SIM card */
168     RIL_E_INVALID_ARGUMENTS = 44,               /* Received invalid arguments in request */
169     RIL_E_INVALID_SIM_STATE = 45,               /* Can not process the request in current SIM state */
170     RIL_E_INVALID_MODEM_STATE = 46,             /* Can not process the request in current Modem state */
171     RIL_E_INVALID_CALL_ID = 47,                 /* Received invalid call id in request */
172     RIL_E_NO_SMS_TO_ACK = 48,                   /* ACK received when there is no SMS to ack */
173     RIL_E_NETWORK_ERR = 49,                     /* Received error from network */
174     RIL_E_REQUEST_RATE_LIMITED = 50,            /* Operation denied due to overly-frequent requests */
175     RIL_E_SIM_BUSY = 51,                        /* SIM is busy */
176     RIL_E_SIM_FULL = 52,                        /* The target EF is full */
177     RIL_E_NETWORK_REJECT = 53,                  /* Request is rejected by network */
178     RIL_E_OPERATION_NOT_ALLOWED = 54,           /* Not allowed the request now */
179     RIL_E_EMPTY_RECORD = 55,                    /* The request record is empty */
180     RIL_E_INVALID_SMS_FORMAT = 56,              /* Invalid sms format */
181     RIL_E_ENCODING_ERR = 57,                    /* Message not encoded properly */
182     RIL_E_INVALID_SMSC_ADDRESS = 58,            /* SMSC address specified is invalid */
183     RIL_E_NO_SUCH_ENTRY = 59,                   /* No such entry present to perform the request */
184     RIL_E_NETWORK_NOT_READY = 60,               /* Network is not ready to perform the request */
185     RIL_E_NOT_PROVISIONED = 61,                 /* Device doesnot have this value provisioned */
186     RIL_E_NO_SUBSCRIPTION = 62,                 /* Device doesnot have subscription */
187     RIL_E_NO_NETWORK_FOUND = 63,                /* Network cannot be found */
188     RIL_E_DEVICE_IN_USE = 64,                   /* Operation cannot be performed because the device
189                                                    is currently in use */
190     RIL_E_ABORTED = 65,                         /* Operation aborted */
191     RIL_E_INVALID_RESPONSE = 66,                /* Invalid response sent by vendor code */
192     // OEM specific error codes. To be used by OEM when they don't want to reveal
193     // specific error codes which would be replaced by Generic failure.
194     RIL_E_OEM_ERROR_1 = 501,
195     RIL_E_OEM_ERROR_2 = 502,
196     RIL_E_OEM_ERROR_3 = 503,
197     RIL_E_OEM_ERROR_4 = 504,
198     RIL_E_OEM_ERROR_5 = 505,
199     RIL_E_OEM_ERROR_6 = 506,
200     RIL_E_OEM_ERROR_7 = 507,
201     RIL_E_OEM_ERROR_8 = 508,
202     RIL_E_OEM_ERROR_9 = 509,
203     RIL_E_OEM_ERROR_10 = 510,
204     RIL_E_OEM_ERROR_11 = 511,
205     RIL_E_OEM_ERROR_12 = 512,
206     RIL_E_OEM_ERROR_13 = 513,
207     RIL_E_OEM_ERROR_14 = 514,
208     RIL_E_OEM_ERROR_15 = 515,
209     RIL_E_OEM_ERROR_16 = 516,
210     RIL_E_OEM_ERROR_17 = 517,
211     RIL_E_OEM_ERROR_18 = 518,
212     RIL_E_OEM_ERROR_19 = 519,
213     RIL_E_OEM_ERROR_20 = 520,
214     RIL_E_OEM_ERROR_21 = 521,
215     RIL_E_OEM_ERROR_22 = 522,
216     RIL_E_OEM_ERROR_23 = 523,
217     RIL_E_OEM_ERROR_24 = 524,
218     RIL_E_OEM_ERROR_25 = 525
219 } RIL_Errno;
220
221 typedef enum {
222     RIL_CALL_ACTIVE = 0,
223     RIL_CALL_HOLDING = 1,
224     RIL_CALL_DIALING = 2,    /* MO call only */
225     RIL_CALL_ALERTING = 3,   /* MO call only */
226     RIL_CALL_INCOMING = 4,   /* MT call only */
227     RIL_CALL_WAITING = 5     /* MT call only */
228 } RIL_CallState;
229
230 typedef enum {
231     RADIO_STATE_OFF = 0,                   /* Radio explictly powered off (eg CFUN=0) */
232     RADIO_STATE_UNAVAILABLE = 1,           /* Radio unavailable (eg, resetting or not booted) */
233     RADIO_STATE_ON = 10                    /* Radio is on */
234 } RIL_RadioState;
235
236 typedef enum {
237     RADIO_TECH_UNKNOWN = 0,
238     RADIO_TECH_GPRS = 1,
239     RADIO_TECH_EDGE = 2,
240     RADIO_TECH_UMTS = 3,
241     RADIO_TECH_IS95A = 4,
242     RADIO_TECH_IS95B = 5,
243     RADIO_TECH_1xRTT =  6,
244     RADIO_TECH_EVDO_0 = 7,
245     RADIO_TECH_EVDO_A = 8,
246     RADIO_TECH_HSDPA = 9,
247     RADIO_TECH_HSUPA = 10,
248     RADIO_TECH_HSPA = 11,
249     RADIO_TECH_EVDO_B = 12,
250     RADIO_TECH_EHRPD = 13,
251     RADIO_TECH_LTE = 14,
252     RADIO_TECH_HSPAP = 15, // HSPA+
253     RADIO_TECH_GSM = 16, // Only supports voice
254     RADIO_TECH_TD_SCDMA = 17,
255     RADIO_TECH_IWLAN = 18,
256     RADIO_TECH_LTE_CA = 19
257 } RIL_RadioTechnology;
258
259 typedef enum {
260     RAF_UNKNOWN =  (1 <<  RADIO_TECH_UNKNOWN),
261     RAF_GPRS = (1 << RADIO_TECH_GPRS),
262     RAF_EDGE = (1 << RADIO_TECH_EDGE),
263     RAF_UMTS = (1 << RADIO_TECH_UMTS),
264     RAF_IS95A = (1 << RADIO_TECH_IS95A),
265     RAF_IS95B = (1 << RADIO_TECH_IS95B),
266     RAF_1xRTT = (1 << RADIO_TECH_1xRTT),
267     RAF_EVDO_0 = (1 << RADIO_TECH_EVDO_0),
268     RAF_EVDO_A = (1 << RADIO_TECH_EVDO_A),
269     RAF_HSDPA = (1 << RADIO_TECH_HSDPA),
270     RAF_HSUPA = (1 << RADIO_TECH_HSUPA),
271     RAF_HSPA = (1 << RADIO_TECH_HSPA),
272     RAF_EVDO_B = (1 << RADIO_TECH_EVDO_B),
273     RAF_EHRPD = (1 << RADIO_TECH_EHRPD),
274     RAF_LTE = (1 << RADIO_TECH_LTE),
275     RAF_HSPAP = (1 << RADIO_TECH_HSPAP),
276     RAF_GSM = (1 << RADIO_TECH_GSM),
277     RAF_TD_SCDMA = (1 << RADIO_TECH_TD_SCDMA),
278     RAF_LTE_CA = (1 << RADIO_TECH_LTE_CA)
279 } RIL_RadioAccessFamily;
280
281 typedef enum {
282     BAND_MODE_UNSPECIFIED = 0,      //"unspecified" (selected by baseband automatically)
283     BAND_MODE_EURO = 1,             //"EURO band" (GSM-900 / DCS-1800 / WCDMA-IMT-2000)
284     BAND_MODE_USA = 2,              //"US band" (GSM-850 / PCS-1900 / WCDMA-850 / WCDMA-PCS-1900)
285     BAND_MODE_JPN = 3,              //"JPN band" (WCDMA-800 / WCDMA-IMT-2000)
286     BAND_MODE_AUS = 4,              //"AUS band" (GSM-900 / DCS-1800 / WCDMA-850 / WCDMA-IMT-2000)
287     BAND_MODE_AUS_2 = 5,            //"AUS band 2" (GSM-900 / DCS-1800 / WCDMA-850)
288     BAND_MODE_CELL_800 = 6,         //"Cellular" (800-MHz Band)
289     BAND_MODE_PCS = 7,              //"PCS" (1900-MHz Band)
290     BAND_MODE_JTACS = 8,            //"Band Class 3" (JTACS Band)
291     BAND_MODE_KOREA_PCS = 9,        //"Band Class 4" (Korean PCS Band)
292     BAND_MODE_5_450M = 10,          //"Band Class 5" (450-MHz Band)
293     BAND_MODE_IMT2000 = 11,         //"Band Class 6" (2-GMHz IMT2000 Band)
294     BAND_MODE_7_700M_2 = 12,        //"Band Class 7" (Upper 700-MHz Band)
295     BAND_MODE_8_1800M = 13,         //"Band Class 8" (1800-MHz Band)
296     BAND_MODE_9_900M = 14,          //"Band Class 9" (900-MHz Band)
297     BAND_MODE_10_800M_2 = 15,       //"Band Class 10" (Secondary 800-MHz Band)
298     BAND_MODE_EURO_PAMR_400M = 16,  //"Band Class 11" (400-MHz European PAMR Band)
299     BAND_MODE_AWS = 17,             //"Band Class 15" (AWS Band)
300     BAND_MODE_USA_2500M = 18        //"Band Class 16" (US 2.5-GHz Band)
301 } RIL_RadioBandMode;
302
303 typedef enum {
304     RC_PHASE_CONFIGURED = 0,  // LM is configured is initial value and value after FINISH completes
305     RC_PHASE_START      = 1,  // START is sent before Apply and indicates that an APPLY will be
306                               // forthcoming with these same parameters
307     RC_PHASE_APPLY      = 2,  // APPLY is sent after all LM's receive START and returned
308                               // RIL_RadioCapability.status = 0, if any START's fail no
309                               // APPLY will be sent
310     RC_PHASE_UNSOL_RSP  = 3,  // UNSOL_RSP is sent with RIL_UNSOL_RADIO_CAPABILITY
311     RC_PHASE_FINISH     = 4   // FINISH is sent after all commands have completed. If an error
312                               // occurs in any previous command the RIL_RadioAccessesFamily and
313                               // logicalModemUuid fields will be the prior configuration thus
314                               // restoring the configuration to the previous value. An error
315                               // returned by this command will generally be ignored or may
316                               // cause that logical modem to be removed from service.
317 } RadioCapabilityPhase;
318
319 typedef enum {
320     RC_STATUS_NONE       = 0, // This parameter has no meaning with RC_PHASE_START,
321                               // RC_PHASE_APPLY
322     RC_STATUS_SUCCESS    = 1, // Tell modem the action transaction of set radio
323                               // capability was success with RC_PHASE_FINISH
324     RC_STATUS_FAIL       = 2, // Tell modem the action transaction of set radio
325                               // capability is fail with RC_PHASE_FINISH.
326 } RadioCapabilityStatus;
327
328 #define RIL_RADIO_CAPABILITY_VERSION 1
329 typedef struct {
330     int version;            // Version of structure, RIL_RADIO_CAPABILITY_VERSION
331     int session;            // Unique session value defined by framework returned in all "responses/unsol"
332     int phase;              // CONFIGURED, START, APPLY, FINISH
333     int rat;                // RIL_RadioAccessFamily for the radio
334     char logicalModemUuid[MAX_UUID_LENGTH]; // A UUID typically "com.xxxx.lmX where X is the logical modem.
335     int status;             // Return status and an input parameter for RC_PHASE_FINISH
336 } RIL_RadioCapability;
337
338 // Do we want to split Data from Voice and the use
339 // RIL_RadioTechnology for get/setPreferredVoice/Data ?
340 typedef enum {
341     PREF_NET_TYPE_GSM_WCDMA                = 0, /* GSM/WCDMA (WCDMA preferred) */
342     PREF_NET_TYPE_GSM_ONLY                 = 1, /* GSM only */
343     PREF_NET_TYPE_WCDMA                    = 2, /* WCDMA  */
344     PREF_NET_TYPE_GSM_WCDMA_AUTO           = 3, /* GSM/WCDMA (auto mode, according to PRL) */
345     PREF_NET_TYPE_CDMA_EVDO_AUTO           = 4, /* CDMA and EvDo (auto mode, according to PRL) */
346     PREF_NET_TYPE_CDMA_ONLY                = 5, /* CDMA only */
347     PREF_NET_TYPE_EVDO_ONLY                = 6, /* EvDo only */
348     PREF_NET_TYPE_GSM_WCDMA_CDMA_EVDO_AUTO = 7, /* GSM/WCDMA, CDMA, and EvDo (auto mode, according to PRL) */
349     PREF_NET_TYPE_LTE_CDMA_EVDO            = 8, /* LTE, CDMA and EvDo */
350     PREF_NET_TYPE_LTE_GSM_WCDMA            = 9, /* LTE, GSM/WCDMA */
351     PREF_NET_TYPE_LTE_CMDA_EVDO_GSM_WCDMA  = 10, /* LTE, CDMA, EvDo, GSM/WCDMA */
352     PREF_NET_TYPE_LTE_ONLY                 = 11, /* LTE only */
353     PREF_NET_TYPE_LTE_WCDMA                = 12,  /* LTE/WCDMA */
354     PREF_NET_TYPE_TD_SCDMA_ONLY            = 13, /* TD-SCDMA only */
355     PREF_NET_TYPE_TD_SCDMA_WCDMA           = 14, /* TD-SCDMA and WCDMA */
356     PREF_NET_TYPE_TD_SCDMA_LTE             = 15, /* TD-SCDMA and LTE */
357     PREF_NET_TYPE_TD_SCDMA_GSM             = 16, /* TD-SCDMA and GSM */
358     PREF_NET_TYPE_TD_SCDMA_GSM_LTE         = 17, /* TD-SCDMA,GSM and LTE */
359     PREF_NET_TYPE_TD_SCDMA_GSM_WCDMA       = 18, /* TD-SCDMA, GSM/WCDMA */
360     PREF_NET_TYPE_TD_SCDMA_WCDMA_LTE       = 19, /* TD-SCDMA, WCDMA and LTE */
361     PREF_NET_TYPE_TD_SCDMA_GSM_WCDMA_LTE   = 20, /* TD-SCDMA, GSM/WCDMA and LTE */
362     PREF_NET_TYPE_TD_SCDMA_GSM_WCDMA_CDMA_EVDO_AUTO  = 21, /* TD-SCDMA, GSM/WCDMA, CDMA and EvDo */
363     PREF_NET_TYPE_TD_SCDMA_LTE_CDMA_EVDO_GSM_WCDMA   = 22  /* TD-SCDMA, LTE, CDMA, EvDo GSM/WCDMA */
364 } RIL_PreferredNetworkType;
365
366 /* Source for cdma subscription */
367 typedef enum {
368    CDMA_SUBSCRIPTION_SOURCE_RUIM_SIM = 0,
369    CDMA_SUBSCRIPTION_SOURCE_NV = 1
370 } RIL_CdmaSubscriptionSource;
371
372 /* User-to-User signaling Info activation types derived from 3GPP 23.087 v8.0 */
373 typedef enum {
374     RIL_UUS_TYPE1_IMPLICIT = 0,
375     RIL_UUS_TYPE1_REQUIRED = 1,
376     RIL_UUS_TYPE1_NOT_REQUIRED = 2,
377     RIL_UUS_TYPE2_REQUIRED = 3,
378     RIL_UUS_TYPE2_NOT_REQUIRED = 4,
379     RIL_UUS_TYPE3_REQUIRED = 5,
380     RIL_UUS_TYPE3_NOT_REQUIRED = 6
381 } RIL_UUS_Type;
382
383 /* User-to-User Signaling Information data coding schemes. Possible values for
384  * Octet 3 (Protocol Discriminator field) in the UUIE. The values have been
385  * specified in section 10.5.4.25 of 3GPP TS 24.008 */
386 typedef enum {
387     RIL_UUS_DCS_USP = 0,          /* User specified protocol */
388     RIL_UUS_DCS_OSIHLP = 1,       /* OSI higher layer protocol */
389     RIL_UUS_DCS_X244 = 2,         /* X.244 */
390     RIL_UUS_DCS_RMCF = 3,         /* Reserved for system mangement
391                                      convergence function */
392     RIL_UUS_DCS_IA5c = 4          /* IA5 characters */
393 } RIL_UUS_DCS;
394
395 /* User-to-User Signaling Information defined in 3GPP 23.087 v8.0
396  * This data is passed in RIL_ExtensionRecord and rec contains this
397  * structure when type is RIL_UUS_INFO_EXT_REC */
398 typedef struct {
399   RIL_UUS_Type    uusType;    /* UUS Type */
400   RIL_UUS_DCS     uusDcs;     /* UUS Data Coding Scheme */
401   int             uusLength;  /* Length of UUS Data */
402   char *          uusData;    /* UUS Data */
403 } RIL_UUS_Info;
404
405 /* CDMA Signal Information Record as defined in C.S0005 section 3.7.5.5 */
406 typedef struct {
407   char isPresent;    /* non-zero if signal information record is present */
408   char signalType;   /* as defined 3.7.5.5-1 */
409   char alertPitch;   /* as defined 3.7.5.5-2 */
410   char signal;       /* as defined 3.7.5.5-3, 3.7.5.5-4 or 3.7.5.5-5 */
411 } RIL_CDMA_SignalInfoRecord;
412
413 typedef struct {
414     RIL_CallState   state;
415     int             index;      /* Connection Index for use with, eg, AT+CHLD */
416     int             toa;        /* type of address, eg 145 = intl */
417     char            isMpty;     /* nonzero if is mpty call */
418     char            isMT;       /* nonzero if call is mobile terminated */
419     char            als;        /* ALS line indicator if available
420                                    (0 = line 1) */
421     char            isVoice;    /* nonzero if this is is a voice call */
422     char            isVoicePrivacy;     /* nonzero if CDMA voice privacy mode is active */
423     char *          number;     /* Remote party number */
424     int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown 3=Payphone */
425     char *          name;       /* Remote party name */
426     int             namePresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown 3=Payphone */
427     RIL_UUS_Info *  uusInfo;    /* NULL or Pointer to User-User Signaling Information */
428 } RIL_Call;
429
430 /* Deprecated, use RIL_Data_Call_Response_v6 */
431 typedef struct {
432     int             cid;        /* Context ID, uniquely identifies this call */
433     int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */
434     char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1.
435                                    For example, "IP", "IPV6", "IPV4V6", or "PPP". */
436     char *          apn;        /* ignored */
437     char *          address;    /* An address, e.g., "192.0.1.3" or "2001:db8::1". */
438 } RIL_Data_Call_Response_v4;
439
440 /*
441  * Returned by RIL_REQUEST_SETUP_DATA_CALL, RIL_REQUEST_DATA_CALL_LIST
442  * and RIL_UNSOL_DATA_CALL_LIST_CHANGED, on error status != 0.
443  */
444 typedef struct {
445     int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */
446     int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry
447                                            back-off timer value RIL wants to override the one
448                                            pre-configured in FW.
449                                            The unit is miliseconds.
450                                            The value < 0 means no value is suggested.
451                                            The value 0 means retry should be done ASAP.
452                                            The value of INT_MAX(0x7fffffff) means no retry. */
453     int             cid;        /* Context ID, uniquely identifies this call */
454     int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */
455     char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1.
456                                    For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is
457                                    PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported
458                                    such as "IP" or "IPV6" */
459     char *          ifname;     /* The network interface name */
460     char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length,
461                                    e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64".
462                                    May not be empty, typically 1 IPv4 or 1 IPv6 or
463                                    one of each. If the prefix length is absent the addresses
464                                    are assumed to be point to point with IPv4 having a prefix
465                                    length of 32 and IPv6 128. */
466     char *          dnses;      /* A space-delimited list of DNS server addresses,
467                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
468                                    May be empty. */
469     char *          gateways;   /* A space-delimited list of default gateway addresses,
470                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
471                                    May be empty in which case the addresses represent point
472                                    to point connections. */
473 } RIL_Data_Call_Response_v6;
474
475 typedef struct {
476     int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */
477     int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry
478                                            back-off timer value RIL wants to override the one
479                                            pre-configured in FW.
480                                            The unit is miliseconds.
481                                            The value < 0 means no value is suggested.
482                                            The value 0 means retry should be done ASAP.
483                                            The value of INT_MAX(0x7fffffff) means no retry. */
484     int             cid;        /* Context ID, uniquely identifies this call */
485     int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */
486     char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1.
487                                    For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is
488                                    PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported
489                                    such as "IP" or "IPV6" */
490     char *          ifname;     /* The network interface name */
491     char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length,
492                                    e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64".
493                                    May not be empty, typically 1 IPv4 or 1 IPv6 or
494                                    one of each. If the prefix length is absent the addresses
495                                    are assumed to be point to point with IPv4 having a prefix
496                                    length of 32 and IPv6 128. */
497     char *          dnses;      /* A space-delimited list of DNS server addresses,
498                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
499                                    May be empty. */
500     char *          gateways;   /* A space-delimited list of default gateway addresses,
501                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
502                                    May be empty in which case the addresses represent point
503                                    to point connections. */
504     char *          pcscf;    /* the Proxy Call State Control Function address
505                                  via PCO(Protocol Configuration Option) for IMS client. */
506 } RIL_Data_Call_Response_v9;
507
508 typedef struct {
509     int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */
510     int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry
511                                            back-off timer value RIL wants to override the one
512                                            pre-configured in FW.
513                                            The unit is miliseconds.
514                                            The value < 0 means no value is suggested.
515                                            The value 0 means retry should be done ASAP.
516                                            The value of INT_MAX(0x7fffffff) means no retry. */
517     int             cid;        /* Context ID, uniquely identifies this call */
518     int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */
519     char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1.
520                                    For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is
521                                    PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported
522                                    such as "IP" or "IPV6" */
523     char *          ifname;     /* The network interface name */
524     char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length,
525                                    e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64".
526                                    May not be empty, typically 1 IPv4 or 1 IPv6 or
527                                    one of each. If the prefix length is absent the addresses
528                                    are assumed to be point to point with IPv4 having a prefix
529                                    length of 32 and IPv6 128. */
530     char *          dnses;      /* A space-delimited list of DNS server addresses,
531                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
532                                    May be empty. */
533     char *          gateways;   /* A space-delimited list of default gateway addresses,
534                                    e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1".
535                                    May be empty in which case the addresses represent point
536                                    to point connections. */
537     char *          pcscf;    /* the Proxy Call State Control Function address
538                                  via PCO(Protocol Configuration Option) for IMS client. */
539     int             mtu;        /* MTU received from network
540                                    Value <= 0 means network has either not sent a value or
541                                    sent an invalid value */
542 } RIL_Data_Call_Response_v11;
543
544 typedef enum {
545     RADIO_TECH_3GPP = 1, /* 3GPP Technologies - GSM, WCDMA */
546     RADIO_TECH_3GPP2 = 2 /* 3GPP2 Technologies - CDMA */
547 } RIL_RadioTechnologyFamily;
548
549 typedef struct {
550     RIL_RadioTechnologyFamily tech;
551     unsigned char             retry;       /* 0 == not retry, nonzero == retry */
552     int                       messageRef;  /* Valid field if retry is set to nonzero.
553                                               Contains messageRef from RIL_SMS_Response
554                                               corresponding to failed MO SMS.
555                                             */
556
557     union {
558         /* Valid field if tech is RADIO_TECH_3GPP2. See RIL_REQUEST_CDMA_SEND_SMS */
559         RIL_CDMA_SMS_Message* cdmaMessage;
560
561         /* Valid field if tech is RADIO_TECH_3GPP. See RIL_REQUEST_SEND_SMS */
562         char**                gsmMessage;   /* This is an array of pointers where pointers
563                                                are contiguous but elements pointed by those pointers
564                                                are not contiguous
565                                             */
566     } message;
567 } RIL_IMS_SMS_Message;
568
569 typedef struct {
570     int messageRef;   /* TP-Message-Reference for GSM,
571                          and BearerData MessageId for CDMA
572                          (See 3GPP2 C.S0015-B, v2.0, table 4.5-1). */
573     char *ackPDU;     /* or NULL if n/a */
574     int errorCode;    /* See 3GPP 27.005, 3.2.5 for GSM/UMTS,
575                          3GPP2 N.S0005 (IS-41C) Table 171 for CDMA,
576                          -1 if unknown or not applicable*/
577 } RIL_SMS_Response;
578
579 /** Used by RIL_REQUEST_WRITE_SMS_TO_SIM */
580 typedef struct {
581     int status;     /* Status of message.  See TS 27.005 3.1, "<stat>": */
582                     /*      0 = "REC UNREAD"    */
583                     /*      1 = "REC READ"      */
584                     /*      2 = "STO UNSENT"    */
585                     /*      3 = "STO SENT"      */
586     char * pdu;     /* PDU of message to write, as an ASCII hex string less the SMSC address,
587                        the TP-layer length is "strlen(pdu)/2". */
588     char * smsc;    /* SMSC address in GSM BCD format prefixed by a length byte
589                        (as expected by TS 27.005) or NULL for default SMSC */
590 } RIL_SMS_WriteArgs;
591
592 /** Used by RIL_REQUEST_DIAL */
593 typedef struct {
594     char * address;
595     int clir;
596             /* (same as 'n' paremeter in TS 27.007 7.7 "+CLIR"
597              * clir == 0 on "use subscription default value"
598              * clir == 1 on "CLIR invocation" (restrict CLI presentation)
599              * clir == 2 on "CLIR suppression" (allow CLI presentation)
600              */
601     RIL_UUS_Info *  uusInfo;    /* NULL or Pointer to User-User Signaling Information */
602 } RIL_Dial;
603
604 typedef struct {
605     int command;    /* one of the commands listed for TS 27.007 +CRSM*/
606     int fileid;     /* EF id */
607     char *path;     /* "pathid" from TS 27.007 +CRSM command.
608                        Path is in hex asciii format eg "7f205f70"
609                        Path must always be provided.
610                      */
611     int p1;
612     int p2;
613     int p3;
614     char *data;     /* May be NULL*/
615     char *pin2;     /* May be NULL*/
616 } RIL_SIM_IO_v5;
617
618 typedef struct {
619     int command;    /* one of the commands listed for TS 27.007 +CRSM*/
620     int fileid;     /* EF id */
621     char *path;     /* "pathid" from TS 27.007 +CRSM command.
622                        Path is in hex asciii format eg "7f205f70"
623                        Path must always be provided.
624                      */
625     int p1;
626     int p2;
627     int p3;
628     char *data;     /* May be NULL*/
629     char *pin2;     /* May be NULL*/
630     char *aidPtr;   /* AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. */
631 } RIL_SIM_IO_v6;
632
633 /* Used by RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL and
634  * RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC. */
635 typedef struct {
636     int sessionid;  /* "sessionid" from TS 27.007 +CGLA command. Should be
637                        ignored for +CSIM command. */
638
639     /* Following fields are used to derive the APDU ("command" and "length"
640        values in TS 27.007 +CSIM and +CGLA commands). */
641     int cla;
642     int instruction;
643     int p1;
644     int p2;
645     int p3;         /* A negative P3 implies a 4 byte APDU. */
646     char *data;     /* May be NULL. In hex string format. */
647 } RIL_SIM_APDU;
648
649 typedef struct {
650     int sw1;
651     int sw2;
652     char *simResponse;  /* In hex string format ([a-fA-F0-9]*), except for SIM_AUTHENTICATION
653                            response for which it is in Base64 format, see 3GPP TS 31.102 7.1.2 */
654 } RIL_SIM_IO_Response;
655
656 /* See also com.android.internal.telephony.gsm.CallForwardInfo */
657
658 typedef struct {
659     int             status;     /*
660                                  * For RIL_REQUEST_QUERY_CALL_FORWARD_STATUS
661                                  * status 1 = active, 0 = not active
662                                  *
663                                  * For RIL_REQUEST_SET_CALL_FORWARD:
664                                  * status is:
665                                  * 0 = disable
666                                  * 1 = enable
667                                  * 2 = interrogate
668                                  * 3 = registeration
669                                  * 4 = erasure
670                                  */
671
672     int             reason;      /* from TS 27.007 7.11 "reason" */
673     int             serviceClass;/* From 27.007 +CCFC/+CLCK "class"
674                                     See table for Android mapping from
675                                     MMI service code
676                                     0 means user doesn't input class */
677     int             toa;         /* "type" from TS 27.007 7.11 */
678     char *          number;      /* "number" from TS 27.007 7.11. May be NULL */
679     int             timeSeconds; /* for CF no reply only */
680 }RIL_CallForwardInfo;
681
682 typedef struct {
683    char * cid;         /* Combination of LAC and Cell Id in 32 bits in GSM.
684                         * Upper 16 bits is LAC and lower 16 bits
685                         * is CID (as described in TS 27.005)
686                         * Primary Scrambling Code (as described in TS 25.331)
687                         *         in 9 bits in UMTS
688                         * Valid values are hexadecimal 0x0000 - 0xffffffff.
689                         */
690    int    rssi;        /* Received RSSI in GSM,
691                         * Level index of CPICH Received Signal Code Power in UMTS
692                         */
693 } RIL_NeighboringCell;
694
695 typedef struct {
696   char lce_status;                 /* LCE service status:
697                                     * -1 = not supported;
698                                     * 0 = stopped;
699                                     * 1 = active.
700                                     */
701   unsigned int actual_interval_ms; /* actual LCE reporting interval,
702                                     * meaningful only if LCEStatus = 1.
703                                     */
704 } RIL_LceStatusInfo;
705
706 typedef struct {
707   unsigned int last_hop_capacity_kbps; /* last-hop cellular capacity: kilobits/second. */
708   unsigned char confidence_level;      /* capacity estimate confidence: 0-100 */
709   unsigned char lce_suspended;         /* LCE report going to be suspended? (e.g., radio
710                                         * moves to inactive state or network type change)
711                                         * 1 = suspended;
712                                         * 0 = not suspended.
713                                         */
714 } RIL_LceDataInfo;
715
716 typedef enum {
717     RIL_MATCH_ALL = 0,          /* Apply to all carriers with the same mcc/mnc */
718     RIL_MATCH_SPN = 1,          /* Use SPN and mcc/mnc to identify the carrier */
719     RIL_MATCH_IMSI_PREFIX = 2,  /* Use IMSI prefix and mcc/mnc to identify the carrier */
720     RIL_MATCH_GID1 = 3,         /* Use GID1 and mcc/mnc to identify the carrier */
721     RIL_MATCH_GID2 = 4,         /* Use GID2 and mcc/mnc to identify the carrier */
722 } RIL_CarrierMatchType;
723
724 typedef struct {
725     const char * mcc;
726     const char * mnc;
727     RIL_CarrierMatchType match_type;   /* Specify match type for the carrier.
728                                         * If it’s RIL_MATCH_ALL, match_data is null;
729                                         * otherwise, match_data is the value for the match type.
730                                         */
731     const char * match_data;
732 } RIL_Carrier;
733
734 typedef struct {
735   int32_t len_allowed_carriers;         /* length of array allowed_carriers */
736   int32_t len_excluded_carriers;        /* length of array excluded_carriers */
737   RIL_Carrier * allowed_carriers;       /* whitelist for allowed carriers */
738   RIL_Carrier * excluded_carriers;      /* blacklist for explicitly excluded carriers
739                                          * which match allowed_carriers. Eg. allowed_carriers match
740                                          * mcc/mnc, excluded_carriers has same mcc/mnc and gid1
741                                          * is ABCD. It means except the carrier whose gid1 is ABCD,
742                                          * all carriers with the same mcc/mnc are allowed.
743                                          */
744 } RIL_CarrierRestrictions;
745
746 /* See RIL_REQUEST_LAST_CALL_FAIL_CAUSE */
747 typedef enum {
748     CALL_FAIL_UNOBTAINABLE_NUMBER = 1,
749     CALL_FAIL_NO_ROUTE_TO_DESTINATION = 3,
750     CALL_FAIL_CHANNEL_UNACCEPTABLE = 6,
751     CALL_FAIL_OPERATOR_DETERMINED_BARRING = 8,
752     CALL_FAIL_NORMAL = 16,
753     CALL_FAIL_BUSY = 17,
754     CALL_FAIL_NO_USER_RESPONDING = 18,
755     CALL_FAIL_NO_ANSWER_FROM_USER = 19,
756     CALL_FAIL_CALL_REJECTED = 21,
757     CALL_FAIL_NUMBER_CHANGED = 22,
758     CALL_FAIL_PREEMPTION = 25,
759     CALL_FAIL_DESTINATION_OUT_OF_ORDER = 27,
760     CALL_FAIL_INVALID_NUMBER_FORMAT = 28,
761     CALL_FAIL_FACILITY_REJECTED = 29,
762     CALL_FAIL_RESP_TO_STATUS_ENQUIRY = 30,
763     CALL_FAIL_NORMAL_UNSPECIFIED = 31,
764     CALL_FAIL_CONGESTION = 34,
765     CALL_FAIL_NETWORK_OUT_OF_ORDER = 38,
766     CALL_FAIL_TEMPORARY_FAILURE = 41,
767     CALL_FAIL_SWITCHING_EQUIPMENT_CONGESTION = 42,
768     CALL_FAIL_ACCESS_INFORMATION_DISCARDED = 43,
769     CALL_FAIL_REQUESTED_CIRCUIT_OR_CHANNEL_NOT_AVAILABLE = 44,
770     CALL_FAIL_RESOURCES_UNAVAILABLE_OR_UNSPECIFIED = 47,
771     CALL_FAIL_QOS_UNAVAILABLE = 49,
772     CALL_FAIL_REQUESTED_FACILITY_NOT_SUBSCRIBED = 50,
773     CALL_FAIL_INCOMING_CALLS_BARRED_WITHIN_CUG = 55,
774     CALL_FAIL_BEARER_CAPABILITY_NOT_AUTHORIZED = 57,
775     CALL_FAIL_BEARER_CAPABILITY_UNAVAILABLE = 58,
776     CALL_FAIL_SERVICE_OPTION_NOT_AVAILABLE = 63,
777     CALL_FAIL_BEARER_SERVICE_NOT_IMPLEMENTED = 65,
778     CALL_FAIL_ACM_LIMIT_EXCEEDED = 68,
779     CALL_FAIL_REQUESTED_FACILITY_NOT_IMPLEMENTED = 69,
780     CALL_FAIL_ONLY_DIGITAL_INFORMATION_BEARER_AVAILABLE = 70,
781     CALL_FAIL_SERVICE_OR_OPTION_NOT_IMPLEMENTED = 79,
782     CALL_FAIL_INVALID_TRANSACTION_IDENTIFIER = 81,
783     CALL_FAIL_USER_NOT_MEMBER_OF_CUG = 87,
784     CALL_FAIL_INCOMPATIBLE_DESTINATION = 88,
785     CALL_FAIL_INVALID_TRANSIT_NW_SELECTION = 91,
786     CALL_FAIL_SEMANTICALLY_INCORRECT_MESSAGE = 95,
787     CALL_FAIL_INVALID_MANDATORY_INFORMATION = 96,
788     CALL_FAIL_MESSAGE_TYPE_NON_IMPLEMENTED = 97,
789     CALL_FAIL_MESSAGE_TYPE_NOT_COMPATIBLE_WITH_PROTOCOL_STATE = 98,
790     CALL_FAIL_INFORMATION_ELEMENT_NON_EXISTENT = 99,
791     CALL_FAIL_CONDITIONAL_IE_ERROR = 100,
792     CALL_FAIL_MESSAGE_NOT_COMPATIBLE_WITH_PROTOCOL_STATE = 101,
793     CALL_FAIL_RECOVERY_ON_TIMER_EXPIRED = 102,
794     CALL_FAIL_PROTOCOL_ERROR_UNSPECIFIED = 111,
795     CALL_FAIL_INTERWORKING_UNSPECIFIED = 127,
796     CALL_FAIL_CALL_BARRED = 240,
797     CALL_FAIL_FDN_BLOCKED = 241,
798     CALL_FAIL_IMSI_UNKNOWN_IN_VLR = 242,
799     CALL_FAIL_IMEI_NOT_ACCEPTED = 243,
800     CALL_FAIL_DIAL_MODIFIED_TO_USSD = 244, /* STK Call Control */
801     CALL_FAIL_DIAL_MODIFIED_TO_SS = 245,
802     CALL_FAIL_DIAL_MODIFIED_TO_DIAL = 246,
803     CALL_FAIL_RADIO_OFF = 247, /* Radio is OFF */
804     CALL_FAIL_OUT_OF_SERVICE = 248, /* No cellular coverage */
805     CALL_FAIL_NO_VALID_SIM = 249, /* No valid SIM is present */
806     CALL_FAIL_RADIO_INTERNAL_ERROR = 250, /* Internal error at Modem */
807     CALL_FAIL_NETWORK_RESP_TIMEOUT = 251, /* No response from network */
808     CALL_FAIL_NETWORK_REJECT = 252, /* Explicit network reject */
809     CALL_FAIL_RADIO_ACCESS_FAILURE = 253, /* RRC connection failure. Eg.RACH */
810     CALL_FAIL_RADIO_LINK_FAILURE = 254, /* Radio Link Failure */
811     CALL_FAIL_RADIO_LINK_LOST = 255, /* Radio link lost due to poor coverage */
812     CALL_FAIL_RADIO_UPLINK_FAILURE = 256, /* Radio uplink failure */
813     CALL_FAIL_RADIO_SETUP_FAILURE = 257, /* RRC connection setup failure */
814     CALL_FAIL_RADIO_RELEASE_NORMAL = 258, /* RRC connection release, normal */
815     CALL_FAIL_RADIO_RELEASE_ABNORMAL = 259, /* RRC connection release, abnormal */
816     CALL_FAIL_ACCESS_CLASS_BLOCKED = 260, /* Access class barring */
817     CALL_FAIL_NETWORK_DETACH = 261, /* Explicit network detach */
818     CALL_FAIL_CDMA_LOCKED_UNTIL_POWER_CYCLE = 1000,
819     CALL_FAIL_CDMA_DROP = 1001,
820     CALL_FAIL_CDMA_INTERCEPT = 1002,
821     CALL_FAIL_CDMA_REORDER = 1003,
822     CALL_FAIL_CDMA_SO_REJECT = 1004,
823     CALL_FAIL_CDMA_RETRY_ORDER = 1005,
824     CALL_FAIL_CDMA_ACCESS_FAILURE = 1006,
825     CALL_FAIL_CDMA_PREEMPTED = 1007,
826     CALL_FAIL_CDMA_NOT_EMERGENCY = 1008, /* For non-emergency number dialed
827                                             during emergency callback mode */
828     CALL_FAIL_CDMA_ACCESS_BLOCKED = 1009, /* CDMA network access probes blocked */
829
830     /* OEM specific error codes. Used to distinguish error from
831      * CALL_FAIL_ERROR_UNSPECIFIED and help assist debugging */
832     CALL_FAIL_OEM_CAUSE_1 = 0xf001,
833     CALL_FAIL_OEM_CAUSE_2 = 0xf002,
834     CALL_FAIL_OEM_CAUSE_3 = 0xf003,
835     CALL_FAIL_OEM_CAUSE_4 = 0xf004,
836     CALL_FAIL_OEM_CAUSE_5 = 0xf005,
837     CALL_FAIL_OEM_CAUSE_6 = 0xf006,
838     CALL_FAIL_OEM_CAUSE_7 = 0xf007,
839     CALL_FAIL_OEM_CAUSE_8 = 0xf008,
840     CALL_FAIL_OEM_CAUSE_9 = 0xf009,
841     CALL_FAIL_OEM_CAUSE_10 = 0xf00a,
842     CALL_FAIL_OEM_CAUSE_11 = 0xf00b,
843     CALL_FAIL_OEM_CAUSE_12 = 0xf00c,
844     CALL_FAIL_OEM_CAUSE_13 = 0xf00d,
845     CALL_FAIL_OEM_CAUSE_14 = 0xf00e,
846     CALL_FAIL_OEM_CAUSE_15 = 0xf00f,
847
848     CALL_FAIL_ERROR_UNSPECIFIED = 0xffff /* This error will be deprecated soon,
849                                             vendor code should make sure to map error
850                                             code to specific error */
851 } RIL_LastCallFailCause;
852
853 typedef struct {
854   RIL_LastCallFailCause cause_code;
855   char *                vendor_cause;
856 } RIL_LastCallFailCauseInfo;
857
858 /* See RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE */
859 typedef enum {
860     PDP_FAIL_NONE = 0, /* No error, connection ok */
861
862     /* an integer cause code defined in TS 24.008
863        section 6.1.3.1.3 or TS 24.301 Release 8+ Annex B.
864        If the implementation does not have access to the exact cause codes,
865        then it should return one of the following values,
866        as the UI layer needs to distinguish these
867        cases for error notification and potential retries. */
868     PDP_FAIL_OPERATOR_BARRED = 0x08,               /* no retry */
869     PDP_FAIL_NAS_SIGNALLING = 0x0E,
870     PDP_FAIL_LLC_SNDCP = 0x19,
871     PDP_FAIL_INSUFFICIENT_RESOURCES = 0x1A,
872     PDP_FAIL_MISSING_UKNOWN_APN = 0x1B,            /* no retry */
873     PDP_FAIL_UNKNOWN_PDP_ADDRESS_TYPE = 0x1C,      /* no retry */
874     PDP_FAIL_USER_AUTHENTICATION = 0x1D,           /* no retry */
875     PDP_FAIL_ACTIVATION_REJECT_GGSN = 0x1E,        /* no retry */
876     PDP_FAIL_ACTIVATION_REJECT_UNSPECIFIED = 0x1F,
877     PDP_FAIL_SERVICE_OPTION_NOT_SUPPORTED = 0x20,  /* no retry */
878     PDP_FAIL_SERVICE_OPTION_NOT_SUBSCRIBED = 0x21, /* no retry */
879     PDP_FAIL_SERVICE_OPTION_OUT_OF_ORDER = 0x22,
880     PDP_FAIL_NSAPI_IN_USE = 0x23,                  /* no retry */
881     PDP_FAIL_REGULAR_DEACTIVATION = 0x24,          /* possibly restart radio,
882                                                       based on framework config */
883     PDP_FAIL_QOS_NOT_ACCEPTED = 0x25,
884     PDP_FAIL_NETWORK_FAILURE = 0x26,
885     PDP_FAIL_UMTS_REACTIVATION_REQ = 0x27,
886     PDP_FAIL_FEATURE_NOT_SUPP = 0x28,
887     PDP_FAIL_TFT_SEMANTIC_ERROR = 0x29,
888     PDP_FAIL_TFT_SYTAX_ERROR = 0x2A,
889     PDP_FAIL_UNKNOWN_PDP_CONTEXT = 0x2B,
890     PDP_FAIL_FILTER_SEMANTIC_ERROR = 0x2C,
891     PDP_FAIL_FILTER_SYTAX_ERROR = 0x2D,
892     PDP_FAIL_PDP_WITHOUT_ACTIVE_TFT = 0x2E,
893     PDP_FAIL_ONLY_IPV4_ALLOWED = 0x32,             /* no retry */
894     PDP_FAIL_ONLY_IPV6_ALLOWED = 0x33,             /* no retry */
895     PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED = 0x34,
896     PDP_FAIL_ESM_INFO_NOT_RECEIVED = 0x35,
897     PDP_FAIL_PDN_CONN_DOES_NOT_EXIST = 0x36,
898     PDP_FAIL_MULTI_CONN_TO_SAME_PDN_NOT_ALLOWED = 0x37,
899     PDP_FAIL_MAX_ACTIVE_PDP_CONTEXT_REACHED = 0x41,
900     PDP_FAIL_UNSUPPORTED_APN_IN_CURRENT_PLMN = 0x42,
901     PDP_FAIL_INVALID_TRANSACTION_ID = 0x51,
902     PDP_FAIL_MESSAGE_INCORRECT_SEMANTIC = 0x5F,
903     PDP_FAIL_INVALID_MANDATORY_INFO = 0x60,
904     PDP_FAIL_MESSAGE_TYPE_UNSUPPORTED = 0x61,
905     PDP_FAIL_MSG_TYPE_NONCOMPATIBLE_STATE = 0x62,
906     PDP_FAIL_UNKNOWN_INFO_ELEMENT = 0x63,
907     PDP_FAIL_CONDITIONAL_IE_ERROR = 0x64,
908     PDP_FAIL_MSG_AND_PROTOCOL_STATE_UNCOMPATIBLE = 0x65,
909     PDP_FAIL_PROTOCOL_ERRORS = 0x6F,             /* no retry */
910     PDP_FAIL_APN_TYPE_CONFLICT = 0x70,
911     PDP_FAIL_INVALID_PCSCF_ADDR = 0x71,
912     PDP_FAIL_INTERNAL_CALL_PREEMPT_BY_HIGH_PRIO_APN = 0x72,
913     PDP_FAIL_EMM_ACCESS_BARRED = 0x73,
914     PDP_FAIL_EMERGENCY_IFACE_ONLY = 0x74,
915     PDP_FAIL_IFACE_MISMATCH = 0x75,
916     PDP_FAIL_COMPANION_IFACE_IN_USE = 0x76,
917     PDP_FAIL_IP_ADDRESS_MISMATCH = 0x77,
918     PDP_FAIL_IFACE_AND_POL_FAMILY_MISMATCH = 0x78,
919     PDP_FAIL_EMM_ACCESS_BARRED_INFINITE_RETRY = 0x79,
920     PDP_FAIL_AUTH_FAILURE_ON_EMERGENCY_CALL = 0x7A,
921
922     // OEM specific error codes. To be used by OEMs when they don't want to
923     // reveal error code which would be replaced by PDP_FAIL_ERROR_UNSPECIFIED
924     PDP_FAIL_OEM_DCFAILCAUSE_1 = 0x1001,
925     PDP_FAIL_OEM_DCFAILCAUSE_2 = 0x1002,
926     PDP_FAIL_OEM_DCFAILCAUSE_3 = 0x1003,
927     PDP_FAIL_OEM_DCFAILCAUSE_4 = 0x1004,
928     PDP_FAIL_OEM_DCFAILCAUSE_5 = 0x1005,
929     PDP_FAIL_OEM_DCFAILCAUSE_6 = 0x1006,
930     PDP_FAIL_OEM_DCFAILCAUSE_7 = 0x1007,
931     PDP_FAIL_OEM_DCFAILCAUSE_8 = 0x1008,
932     PDP_FAIL_OEM_DCFAILCAUSE_9 = 0x1009,
933     PDP_FAIL_OEM_DCFAILCAUSE_10 = 0x100A,
934     PDP_FAIL_OEM_DCFAILCAUSE_11 = 0x100B,
935     PDP_FAIL_OEM_DCFAILCAUSE_12 = 0x100C,
936     PDP_FAIL_OEM_DCFAILCAUSE_13 = 0x100D,
937     PDP_FAIL_OEM_DCFAILCAUSE_14 = 0x100E,
938     PDP_FAIL_OEM_DCFAILCAUSE_15 = 0x100F,
939
940     /* Not mentioned in the specification */
941     PDP_FAIL_VOICE_REGISTRATION_FAIL = -1,
942     PDP_FAIL_DATA_REGISTRATION_FAIL = -2,
943
944    /* reasons for data call drop - network/modem disconnect */
945     PDP_FAIL_SIGNAL_LOST = -3,
946     PDP_FAIL_PREF_RADIO_TECH_CHANGED = -4,/* preferred technology has changed, should retry
947                                              with parameters appropriate for new technology */
948     PDP_FAIL_RADIO_POWER_OFF = -5,        /* data call was disconnected because radio was resetting,
949                                              powered off - no retry */
950     PDP_FAIL_TETHERED_CALL_ACTIVE = -6,   /* data call was disconnected by modem because tethered
951                                              mode was up on same APN/data profile - no retry until
952                                              tethered call is off */
953
954     PDP_FAIL_ERROR_UNSPECIFIED = 0xffff,  /* retry silently. Will be deprecated soon as
955                                              new error codes are added making this unnecessary */
956 } RIL_DataCallFailCause;
957
958 /* See RIL_REQUEST_SETUP_DATA_CALL */
959 typedef enum {
960     RIL_DATA_PROFILE_DEFAULT    = 0,
961     RIL_DATA_PROFILE_TETHERED   = 1,
962     RIL_DATA_PROFILE_IMS        = 2,
963     RIL_DATA_PROFILE_FOTA       = 3,
964     RIL_DATA_PROFILE_CBS        = 4,
965     RIL_DATA_PROFILE_OEM_BASE   = 1000,    /* Start of OEM-specific profiles */
966     RIL_DATA_PROFILE_INVALID    = 0xFFFFFFFF
967 } RIL_DataProfile;
968
969 /* Used by RIL_UNSOL_SUPP_SVC_NOTIFICATION */
970 typedef struct {
971     int     notificationType;   /*
972                                  * 0 = MO intermediate result code
973                                  * 1 = MT unsolicited result code
974                                  */
975     int     code;               /* See 27.007 7.17
976                                    "code1" for MO
977                                    "code2" for MT. */
978     int     index;              /* CUG index. See 27.007 7.17. */
979     int     type;               /* "type" from 27.007 7.17 (MT only). */
980     char *  number;             /* "number" from 27.007 7.17
981                                    (MT only, may be NULL). */
982 } RIL_SuppSvcNotification;
983
984 #define RIL_CARD_MAX_APPS     8
985
986 typedef enum {
987     RIL_CARDSTATE_ABSENT     = 0,
988     RIL_CARDSTATE_PRESENT    = 1,
989     RIL_CARDSTATE_ERROR      = 2,
990     RIL_CARDSTATE_RESTRICTED = 3  /* card is present but not usable due to carrier restrictions.*/
991 } RIL_CardState;
992
993 typedef enum {
994     RIL_PERSOSUBSTATE_UNKNOWN                   = 0, /* initial state */
995     RIL_PERSOSUBSTATE_IN_PROGRESS               = 1, /* in between each lock transition */
996     RIL_PERSOSUBSTATE_READY                     = 2, /* when either SIM or RUIM Perso is finished
997                                                         since each app can only have 1 active perso
998                                                         involved */
999     RIL_PERSOSUBSTATE_SIM_NETWORK               = 3,
1000     RIL_PERSOSUBSTATE_SIM_NETWORK_SUBSET        = 4,
1001     RIL_PERSOSUBSTATE_SIM_CORPORATE             = 5,
1002     RIL_PERSOSUBSTATE_SIM_SERVICE_PROVIDER      = 6,
1003     RIL_PERSOSUBSTATE_SIM_SIM                   = 7,
1004     RIL_PERSOSUBSTATE_SIM_NETWORK_PUK           = 8, /* The corresponding perso lock is blocked */
1005     RIL_PERSOSUBSTATE_SIM_NETWORK_SUBSET_PUK    = 9,
1006     RIL_PERSOSUBSTATE_SIM_CORPORATE_PUK         = 10,
1007     RIL_PERSOSUBSTATE_SIM_SERVICE_PROVIDER_PUK  = 11,
1008     RIL_PERSOSUBSTATE_SIM_SIM_PUK               = 12,
1009     RIL_PERSOSUBSTATE_RUIM_NETWORK1             = 13,
1010     RIL_PERSOSUBSTATE_RUIM_NETWORK2             = 14,
1011     RIL_PERSOSUBSTATE_RUIM_HRPD                 = 15,
1012     RIL_PERSOSUBSTATE_RUIM_CORPORATE            = 16,
1013     RIL_PERSOSUBSTATE_RUIM_SERVICE_PROVIDER     = 17,
1014     RIL_PERSOSUBSTATE_RUIM_RUIM                 = 18,
1015     RIL_PERSOSUBSTATE_RUIM_NETWORK1_PUK         = 19, /* The corresponding perso lock is blocked */
1016     RIL_PERSOSUBSTATE_RUIM_NETWORK2_PUK         = 20,
1017     RIL_PERSOSUBSTATE_RUIM_HRPD_PUK             = 21,
1018     RIL_PERSOSUBSTATE_RUIM_CORPORATE_PUK        = 22,
1019     RIL_PERSOSUBSTATE_RUIM_SERVICE_PROVIDER_PUK = 23,
1020     RIL_PERSOSUBSTATE_RUIM_RUIM_PUK             = 24
1021 } RIL_PersoSubstate;
1022
1023 typedef enum {
1024     RIL_APPSTATE_UNKNOWN               = 0,
1025     RIL_APPSTATE_DETECTED              = 1,
1026     RIL_APPSTATE_PIN                   = 2, /* If PIN1 or UPin is required */
1027     RIL_APPSTATE_PUK                   = 3, /* If PUK1 or Puk for UPin is required */
1028     RIL_APPSTATE_SUBSCRIPTION_PERSO    = 4, /* perso_substate should be look at
1029                                                when app_state is assigned to this value */
1030     RIL_APPSTATE_READY                 = 5
1031 } RIL_AppState;
1032
1033 typedef enum {
1034     RIL_PINSTATE_UNKNOWN              = 0,
1035     RIL_PINSTATE_ENABLED_NOT_VERIFIED = 1,
1036     RIL_PINSTATE_ENABLED_VERIFIED     = 2,
1037     RIL_PINSTATE_DISABLED             = 3,
1038     RIL_PINSTATE_ENABLED_BLOCKED      = 4,
1039     RIL_PINSTATE_ENABLED_PERM_BLOCKED = 5
1040 } RIL_PinState;
1041
1042 typedef enum {
1043   RIL_APPTYPE_UNKNOWN = 0,
1044   RIL_APPTYPE_SIM     = 1,
1045   RIL_APPTYPE_USIM    = 2,
1046   RIL_APPTYPE_RUIM    = 3,
1047   RIL_APPTYPE_CSIM    = 4,
1048   RIL_APPTYPE_ISIM    = 5
1049 } RIL_AppType;
1050
1051 /*
1052  * Please note that registration state UNKNOWN is
1053  * treated as "out of service" in the Android telephony.
1054  * Registration state REG_DENIED must be returned if Location Update
1055  * Reject (with cause 17 - Network Failure) is received
1056  * repeatedly from the network, to facilitate
1057  * "managed roaming"
1058  */
1059 typedef enum {
1060     RIL_NOT_REG_AND_NOT_SEARCHING = 0,           // Not registered, MT is not currently searching
1061                                                  // a new operator to register
1062     RIL_REG_HOME = 1,                            // Registered, home network
1063     RIL_NOT_REG_AND_SEARCHING = 2,               // Not registered, but MT is currently searching
1064                                                  // a new operator to register
1065     RIL_REG_DENIED = 3,                          // Registration denied
1066     RIL_UNKNOWN = 4,                             // Unknown
1067     RIL_REG_ROAMING = 5,                         // Registered, roaming
1068     RIL_NOT_REG_AND_EMERGENCY_AVAILABLE_AND_NOT_SEARCHING = 10,   // Same as
1069                                                  // RIL_NOT_REG_AND_NOT_SEARCHING but indicates that
1070                                                  // emergency calls are enabled.
1071     RIL_NOT_REG_AND_EMERGENCY_AVAILABLE_AND_SEARCHING = 12,  // Same as RIL_NOT_REG_AND_SEARCHING
1072                                                  // but indicates that
1073                                                  // emergency calls are enabled.
1074     RIL_REG_DENIED_AND_EMERGENCY_AVAILABLE = 13, // Same as REG_DENIED but indicates that
1075                                                  // emergency calls are enabled.
1076     RIL_UNKNOWN_AND_EMERGENCY_AVAILABLE = 14,    // Same as UNKNOWN but indicates that
1077                                                  // emergency calls are enabled.
1078 } RIL_RegState;
1079
1080 typedef struct
1081 {
1082   RIL_AppType      app_type;
1083   RIL_AppState     app_state;
1084   RIL_PersoSubstate perso_substate; /* applicable only if app_state ==
1085                                        RIL_APPSTATE_SUBSCRIPTION_PERSO */
1086   char             *aid_ptr;        /* null terminated string, e.g., from 0xA0, 0x00 -> 0x41,
1087                                        0x30, 0x30, 0x30 */
1088   char             *app_label_ptr;  /* null terminated string */
1089   int              pin1_replaced;   /* applicable to USIM, CSIM & ISIM */
1090   RIL_PinState     pin1;
1091   RIL_PinState     pin2;
1092 } RIL_AppStatus;
1093
1094 /* Deprecated, use RIL_CardStatus_v6 */
1095 typedef struct
1096 {
1097   RIL_CardState card_state;
1098   RIL_PinState  universal_pin_state;             /* applicable to USIM and CSIM: RIL_PINSTATE_xxx */
1099   int           gsm_umts_subscription_app_index; /* value < RIL_CARD_MAX_APPS, -1 if none */
1100   int           cdma_subscription_app_index;     /* value < RIL_CARD_MAX_APPS, -1 if none */
1101   int           num_applications;                /* value <= RIL_CARD_MAX_APPS */
1102   RIL_AppStatus applications[RIL_CARD_MAX_APPS];
1103 } RIL_CardStatus_v5;
1104
1105 typedef struct
1106 {
1107   RIL_CardState card_state;
1108   RIL_PinState  universal_pin_state;             /* applicable to USIM and CSIM: RIL_PINSTATE_xxx */
1109   int           gsm_umts_subscription_app_index; /* value < RIL_CARD_MAX_APPS, -1 if none */
1110   int           cdma_subscription_app_index;     /* value < RIL_CARD_MAX_APPS, -1 if none */
1111   int           ims_subscription_app_index;      /* value < RIL_CARD_MAX_APPS, -1 if none */
1112   int           num_applications;                /* value <= RIL_CARD_MAX_APPS */
1113   RIL_AppStatus applications[RIL_CARD_MAX_APPS];
1114 } RIL_CardStatus_v6;
1115
1116 /** The result of a SIM refresh, returned in data[0] of RIL_UNSOL_SIM_REFRESH
1117  *      or as part of RIL_SimRefreshResponse_v7
1118  */
1119 typedef enum {
1120     /* A file on SIM has been updated.  data[1] contains the EFID. */
1121     SIM_FILE_UPDATE = 0,
1122     /* SIM initialized.  All files should be re-read. */
1123     SIM_INIT = 1,
1124     /* SIM reset.  SIM power required, SIM may be locked and all files should be re-read. */
1125     SIM_RESET = 2
1126 } RIL_SimRefreshResult;
1127
1128 typedef struct {
1129     RIL_SimRefreshResult result;
1130     int                  ef_id; /* is the EFID of the updated file if the result is */
1131                                 /* SIM_FILE_UPDATE or 0 for any other result. */
1132     char *               aid;   /* is AID(application ID) of the card application */
1133                                 /* See ETSI 102.221 8.1 and 101.220 4 */
1134                                 /*     For SIM_FILE_UPDATE result it can be set to AID of */
1135                                 /*         application in which updated EF resides or it can be */
1136                                 /*         NULL if EF is outside of an application. */
1137                                 /*     For SIM_INIT result this field is set to AID of */
1138                                 /*         application that caused REFRESH */
1139                                 /*     For SIM_RESET result it is NULL. */
1140 } RIL_SimRefreshResponse_v7;
1141
1142 /* Deprecated, use RIL_CDMA_CallWaiting_v6 */
1143 typedef struct {
1144     char *          number;             /* Remote party number */
1145     int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown */
1146     char *          name;               /* Remote party name */
1147     RIL_CDMA_SignalInfoRecord signalInfoRecord;
1148 } RIL_CDMA_CallWaiting_v5;
1149
1150 typedef struct {
1151     char *          number;             /* Remote party number */
1152     int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown */
1153     char *          name;               /* Remote party name */
1154     RIL_CDMA_SignalInfoRecord signalInfoRecord;
1155     /* Number type/Number plan required to support International Call Waiting */
1156     int             number_type;        /* 0=Unknown, 1=International, 2=National,
1157                                            3=Network specific, 4=subscriber */
1158     int             number_plan;        /* 0=Unknown, 1=ISDN, 3=Data, 4=Telex, 8=Nat'l, 9=Private */
1159 } RIL_CDMA_CallWaiting_v6;
1160
1161 /**
1162  * Which types of Cell Broadcast Message (CBM) are to be received by the ME
1163  *
1164  * uFromServiceID - uToServiceID defines a range of CBM message identifiers
1165  * whose value is 0x0000 - 0xFFFF as defined in TS 23.041 9.4.1.2.2 for GMS
1166  * and 9.4.4.2.2 for UMTS. All other values can be treated as empty
1167  * CBM message ID.
1168  *
1169  * uFromCodeScheme - uToCodeScheme defines a range of CBM data coding schemes
1170  * whose value is 0x00 - 0xFF as defined in TS 23.041 9.4.1.2.3 for GMS
1171  * and 9.4.4.2.3 for UMTS.
1172  * All other values can be treated as empty CBM data coding scheme.
1173  *
1174  * selected 0 means message types specified in <fromServiceId, toServiceId>
1175  * and <fromCodeScheme, toCodeScheme>are not accepted, while 1 means accepted.
1176  *
1177  * Used by RIL_REQUEST_GSM_GET_BROADCAST_CONFIG and
1178  * RIL_REQUEST_GSM_SET_BROADCAST_CONFIG.
1179  */
1180 typedef struct {
1181     int fromServiceId;
1182     int toServiceId;
1183     int fromCodeScheme;
1184     int toCodeScheme;
1185     unsigned char selected;
1186 } RIL_GSM_BroadcastSmsConfigInfo;
1187
1188 /* No restriction at all including voice/SMS/USSD/SS/AV64 and packet data. */
1189 #define RIL_RESTRICTED_STATE_NONE           0x00
1190 /* Block emergency call due to restriction. But allow all normal voice/SMS/USSD/SS/AV64. */
1191 #define RIL_RESTRICTED_STATE_CS_EMERGENCY   0x01
1192 /* Block all normal voice/SMS/USSD/SS/AV64 due to restriction. Only Emergency call allowed. */
1193 #define RIL_RESTRICTED_STATE_CS_NORMAL      0x02
1194 /* Block all voice/SMS/USSD/SS/AV64 including emergency call due to restriction.*/
1195 #define RIL_RESTRICTED_STATE_CS_ALL         0x04
1196 /* Block packet data access due to restriction. */
1197 #define RIL_RESTRICTED_STATE_PS_ALL         0x10
1198
1199 /* The status for an OTASP/OTAPA session */
1200 typedef enum {
1201     CDMA_OTA_PROVISION_STATUS_SPL_UNLOCKED,
1202     CDMA_OTA_PROVISION_STATUS_SPC_RETRIES_EXCEEDED,
1203     CDMA_OTA_PROVISION_STATUS_A_KEY_EXCHANGED,
1204     CDMA_OTA_PROVISION_STATUS_SSD_UPDATED,
1205     CDMA_OTA_PROVISION_STATUS_NAM_DOWNLOADED,
1206     CDMA_OTA_PROVISION_STATUS_MDN_DOWNLOADED,
1207     CDMA_OTA_PROVISION_STATUS_IMSI_DOWNLOADED,
1208     CDMA_OTA_PROVISION_STATUS_PRL_DOWNLOADED,
1209     CDMA_OTA_PROVISION_STATUS_COMMITTED,
1210     CDMA_OTA_PROVISION_STATUS_OTAPA_STARTED,
1211     CDMA_OTA_PROVISION_STATUS_OTAPA_STOPPED,
1212     CDMA_OTA_PROVISION_STATUS_OTAPA_ABORTED
1213 } RIL_CDMA_OTA_ProvisionStatus;
1214
1215 typedef struct {
1216     int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */
1217     int bitErrorRate;    /* bit error rate (0-7, 99) as defined in TS 27.007 8.5 */
1218 } RIL_GW_SignalStrength;
1219
1220 typedef struct {
1221     int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */
1222     int bitErrorRate;    /* bit error rate (0-7, 99) as defined in TS 27.007 8.5 */
1223     int timingAdvance;   /* Timing Advance in bit periods. 1 bit period = 48/13 us.
1224                           * INT_MAX denotes invalid value */
1225 } RIL_GSM_SignalStrength_v12;
1226
1227 typedef struct {
1228     int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */
1229     int bitErrorRate;    /* bit error rate (0-7, 99) as defined in TS 27.007 8.5 */
1230 } RIL_SignalStrengthWcdma;
1231
1232 typedef struct {
1233     int dbm;  /* Valid values are positive integers.  This value is the actual RSSI value
1234                * multiplied by -1.  Example: If the actual RSSI is -75, then this response
1235                * value will be 75.
1236                */
1237     int ecio; /* Valid values are positive integers.  This value is the actual Ec/Io multiplied
1238                * by -10.  Example: If the actual Ec/Io is -12.5 dB, then this response value
1239                * will be 125.
1240                */
1241 } RIL_CDMA_SignalStrength;
1242
1243
1244 typedef struct {
1245     int dbm;  /* Valid values are positive integers.  This value is the actual RSSI value
1246                * multiplied by -1.  Example: If the actual RSSI is -75, then this response
1247                * value will be 75.
1248                */
1249     int ecio; /* Valid values are positive integers.  This value is the actual Ec/Io multiplied
1250                * by -10.  Example: If the actual Ec/Io is -12.5 dB, then this response value
1251                * will be 125.
1252                */
1253     int signalNoiseRatio; /* Valid values are 0-8.  8 is the highest signal to noise ratio. */
1254 } RIL_EVDO_SignalStrength;
1255
1256 typedef struct {
1257     int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */
1258     int rsrp;            /* The current Reference Signal Receive Power in dBm multipled by -1.
1259                           * Range: 44 to 140 dBm
1260                           * INT_MAX: 0x7FFFFFFF denotes invalid value.
1261                           * Reference: 3GPP TS 36.133 9.1.4 */
1262     int rsrq;            /* The current Reference Signal Receive Quality in dB multiplied by -1.
1263                           * Range: 20 to 3 dB.
1264                           * INT_MAX: 0x7FFFFFFF denotes invalid value.
1265                           * Reference: 3GPP TS 36.133 9.1.7 */
1266     int rssnr;           /* The current reference signal signal-to-noise ratio in 0.1 dB units.
1267                           * Range: -200 to +300 (-200 = -20.0 dB, +300 = 30dB).
1268                           * INT_MAX : 0x7FFFFFFF denotes invalid value.
1269                           * Reference: 3GPP TS 36.101 8.1.1 */
1270     int cqi;             /* The current Channel Quality Indicator.
1271                           * Range: 0 to 15.
1272                           * INT_MAX : 0x7FFFFFFF denotes invalid value.
1273                           * Reference: 3GPP TS 36.101 9.2, 9.3, A.4 */
1274 } RIL_LTE_SignalStrength;
1275
1276 typedef struct {
1277     int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */
1278     int rsrp;            /* The current Reference Signal Receive Power in dBm multipled by -1.
1279                           * Range: 44 to 140 dBm
1280                           * INT_MAX: 0x7FFFFFFF denotes invalid value.
1281                           * Reference: 3GPP TS 36.133 9.1.4 */
1282     int rsrq;            /* The current Reference Signal Receive Quality in dB multiplied by -1.
1283                           * Range: 20 to 3 dB.
1284                           * INT_MAX: 0x7FFFFFFF denotes invalid value.
1285                           * Reference: 3GPP TS 36.133 9.1.7 */
1286     int rssnr;           /* The current reference signal signal-to-noise ratio in 0.1 dB units.
1287                           * Range: -200 to +300 (-200 = -20.0 dB, +300 = 30dB).
1288                           * INT_MAX : 0x7FFFFFFF denotes invalid value.
1289                           * Reference: 3GPP TS 36.101 8.1.1 */
1290     int cqi;             /* The current Channel Quality Indicator.
1291                           * Range: 0 to 15.
1292                           * INT_MAX : 0x7FFFFFFF denotes invalid value.
1293                           * Reference: 3GPP TS 36.101 9.2, 9.3, A.4 */
1294     int timingAdvance;   /* timing advance in micro seconds for a one way trip from cell to device.
1295                           * Approximate distance can be calculated using 300m/us * timingAdvance.
1296                           * Range: 0 to 0x7FFFFFFE
1297                           * INT_MAX : 0x7FFFFFFF denotes invalid value.
1298                           * Reference: 3GPP 36.321 section 6.1.3.5
1299                           * also: http://www.cellular-planningoptimization.com/2010/02/timing-advance-with-calculation.html */
1300 } RIL_LTE_SignalStrength_v8;
1301
1302 typedef struct {
1303     int rscp;    /* The Received Signal Code Power in dBm multipled by -1.
1304                   * Range : 25 to 120
1305                   * INT_MAX: 0x7FFFFFFF denotes invalid value.
1306                   * Reference: 3GPP TS 25.123, section 9.1.1.1 */
1307 } RIL_TD_SCDMA_SignalStrength;
1308
1309 /* Deprecated, use RIL_SignalStrength_v6 */
1310 typedef struct {
1311     RIL_GW_SignalStrength   GW_SignalStrength;
1312     RIL_CDMA_SignalStrength CDMA_SignalStrength;
1313     RIL_EVDO_SignalStrength EVDO_SignalStrength;
1314 } RIL_SignalStrength_v5;
1315
1316 typedef struct {
1317     RIL_GW_SignalStrength   GW_SignalStrength;
1318     RIL_CDMA_SignalStrength CDMA_SignalStrength;
1319     RIL_EVDO_SignalStrength EVDO_SignalStrength;
1320     RIL_LTE_SignalStrength  LTE_SignalStrength;
1321 } RIL_SignalStrength_v6;
1322
1323 typedef struct {
1324     RIL_GW_SignalStrength       GW_SignalStrength;
1325     RIL_CDMA_SignalStrength     CDMA_SignalStrength;
1326     RIL_EVDO_SignalStrength     EVDO_SignalStrength;
1327     RIL_LTE_SignalStrength_v8   LTE_SignalStrength;
1328 } RIL_SignalStrength_v8;
1329
1330 typedef struct {
1331     RIL_GW_SignalStrength       GW_SignalStrength;
1332     RIL_CDMA_SignalStrength     CDMA_SignalStrength;
1333     RIL_EVDO_SignalStrength     EVDO_SignalStrength;
1334     RIL_LTE_SignalStrength_v8   LTE_SignalStrength;
1335     RIL_TD_SCDMA_SignalStrength TD_SCDMA_SignalStrength;
1336 } RIL_SignalStrength_v10;
1337
1338 typedef struct {
1339     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown */
1340     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown */
1341     int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */
1342     int cid;    /* 16-bit GSM Cell Identity described in TS 27.007, 0..65535, INT_MAX if unknown  */
1343 } RIL_CellIdentityGsm;
1344
1345 typedef struct {
1346     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown */
1347     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown */
1348     int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */
1349     int cid;    /* 16-bit GSM Cell Identity described in TS 27.007, 0..65535, INT_MAX if unknown  */
1350     int arfcn;  /* 16-bit GSM Absolute RF channel number, INT_MAX if unknown */
1351     uint8_t bsic;/* 6-bit Base Station Identity Code, 0xFF if unknown */
1352 } RIL_CellIdentityGsm_v12;
1353
1354 typedef struct {
1355     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */
1356     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */
1357     int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */
1358     int cid;    /* 28-bit UMTS Cell Identity described in TS 25.331, 0..268435455, INT_MAX if unknown  */
1359     int psc;    /* 9-bit UMTS Primary Scrambling Code described in TS 25.331, 0..511, INT_MAX if unknown */
1360 } RIL_CellIdentityWcdma;
1361
1362 typedef struct {
1363     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */
1364     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */
1365     int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */
1366     int cid;    /* 28-bit UMTS Cell Identity described in TS 25.331, 0..268435455, INT_MAX if unknown  */
1367     int psc;    /* 9-bit UMTS Primary Scrambling Code described in TS 25.331, 0..511, INT_MAX if unknown */
1368     int uarfcn; /* 16-bit UMTS Absolute RF Channel Number, INT_MAX if unknown */
1369 } RIL_CellIdentityWcdma_v12;
1370
1371 typedef struct {
1372     int networkId;      /* Network Id 0..65535, INT_MAX if unknown */
1373     int systemId;       /* CDMA System Id 0..32767, INT_MAX if unknown  */
1374     int basestationId;  /* Base Station Id 0..65535, INT_MAX if unknown  */
1375     int longitude;      /* Longitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0.
1376                          * It is represented in units of 0.25 seconds and ranges from -2592000
1377                          * to 2592000, both values inclusive (corresponding to a range of -180
1378                          * to +180 degrees). INT_MAX if unknown */
1379
1380     int latitude;       /* Latitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0.
1381                          * It is represented in units of 0.25 seconds and ranges from -1296000
1382                          * to 1296000, both values inclusive (corresponding to a range of -90
1383                          * to +90 degrees). INT_MAX if unknown */
1384 } RIL_CellIdentityCdma;
1385
1386 typedef struct {
1387     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */
1388     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */
1389     int ci;     /* 28-bit Cell Identity described in TS ???, INT_MAX if unknown */
1390     int pci;    /* physical cell id 0..503, INT_MAX if unknown  */
1391     int tac;    /* 16-bit tracking area code, INT_MAX if unknown  */
1392 } RIL_CellIdentityLte;
1393
1394 typedef struct {
1395     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */
1396     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */
1397     int ci;     /* 28-bit Cell Identity described in TS ???, INT_MAX if unknown */
1398     int pci;    /* physical cell id 0..503, INT_MAX if unknown  */
1399     int tac;    /* 16-bit tracking area code, INT_MAX if unknown  */
1400     int earfcn; /* 18-bit LTE Absolute RC Channel Number, INT_MAX if unknown */
1401 } RIL_CellIdentityLte_v12;
1402
1403 typedef struct {
1404     int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */
1405     int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */
1406     int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */
1407     int cid;    /* 28-bit UMTS Cell Identity described in TS 25.331, 0..268435455, INT_MAX if unknown  */
1408     int cpid;    /* 8-bit Cell Parameters ID described in TS 25.331, 0..127, INT_MAX if unknown */
1409 } RIL_CellIdentityTdscdma;
1410
1411 typedef struct {
1412   RIL_CellIdentityGsm   cellIdentityGsm;
1413   RIL_GW_SignalStrength signalStrengthGsm;
1414 } RIL_CellInfoGsm;
1415
1416 typedef struct {
1417   RIL_CellIdentityGsm_v12   cellIdentityGsm;
1418   RIL_GSM_SignalStrength_v12 signalStrengthGsm;
1419 } RIL_CellInfoGsm_v12;
1420
1421 typedef struct {
1422   RIL_CellIdentityWcdma cellIdentityWcdma;
1423   RIL_SignalStrengthWcdma signalStrengthWcdma;
1424 } RIL_CellInfoWcdma;
1425
1426 typedef struct {
1427   RIL_CellIdentityWcdma_v12 cellIdentityWcdma;
1428   RIL_SignalStrengthWcdma signalStrengthWcdma;
1429 } RIL_CellInfoWcdma_v12;
1430
1431 typedef struct {
1432   RIL_CellIdentityCdma      cellIdentityCdma;
1433   RIL_CDMA_SignalStrength   signalStrengthCdma;
1434   RIL_EVDO_SignalStrength   signalStrengthEvdo;
1435 } RIL_CellInfoCdma;
1436
1437 typedef struct {
1438   RIL_CellIdentityLte        cellIdentityLte;
1439   RIL_LTE_SignalStrength_v8  signalStrengthLte;
1440 } RIL_CellInfoLte;
1441
1442 typedef struct {
1443   RIL_CellIdentityLte_v12    cellIdentityLte;
1444   RIL_LTE_SignalStrength_v8  signalStrengthLte;
1445 } RIL_CellInfoLte_v12;
1446
1447 typedef struct {
1448   RIL_CellIdentityTdscdma cellIdentityTdscdma;
1449   RIL_TD_SCDMA_SignalStrength signalStrengthTdscdma;
1450 } RIL_CellInfoTdscdma;
1451
1452 // Must be the same as CellInfo.TYPE_XXX
1453 typedef enum {
1454   RIL_CELL_INFO_TYPE_NONE   = 0, /* indicates no cell information */
1455   RIL_CELL_INFO_TYPE_GSM    = 1,
1456   RIL_CELL_INFO_TYPE_CDMA   = 2,
1457   RIL_CELL_INFO_TYPE_LTE    = 3,
1458   RIL_CELL_INFO_TYPE_WCDMA  = 4,
1459   RIL_CELL_INFO_TYPE_TD_SCDMA  = 5
1460 } RIL_CellInfoType;
1461
1462 // Must be the same as CellInfo.TIMESTAMP_TYPE_XXX
1463 typedef enum {
1464     RIL_TIMESTAMP_TYPE_UNKNOWN = 0,
1465     RIL_TIMESTAMP_TYPE_ANTENNA = 1,
1466     RIL_TIMESTAMP_TYPE_MODEM = 2,
1467     RIL_TIMESTAMP_TYPE_OEM_RIL = 3,
1468     RIL_TIMESTAMP_TYPE_JAVA_RIL = 4,
1469 } RIL_TimeStampType;
1470
1471 typedef struct {
1472   RIL_CellInfoType  cellInfoType;   /* cell type for selecting from union CellInfo */
1473   int               registered;     /* !0 if this cell is registered 0 if not registered */
1474   RIL_TimeStampType timeStampType;  /* type of time stamp represented by timeStamp */
1475   uint64_t          timeStamp;      /* Time in nanos as returned by ril_nano_time */
1476   union {
1477     RIL_CellInfoGsm     gsm;
1478     RIL_CellInfoCdma    cdma;
1479     RIL_CellInfoLte     lte;
1480     RIL_CellInfoWcdma   wcdma;
1481     RIL_CellInfoTdscdma tdscdma;
1482   } CellInfo;
1483 } RIL_CellInfo;
1484
1485 typedef struct {
1486   RIL_CellInfoType  cellInfoType;   /* cell type for selecting from union CellInfo */
1487   int               registered;     /* !0 if this cell is registered 0 if not registered */
1488   RIL_TimeStampType timeStampType;  /* type of time stamp represented by timeStamp */
1489   uint64_t          timeStamp;      /* Time in nanos as returned by ril_nano_time */
1490   union {
1491     RIL_CellInfoGsm_v12     gsm;
1492     RIL_CellInfoCdma        cdma;
1493     RIL_CellInfoLte_v12     lte;
1494     RIL_CellInfoWcdma_v12   wcdma;
1495     RIL_CellInfoTdscdma     tdscdma;
1496   } CellInfo;
1497 } RIL_CellInfo_v12;
1498
1499 typedef struct {
1500   RIL_CellInfoType  cellInfoType;   /* cell type for selecting from union CellInfo */
1501   union {
1502     RIL_CellIdentityGsm_v12 cellIdentityGsm;
1503     RIL_CellIdentityWcdma_v12 cellIdentityWcdma;
1504     RIL_CellIdentityLte_v12 cellIdentityLte;
1505     RIL_CellIdentityTdscdma cellIdentityTdscdma;
1506     RIL_CellIdentityCdma cellIdentityCdma;
1507   };
1508 }RIL_CellIdentity_v16;
1509
1510 typedef struct {
1511     RIL_RegState regState;                // Valid reg states are RIL_NOT_REG_AND_NOT_SEARCHING,
1512                                           // REG_HOME, RIL_NOT_REG_AND_SEARCHING, REG_DENIED,
1513                                           // UNKNOWN, REG_ROAMING defined in RegState
1514     RIL_RadioTechnology rat;              // indicates the available voice radio technology,
1515                                           // valid values as defined by RadioTechnology.
1516     int32_t cssSupported;                 // concurrent services support indicator. if
1517                                           // registered on a CDMA system.
1518                                           // 0 - Concurrent services not supported,
1519                                           // 1 - Concurrent services supported
1520     int32_t roamingIndicator;             // TSB-58 Roaming Indicator if registered
1521                                           // on a CDMA or EVDO system or -1 if not.
1522                                           // Valid values are 0-255.
1523     int32_t systemIsInPrl;                // indicates whether the current system is in the
1524                                           // PRL if registered on a CDMA or EVDO system or -1 if
1525                                           // not. 0=not in the PRL, 1=in the PRL
1526     int32_t defaultRoamingIndicator;      // default Roaming Indicator from the PRL,
1527                                           // if registered on a CDMA or EVDO system or -1 if not.
1528                                           // Valid values are 0-255.
1529     int32_t reasonForDenial;              // reasonForDenial if registration state is 3
1530                                           // (Registration denied) this is an enumerated reason why
1531                                           // registration was denied. See 3GPP TS 24.008,
1532                                           // 10.5.3.6 and Annex G.
1533                                           // 0 - General
1534                                           // 1 - Authentication Failure
1535                                           // 2 - IMSI unknown in HLR
1536                                           // 3 - Illegal MS
1537                                           // 4 - Illegal ME
1538                                           // 5 - PLMN not allowed
1539                                           // 6 - Location area not allowed
1540                                           // 7 - Roaming not allowed
1541                                           // 8 - No Suitable Cells in this Location Area
1542                                           // 9 - Network failure
1543                                           // 10 - Persistent location update reject
1544                                           // 11 - PLMN not allowed
1545                                           // 12 - Location area not allowed
1546                                           // 13 - Roaming not allowed in this Location Area
1547                                           // 15 - No Suitable Cells in this Location Area
1548                                           // 17 - Network Failure
1549                                           // 20 - MAC Failure
1550                                           // 21 - Sync Failure
1551                                           // 22 - Congestion
1552                                           // 23 - GSM Authentication unacceptable
1553                                           // 25 - Not Authorized for this CSG
1554                                           // 32 - Service option not supported
1555                                           // 33 - Requested service option not subscribed
1556                                           // 34 - Service option temporarily out of order
1557                                           // 38 - Call cannot be identified
1558                                           // 48-63 - Retry upon entry into a new cell
1559                                           // 95 - Semantically incorrect message
1560                                           // 96 - Invalid mandatory information
1561                                           // 97 - Message type non-existent or not implemented
1562                                           // 98 - Message type not compatible with protocol state
1563                                           // 99 - Information element non-existent or
1564                                           //      not implemented
1565                                           // 100 - Conditional IE error
1566                                           // 101 - Message not compatible with protocol state;
1567     RIL_CellIdentity_v16 cellIdentity;    // current cell information
1568 }RIL_VoiceRegistrationStateResponse;
1569
1570
1571 typedef struct {
1572     RIL_RegState regState;                // Valid reg states are RIL_NOT_REG_AND_NOT_SEARCHING,
1573                                           // REG_HOME, RIL_NOT_REG_AND_SEARCHING, REG_DENIED,
1574                                           // UNKNOWN, REG_ROAMING defined in RegState
1575     RIL_RadioTechnology rat;              // indicates the available data radio technology,
1576                                           // valid values as defined by RadioTechnology.
1577     int32_t reasonDataDenied;             // if registration state is 3 (Registration
1578                                           // denied) this is an enumerated reason why
1579                                           // registration was denied. See 3GPP TS 24.008,
1580                                           // Annex G.6 "Additional cause codes for GMM".
1581                                           // 7 == GPRS services not allowed
1582                                           // 8 == GPRS services and non-GPRS services not allowed
1583                                           // 9 == MS identity cannot be derived by the network
1584                                           // 10 == Implicitly detached
1585                                           // 14 == GPRS services not allowed in this PLMN
1586                                           // 16 == MSC temporarily not reachable
1587                                           // 40 == No PDP context activated
1588     int32_t maxDataCalls;                 // The maximum number of simultaneous Data Calls that
1589                                           // must be established using setupDataCall().
1590     RIL_CellIdentity_v16 cellIdentity;    // Current cell information
1591 }RIL_DataRegistrationStateResponse;
1592
1593 /* Names of the CDMA info records (C.S0005 section 3.7.5) */
1594 typedef enum {
1595   RIL_CDMA_DISPLAY_INFO_REC,
1596   RIL_CDMA_CALLED_PARTY_NUMBER_INFO_REC,
1597   RIL_CDMA_CALLING_PARTY_NUMBER_INFO_REC,
1598   RIL_CDMA_CONNECTED_NUMBER_INFO_REC,
1599   RIL_CDMA_SIGNAL_INFO_REC,
1600   RIL_CDMA_REDIRECTING_NUMBER_INFO_REC,
1601   RIL_CDMA_LINE_CONTROL_INFO_REC,
1602   RIL_CDMA_EXTENDED_DISPLAY_INFO_REC,
1603   RIL_CDMA_T53_CLIR_INFO_REC,
1604   RIL_CDMA_T53_RELEASE_INFO_REC,
1605   RIL_CDMA_T53_AUDIO_CONTROL_INFO_REC
1606 } RIL_CDMA_InfoRecName;
1607
1608 /* Display Info Rec as defined in C.S0005 section 3.7.5.1
1609    Extended Display Info Rec as defined in C.S0005 section 3.7.5.16
1610    Note: the Extended Display info rec contains multiple records of the
1611    form: display_tag, display_len, and display_len occurrences of the
1612    chari field if the display_tag is not 10000000 or 10000001.
1613    To save space, the records are stored consecutively in a byte buffer.
1614    The display_tag, display_len and chari fields are all 1 byte.
1615 */
1616
1617 typedef struct {
1618   char alpha_len;
1619   char alpha_buf[CDMA_ALPHA_INFO_BUFFER_LENGTH];
1620 } RIL_CDMA_DisplayInfoRecord;
1621
1622 /* Called Party Number Info Rec as defined in C.S0005 section 3.7.5.2
1623    Calling Party Number Info Rec as defined in C.S0005 section 3.7.5.3
1624    Connected Number Info Rec as defined in C.S0005 section 3.7.5.4
1625 */
1626
1627 typedef struct {
1628   char len;
1629   char buf[CDMA_NUMBER_INFO_BUFFER_LENGTH];
1630   char number_type;
1631   char number_plan;
1632   char pi;
1633   char si;
1634 } RIL_CDMA_NumberInfoRecord;
1635
1636 /* Redirecting Number Information Record as defined in C.S0005 section 3.7.5.11 */
1637 typedef enum {
1638   RIL_REDIRECTING_REASON_UNKNOWN = 0,
1639   RIL_REDIRECTING_REASON_CALL_FORWARDING_BUSY = 1,
1640   RIL_REDIRECTING_REASON_CALL_FORWARDING_NO_REPLY = 2,
1641   RIL_REDIRECTING_REASON_CALLED_DTE_OUT_OF_ORDER = 9,
1642   RIL_REDIRECTING_REASON_CALL_FORWARDING_BY_THE_CALLED_DTE = 10,
1643   RIL_REDIRECTING_REASON_CALL_FORWARDING_UNCONDITIONAL = 15,
1644   RIL_REDIRECTING_REASON_RESERVED
1645 } RIL_CDMA_RedirectingReason;
1646
1647 typedef struct {
1648   RIL_CDMA_NumberInfoRecord redirectingNumber;
1649   /* redirectingReason is set to RIL_REDIRECTING_REASON_UNKNOWN if not included */
1650   RIL_CDMA_RedirectingReason redirectingReason;
1651 } RIL_CDMA_RedirectingNumberInfoRecord;
1652
1653 /* Line Control Information Record as defined in C.S0005 section 3.7.5.15 */
1654 typedef struct {
1655   char lineCtrlPolarityIncluded;
1656   char lineCtrlToggle;
1657   char lineCtrlReverse;
1658   char lineCtrlPowerDenial;
1659 } RIL_CDMA_LineControlInfoRecord;
1660
1661 /* T53 CLIR Information Record */
1662 typedef struct {
1663   char cause;
1664 } RIL_CDMA_T53_CLIRInfoRecord;
1665
1666 /* T53 Audio Control Information Record */
1667 typedef struct {
1668   char upLink;
1669   char downLink;
1670 } RIL_CDMA_T53_AudioControlInfoRecord;
1671
1672 typedef struct {
1673
1674   RIL_CDMA_InfoRecName name;
1675
1676   union {
1677     /* Display and Extended Display Info Rec */
1678     RIL_CDMA_DisplayInfoRecord           display;
1679
1680     /* Called Party Number, Calling Party Number, Connected Number Info Rec */
1681     RIL_CDMA_NumberInfoRecord            number;
1682
1683     /* Signal Info Rec */
1684     RIL_CDMA_SignalInfoRecord            signal;
1685
1686     /* Redirecting Number Info Rec */
1687     RIL_CDMA_RedirectingNumberInfoRecord redir;
1688
1689     /* Line Control Info Rec */
1690     RIL_CDMA_LineControlInfoRecord       lineCtrl;
1691
1692     /* T53 CLIR Info Rec */
1693     RIL_CDMA_T53_CLIRInfoRecord          clir;
1694
1695     /* T53 Audio Control Info Rec */
1696     RIL_CDMA_T53_AudioControlInfoRecord  audioCtrl;
1697   } rec;
1698 } RIL_CDMA_InformationRecord;
1699
1700 #define RIL_CDMA_MAX_NUMBER_OF_INFO_RECS 10
1701
1702 typedef struct {
1703   char numberOfInfoRecs;
1704   RIL_CDMA_InformationRecord infoRec[RIL_CDMA_MAX_NUMBER_OF_INFO_RECS];
1705 } RIL_CDMA_InformationRecords;
1706
1707 /* See RIL_REQUEST_NV_READ_ITEM */
1708 typedef struct {
1709   RIL_NV_Item itemID;
1710 } RIL_NV_ReadItem;
1711
1712 /* See RIL_REQUEST_NV_WRITE_ITEM */
1713 typedef struct {
1714   RIL_NV_Item   itemID;
1715   char *        value;
1716 } RIL_NV_WriteItem;
1717
1718 typedef enum {
1719     HANDOVER_STARTED = 0,
1720     HANDOVER_COMPLETED = 1,
1721     HANDOVER_FAILED = 2,
1722     HANDOVER_CANCELED = 3
1723 } RIL_SrvccState;
1724
1725 /* hardware configuration reported to RILJ. */
1726 typedef enum {
1727    RIL_HARDWARE_CONFIG_MODEM = 0,
1728    RIL_HARDWARE_CONFIG_SIM = 1,
1729 } RIL_HardwareConfig_Type;
1730
1731 typedef enum {
1732    RIL_HARDWARE_CONFIG_STATE_ENABLED = 0,
1733    RIL_HARDWARE_CONFIG_STATE_STANDBY = 1,
1734    RIL_HARDWARE_CONFIG_STATE_DISABLED = 2,
1735 } RIL_HardwareConfig_State;
1736
1737 typedef struct {
1738    int rilModel;
1739    uint32_t rat; /* bitset - ref. RIL_RadioTechnology. */
1740    int maxVoice;
1741    int maxData;
1742    int maxStandby;
1743 } RIL_HardwareConfig_Modem;
1744
1745 typedef struct {
1746    char modemUuid[MAX_UUID_LENGTH];
1747 } RIL_HardwareConfig_Sim;
1748
1749 typedef struct {
1750   RIL_HardwareConfig_Type type;
1751   char uuid[MAX_UUID_LENGTH];
1752   RIL_HardwareConfig_State state;
1753   union {
1754      RIL_HardwareConfig_Modem modem;
1755      RIL_HardwareConfig_Sim sim;
1756   } cfg;
1757 } RIL_HardwareConfig;
1758
1759 typedef enum {
1760   SS_CFU,
1761   SS_CF_BUSY,
1762   SS_CF_NO_REPLY,
1763   SS_CF_NOT_REACHABLE,
1764   SS_CF_ALL,
1765   SS_CF_ALL_CONDITIONAL,
1766   SS_CLIP,
1767   SS_CLIR,
1768   SS_COLP,
1769   SS_COLR,
1770   SS_WAIT,
1771   SS_BAOC,
1772   SS_BAOIC,
1773   SS_BAOIC_EXC_HOME,
1774   SS_BAIC,
1775   SS_BAIC_ROAMING,
1776   SS_ALL_BARRING,
1777   SS_OUTGOING_BARRING,
1778   SS_INCOMING_BARRING
1779 } RIL_SsServiceType;
1780
1781 typedef enum {
1782   SS_ACTIVATION,
1783   SS_DEACTIVATION,
1784   SS_INTERROGATION,
1785   SS_REGISTRATION,
1786   SS_ERASURE
1787 } RIL_SsRequestType;
1788
1789 typedef enum {
1790   SS_ALL_TELE_AND_BEARER_SERVICES,
1791   SS_ALL_TELESEVICES,
1792   SS_TELEPHONY,
1793   SS_ALL_DATA_TELESERVICES,
1794   SS_SMS_SERVICES,
1795   SS_ALL_TELESERVICES_EXCEPT_SMS
1796 } RIL_SsTeleserviceType;
1797
1798 #define SS_INFO_MAX 4
1799 #define NUM_SERVICE_CLASSES 7
1800
1801 typedef struct {
1802   int numValidIndexes; /* This gives the number of valid values in cfInfo.
1803                        For example if voice is forwarded to one number and data
1804                        is forwarded to a different one then numValidIndexes will be
1805                        2 indicating total number of valid values in cfInfo.
1806                        Similarly if all the services are forwarded to the same
1807                        number then the value of numValidIndexes will be 1. */
1808
1809   RIL_CallForwardInfo cfInfo[NUM_SERVICE_CLASSES]; /* This is the response data
1810                                                       for SS request to query call
1811                                                       forward status. see
1812                                                       RIL_REQUEST_QUERY_CALL_FORWARD_STATUS */
1813 } RIL_CfData;
1814
1815 typedef struct {
1816   RIL_SsServiceType serviceType;
1817   RIL_SsRequestType requestType;
1818   RIL_SsTeleserviceType teleserviceType;
1819   int serviceClass;
1820   RIL_Errno result;
1821
1822   union {
1823     int ssInfo[SS_INFO_MAX]; /* This is the response data for most of the SS GET/SET
1824                                 RIL requests. E.g. RIL_REQUSET_GET_CLIR returns
1825                                 two ints, so first two values of ssInfo[] will be
1826                                 used for response if serviceType is SS_CLIR and
1827                                 requestType is SS_INTERROGATION */
1828
1829     RIL_CfData cfData;
1830   };
1831 } RIL_StkCcUnsolSsResponse;
1832
1833 /**
1834  * Data connection power state
1835  */
1836 typedef enum {
1837     RIL_DC_POWER_STATE_LOW      = 1,        // Low power state
1838     RIL_DC_POWER_STATE_MEDIUM   = 2,        // Medium power state
1839     RIL_DC_POWER_STATE_HIGH     = 3,        // High power state
1840     RIL_DC_POWER_STATE_UNKNOWN  = INT32_MAX // Unknown state
1841 } RIL_DcPowerStates;
1842
1843 /**
1844  * Data connection real time info
1845  */
1846 typedef struct {
1847     uint64_t                    time;       // Time in nanos as returned by ril_nano_time
1848     RIL_DcPowerStates           powerState; // Current power state
1849 } RIL_DcRtInfo;
1850
1851 /**
1852  * Data profile to modem
1853  */
1854 typedef struct {
1855     /* id of the data profile */
1856     int profileId;
1857     /* the APN to connect to */
1858     char* apn;
1859     /** one of the PDP_type values in TS 27.007 section 10.1.1.
1860      * For example, "IP", "IPV6", "IPV4V6", or "PPP".
1861      */
1862     char* protocol;
1863     /** authentication protocol used for this PDP context
1864      * (None: 0, PAP: 1, CHAP: 2, PAP&CHAP: 3)
1865      */
1866     int authType;
1867     /* the username for APN, or NULL */
1868     char* user;
1869     /* the password for APN, or NULL */
1870     char* password;
1871     /* the profile type, TYPE_COMMON-0, TYPE_3GPP-1, TYPE_3GPP2-2 */
1872     int type;
1873     /* the period in seconds to limit the maximum connections */
1874     int maxConnsTime;
1875     /* the maximum connections during maxConnsTime */
1876     int maxConns;
1877     /** the required wait time in seconds after a successful UE initiated
1878      * disconnect of a given PDN connection before the device can send
1879      * a new PDN connection request for that given PDN
1880      */
1881     int waitTime;
1882     /* true to enable the profile, 0 to disable, 1 to enable */
1883     int enabled;
1884 } RIL_DataProfileInfo;
1885
1886 typedef struct {
1887     /* id of the data profile */
1888     int profileId;
1889     /* the APN to connect to */
1890     char* apn;
1891     /** one of the PDP_type values in TS 27.007 section 10.1.1.
1892      * For example, "IP", "IPV6", "IPV4V6", or "PPP".
1893      */
1894     char* protocol;
1895     /** one of the PDP_type values in TS 27.007 section 10.1.1 used on roaming network.
1896      * For example, "IP", "IPV6", "IPV4V6", or "PPP".
1897      */
1898     char *roamingProtocol;
1899     /** authentication protocol used for this PDP context
1900      * (None: 0, PAP: 1, CHAP: 2, PAP&CHAP: 3)
1901      */
1902     int authType;
1903     /* the username for APN, or NULL */
1904     char* user;
1905     /* the password for APN, or NULL */
1906     char* password;
1907     /* the profile type, TYPE_COMMON-0, TYPE_3GPP-1, TYPE_3GPP2-2 */
1908     int type;
1909     /* the period in seconds to limit the maximum connections */
1910     int maxConnsTime;
1911     /* the maximum connections during maxConnsTime */
1912     int maxConns;
1913     /** the required wait time in seconds after a successful UE initiated
1914      * disconnect of a given PDN connection before the device can send
1915      * a new PDN connection request for that given PDN
1916      */
1917     int waitTime;
1918     /* true to enable the profile, 0 to disable, 1 to enable */
1919     int enabled;
1920     /* supported APN types bitmask. See RIL_ApnTypes for the value of each bit. */
1921     int supportedTypesBitmask;
1922     /** the bearer bitmask. See RIL_RadioAccessFamily for the value of each bit. */
1923     int bearerBitmask;
1924     /** maximum transmission unit (MTU) size in bytes */
1925     int mtu;
1926     /** the MVNO type: possible values are "imsi", "gid", "spn" */
1927     char *mvnoType;
1928     /** MVNO match data. Can be anything defined by the carrier. For example,
1929      *        SPN like: "A MOBILE", "BEN NL", etc...
1930      *        IMSI like: "302720x94", "2060188", etc...
1931      *        GID like: "4E", "33", etc...
1932      */
1933     char *mvnoMatchData;
1934 } RIL_DataProfileInfo_v15;
1935
1936 /* Tx Power Levels */
1937 #define RIL_NUM_TX_POWER_LEVELS     5
1938
1939 /**
1940  * Aggregate modem activity information
1941  */
1942 typedef struct {
1943
1944   /* total time (in ms) when modem is in a low power or
1945    * sleep state
1946    */
1947   uint32_t sleep_mode_time_ms;
1948
1949   /* total time (in ms) when modem is awake but neither
1950    * the transmitter nor receiver are active/awake */
1951   uint32_t idle_mode_time_ms;
1952
1953   /* total time (in ms) during which the transmitter is active/awake,
1954    * subdivided by manufacturer-defined device-specific
1955    * contiguous increasing ranges of transmit power between
1956    * 0 and the transmitter's maximum transmit power.
1957    */
1958   uint32_t tx_mode_time_ms[RIL_NUM_TX_POWER_LEVELS];
1959
1960   /* total time (in ms) for which receiver is active/awake and
1961    * the transmitter is inactive */
1962   uint32_t rx_mode_time_ms;
1963 } RIL_ActivityStatsInfo;
1964
1965 typedef enum {
1966     RIL_APN_TYPE_UNKNOWN      = 0x0,          // Unknown
1967     RIL_APN_TYPE_DEFAULT      = 0x1,          // APN type for default data traffic
1968     RIL_APN_TYPE_MMS          = 0x2,          // APN type for MMS traffic
1969     RIL_APN_TYPE_SUPL         = 0x4,          // APN type for SUPL assisted GPS
1970     RIL_APN_TYPE_DUN          = 0x8,          // APN type for DUN traffic
1971     RIL_APN_TYPE_HIPRI        = 0x10,         // APN type for HiPri traffic
1972     RIL_APN_TYPE_FOTA         = 0x20,         // APN type for FOTA
1973     RIL_APN_TYPE_IMS          = 0x40,         // APN type for IMS
1974     RIL_APN_TYPE_CBS          = 0x80,         // APN type for CBS
1975     RIL_APN_TYPE_IA           = 0x100,        // APN type for IA Initial Attach APN
1976     RIL_APN_TYPE_EMERGENCY    = 0x200,        // APN type for Emergency PDN. This is not an IA apn,
1977                                               // but is used for access to carrier services in an
1978                                               // emergency call situation.
1979     RIL_APN_TYPE_ALL          = 0xFFFFFFFF    // All APN types
1980 } RIL_ApnTypes;
1981
1982 typedef enum {
1983     RIL_DST_POWER_SAVE_MODE,        // Device power save mode (provided by PowerManager)
1984                                     // True indicates the device is in power save mode.
1985     RIL_DST_CHARGING_STATE,         // Device charging state (provided by BatteryManager)
1986                                     // True indicates the device is charging.
1987     RIL_DST_LOW_DATA_EXPECTED       // Low data expected mode. True indicates low data traffic
1988                                     // is expected, for example, when the device is idle
1989                                     // (e.g. not doing tethering in the background). Note
1990                                     // this doesn't mean no data is expected.
1991 } RIL_DeviceStateType;
1992
1993 typedef enum {
1994     RIL_UR_SIGNAL_STRENGTH            = 0x01, // When this bit is set, modem should always send the
1995                                               // signal strength update through
1996                                               // RIL_UNSOL_SIGNAL_STRENGTH, otherwise suppress it.
1997     RIL_UR_FULL_NETWORK_STATE         = 0x02, // When this bit is set, modem should always send
1998                                               // RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED
1999                                               // when any field in
2000                                               // RIL_REQUEST_VOICE_REGISTRATION_STATE or
2001                                               // RIL_REQUEST_DATA_REGISTRATION_STATE changes. When
2002                                               // this bit is not set, modem should suppress
2003                                               // RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED
2004                                               // only when insignificant fields change
2005                                               // (e.g. cell info).
2006                                               // Modem should continue sending
2007                                               // RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED
2008                                               // when significant fields are updated even when this
2009                                               // bit is not set. The following fields are
2010                                               // considered significant, registration state and
2011                                               // radio technology.
2012     RIL_UR_DATA_CALL_DORMANCY_CHANGED = 0x04  // When this bit is set, modem should send the data
2013                                               // call list changed unsolicited response
2014                                               // RIL_UNSOL_DATA_CALL_LIST_CHANGED whenever any
2015                                               // field in RIL_Data_Call_Response changes.
2016                                               // Otherwise modem should suppress the unsolicited
2017                                               // response when the only changed field is 'active'
2018                                               // (for data dormancy). For all other fields change,
2019                                               // modem should continue sending
2020                                               // RIL_UNSOL_DATA_CALL_LIST_CHANGED regardless this
2021                                               // bit is set or not.
2022 } RIL_UnsolicitedResponseFilter;
2023
2024 typedef struct {
2025     char * aidPtr; /* AID value, See ETSI 102.221 and 101.220*/
2026     int p2;        /* P2 parameter (described in ISO 7816-4)
2027                       P2Constants:NO_P2 if to be ignored */
2028 } RIL_OpenChannelParams;
2029
2030 /**
2031  * RIL_REQUEST_GET_SIM_STATUS
2032  *
2033  * Requests status of the SIM interface and the SIM card
2034  *
2035  * "data" is NULL
2036  *
2037  * "response" is const RIL_CardStatus_v6 *
2038  *
2039  * Valid errors:
2040  *  Must never fail
2041  */
2042 #define RIL_REQUEST_GET_SIM_STATUS 1
2043
2044 /**
2045  * RIL_REQUEST_ENTER_SIM_PIN
2046  *
2047  * Supplies SIM PIN. Only called if RIL_CardStatus has RIL_APPSTATE_PIN state
2048  *
2049  * "data" is const char **
2050  * ((const char **)data)[0] is PIN value
2051  * ((const char **)data)[1] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2052  *
2053  * "response" is int *
2054  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2055  *
2056  * Valid errors:
2057  *
2058  * SUCCESS
2059  * RADIO_NOT_AVAILABLE (radio resetting)
2060  * PASSWORD_INCORRECT
2061  */
2062
2063 #define RIL_REQUEST_ENTER_SIM_PIN 2
2064
2065 /**
2066  * RIL_REQUEST_ENTER_SIM_PUK
2067  *
2068  * Supplies SIM PUK and new PIN.
2069  *
2070  * "data" is const char **
2071  * ((const char **)data)[0] is PUK value
2072  * ((const char **)data)[1] is new PIN value
2073  * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2074  *
2075  * "response" is int *
2076  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2077  *
2078  * Valid errors:
2079  *
2080  *  SUCCESS
2081  *  RADIO_NOT_AVAILABLE (radio resetting)
2082  *  PASSWORD_INCORRECT
2083  *     (PUK is invalid)
2084  */
2085
2086 #define RIL_REQUEST_ENTER_SIM_PUK 3
2087
2088 /**
2089  * RIL_REQUEST_ENTER_SIM_PIN2
2090  *
2091  * Supplies SIM PIN2. Only called following operation where SIM_PIN2 was
2092  * returned as a a failure from a previous operation.
2093  *
2094  * "data" is const char **
2095  * ((const char **)data)[0] is PIN2 value
2096  * ((const char **)data)[1] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2097  *
2098  * "response" is int *
2099  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2100  *
2101  * Valid errors:
2102  *
2103  *  SUCCESS
2104  *  RADIO_NOT_AVAILABLE (radio resetting)
2105  *  PASSWORD_INCORRECT
2106  */
2107
2108 #define RIL_REQUEST_ENTER_SIM_PIN2 4
2109
2110 /**
2111  * RIL_REQUEST_ENTER_SIM_PUK2
2112  *
2113  * Supplies SIM PUK2 and new PIN2.
2114  *
2115  * "data" is const char **
2116  * ((const char **)data)[0] is PUK2 value
2117  * ((const char **)data)[1] is new PIN2 value
2118  * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2119  *
2120  * "response" is int *
2121  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2122  *
2123  * Valid errors:
2124  *
2125  *  SUCCESS
2126  *  RADIO_NOT_AVAILABLE (radio resetting)
2127  *  PASSWORD_INCORRECT
2128  *     (PUK2 is invalid)
2129  */
2130
2131 #define RIL_REQUEST_ENTER_SIM_PUK2 5
2132
2133 /**
2134  * RIL_REQUEST_CHANGE_SIM_PIN
2135  *
2136  * Supplies old SIM PIN and new PIN.
2137  *
2138  * "data" is const char **
2139  * ((const char **)data)[0] is old PIN value
2140  * ((const char **)data)[1] is new PIN value
2141  * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2142  *
2143  * "response" is int *
2144  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2145  *
2146  * Valid errors:
2147  *
2148  *  SUCCESS
2149  *  RADIO_NOT_AVAILABLE (radio resetting)
2150  *  PASSWORD_INCORRECT
2151  *     (old PIN is invalid)
2152  *
2153  */
2154
2155 #define RIL_REQUEST_CHANGE_SIM_PIN 6
2156
2157
2158 /**
2159  * RIL_REQUEST_CHANGE_SIM_PIN2
2160  *
2161  * Supplies old SIM PIN2 and new PIN2.
2162  *
2163  * "data" is const char **
2164  * ((const char **)data)[0] is old PIN2 value
2165  * ((const char **)data)[1] is new PIN2 value
2166  * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2167  *
2168  * "response" is int *
2169  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2170  *
2171  * Valid errors:
2172  *
2173  *  SUCCESS
2174  *  RADIO_NOT_AVAILABLE (radio resetting)
2175  *  PASSWORD_INCORRECT
2176  *     (old PIN2 is invalid)
2177  *
2178  */
2179
2180 #define RIL_REQUEST_CHANGE_SIM_PIN2 7
2181
2182 /**
2183  * RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION
2184  *
2185  * Requests that network personlization be deactivated
2186  *
2187  * "data" is const char **
2188  * ((const char **)(data))[0]] is network depersonlization code
2189  *
2190  * "response" is int *
2191  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
2192  *
2193  * Valid errors:
2194  *
2195  *  SUCCESS
2196  *  RADIO_NOT_AVAILABLE (radio resetting)
2197  *  PASSWORD_INCORRECT
2198  *     (code is invalid)
2199  */
2200
2201 #define RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION 8
2202
2203 /**
2204  * RIL_REQUEST_GET_CURRENT_CALLS
2205  *
2206  * Requests current call list
2207  *
2208  * "data" is NULL
2209  *
2210  * "response" must be a "const RIL_Call **"
2211  *
2212  * Valid errors:
2213  *
2214  *  SUCCESS
2215  *  RADIO_NOT_AVAILABLE (radio resetting)
2216  *  NO_MEMORY
2217  *      (request will be made again in a few hundred msec)
2218  */
2219
2220 #define RIL_REQUEST_GET_CURRENT_CALLS 9
2221
2222
2223 /**
2224  * RIL_REQUEST_DIAL
2225  *
2226  * Initiate voice call
2227  *
2228  * "data" is const RIL_Dial *
2229  * "response" is NULL
2230  *
2231  * This method is never used for supplementary service codes
2232  *
2233  * Valid errors:
2234  *  SUCCESS
2235  *  RADIO_NOT_AVAILABLE (radio resetting)
2236  *  DIAL_MODIFIED_TO_USSD
2237  *  DIAL_MODIFIED_TO_SS
2238  *  DIAL_MODIFIED_TO_DIAL
2239  *  INVALID_ARGUMENTS
2240  *  NO_MEMORY
2241  *  INVALID_STATE
2242  *  NO_RESOURCES
2243  *  INTERNAL_ERR
2244  *  FDN_CHECK_FAILURE
2245  *  MODEM_ERR
2246  *  NO_SUBSCRIPTION
2247  *  NO_NETWORK_FOUND
2248  *  INVALID_CALL_ID
2249  *  DEVICE_IN_USE
2250  *  MODE_NOT_SUPPORTED
2251  *  ABORTED
2252  */
2253 #define RIL_REQUEST_DIAL 10
2254
2255 /**
2256  * RIL_REQUEST_GET_IMSI
2257  *
2258  * Get the SIM IMSI
2259  *
2260  * Only valid when radio state is "RADIO_STATE_ON"
2261  *
2262  * "data" is const char **
2263  * ((const char **)data)[0] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
2264  * "response" is a const char * containing the IMSI
2265  *
2266  * Valid errors:
2267  *  SUCCESS
2268  *  RADIO_NOT_AVAILABLE (radio resetting)
2269  */
2270
2271 #define RIL_REQUEST_GET_IMSI 11
2272
2273 /**
2274  * RIL_REQUEST_HANGUP
2275  *
2276  * Hang up a specific line (like AT+CHLD=1x)
2277  *
2278  * After this HANGUP request returns, RIL should show the connection is NOT
2279  * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query.
2280  *
2281  * "data" is an int *
2282  * (int *)data)[0] contains Connection index (value of 'x' in CHLD above)
2283  *
2284  * "response" is NULL
2285  *
2286  * Valid errors:
2287  *  SUCCESS
2288  *  RADIO_NOT_AVAILABLE (radio resetting)
2289  *  INVALID_ARGUMENTS
2290  *  NO_MEMORY
2291  *  INVALID_STATE
2292  *  MODEM_ERR
2293  *  INTERNAL_ERR
2294  *  NO_MEMORY
2295  *  INVALID_CALL_ID
2296  *  INVALID_ARGUMENTS
2297  */
2298
2299 #define RIL_REQUEST_HANGUP 12
2300
2301 /**
2302  * RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND
2303  *
2304  * Hang up waiting or held (like AT+CHLD=0)
2305  *
2306  * After this HANGUP request returns, RIL should show the connection is NOT
2307  * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query.
2308  *
2309  * "data" is NULL
2310  * "response" is NULL
2311  *
2312  * Valid errors:
2313  *  SUCCESS
2314  *  RADIO_NOT_AVAILABLE (radio resetting)
2315  *  INVALID_STATE
2316  *  NO_MEMORY
2317  *  MODEM_ERR
2318  *  INTERNAL_ERR
2319  *  NO_MEMORY
2320  *  INVALID_CALL_ID
2321  *  NO_RESOURCES
2322  *  OPERATION_NOT_ALLOWED
2323  *  INVALID_ARGUMENTS
2324  */
2325
2326 #define RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND 13
2327
2328 /**
2329  * RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND
2330  *
2331  * Hang up waiting or held (like AT+CHLD=1)
2332  *
2333  * After this HANGUP request returns, RIL should show the connection is NOT
2334  * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query.
2335  *
2336  * "data" is NULL
2337  * "response" is NULL
2338  *
2339  * Valid errors:
2340  *  SUCCESS
2341  *  RADIO_NOT_AVAILABLE (radio resetting)
2342  *  INVALID_STATE
2343  *  NO_MEMORY
2344  *  MODEM_ERR
2345  *  INTERNAL_ERR
2346  *  INVALID_CALL_ID
2347  *  OPERATION_NOT_ALLOWED
2348  *  INVALID_ARGUMENTS
2349  *  NO_RESOURCES
2350  */
2351
2352 #define RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND 14
2353
2354 /**
2355  * RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE
2356  *
2357  * Switch waiting or holding call and active call (like AT+CHLD=2)
2358  *
2359  * State transitions should be is follows:
2360  *
2361  * If call 1 is waiting and call 2 is active, then if this re
2362  *
2363  *   BEFORE                               AFTER
2364  * Call 1   Call 2                 Call 1       Call 2
2365  * ACTIVE   HOLDING                HOLDING     ACTIVE
2366  * ACTIVE   WAITING                HOLDING     ACTIVE
2367  * HOLDING  WAITING                HOLDING     ACTIVE
2368  * ACTIVE   IDLE                   HOLDING     IDLE
2369  * IDLE     IDLE                   IDLE        IDLE
2370  *
2371  * "data" is NULL
2372  * "response" is NULL
2373  *
2374  * Valid errors:
2375  *  SUCCESS
2376  *  RADIO_NOT_AVAILABLE (radio resetting)
2377  *  INVALID_STATE
2378  *  NO_MEMORY
2379  *  MODEM_ERR
2380  *  INTERNAL_ERR
2381  *  INVALID_STATE
2382  *  INVALID_ARGUMENTS
2383  *  INVALID_CALL_ID
2384  *  OPERATION_NOT_ALLOWED
2385  */
2386
2387 #define RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE 15
2388 #define RIL_REQUEST_SWITCH_HOLDING_AND_ACTIVE 15
2389
2390 /**
2391  * RIL_REQUEST_CONFERENCE
2392  *
2393  * Conference holding and active (like AT+CHLD=3)
2394
2395  * "data" is NULL
2396  * "response" is NULL
2397  *
2398  * Valid errors:
2399  *  SUCCESS
2400  *  RADIO_NOT_AVAILABLE (radio resetting)
2401  *  NO_MEMORY
2402  *  MODEM_ERR
2403  *  INTERNAL_ERR
2404  *  INVALID_STATE
2405  *  INVALID_CALL_ID
2406  *  INVALID_ARGUMENTS
2407  *  OPERATION_NOT_ALLOWED
2408  */
2409 #define RIL_REQUEST_CONFERENCE 16
2410
2411 /**
2412  * RIL_REQUEST_UDUB
2413  *
2414  * Send UDUB (user determined used busy) to ringing or
2415  * waiting call answer)(RIL_BasicRequest r);
2416  *
2417  * "data" is NULL
2418  * "response" is NULL
2419  *
2420  * Valid errors:
2421  *  SUCCESS
2422  *  RADIO_NOT_AVAILABLE (radio resetting)
2423  *  INVALID_STATE
2424  *  NO_RESOURCES
2425  *  NO_MEMORY
2426  *  MODEM_ERR
2427  *  INTERNAL_ERR
2428  *  INVALID_CALL_ID
2429  *  OPERATION_NOT_ALLOWED
2430  *  INVALID_ARGUMENTS
2431  */
2432 #define RIL_REQUEST_UDUB 17
2433
2434 /**
2435  * RIL_REQUEST_LAST_CALL_FAIL_CAUSE
2436  *
2437  * Requests the failure cause code for the most recently terminated call
2438  *
2439  * "data" is NULL
2440  * "response" is a const RIL_LastCallFailCauseInfo *
2441  * RIL_LastCallFailCauseInfo contains LastCallFailCause and vendor cause.
2442  * The vendor cause code must be used for debugging purpose only.
2443  * The implementation must return one of the values of LastCallFailCause
2444  * as mentioned below.
2445  *
2446  * GSM failure reasons codes for the cause codes defined in TS 24.008 Annex H
2447  * where possible.
2448  * CDMA failure reasons codes for the possible call failure scenarios
2449  * described in the "CDMA IS-2000 Release A (C.S0005-A v6.0)" standard.
2450  * Any of the following reason codes if the call is failed or dropped due to reason
2451  * mentioned with in the braces.
2452  *
2453  *      CALL_FAIL_RADIO_OFF (Radio is OFF)
2454  *      CALL_FAIL_OUT_OF_SERVICE (No cell coverage)
2455  *      CALL_FAIL_NO_VALID_SIM (No valid SIM)
2456  *      CALL_FAIL_RADIO_INTERNAL_ERROR (Modem hit unexpected error scenario)
2457  *      CALL_FAIL_NETWORK_RESP_TIMEOUT (No response from network)
2458  *      CALL_FAIL_NETWORK_REJECT (Explicit network reject)
2459  *      CALL_FAIL_RADIO_ACCESS_FAILURE (RRC connection failure. Eg.RACH)
2460  *      CALL_FAIL_RADIO_LINK_FAILURE (Radio Link Failure)
2461  *      CALL_FAIL_RADIO_LINK_LOST (Radio link lost due to poor coverage)
2462  *      CALL_FAIL_RADIO_UPLINK_FAILURE (Radio uplink failure)
2463  *      CALL_FAIL_RADIO_SETUP_FAILURE (RRC connection setup failure)
2464  *      CALL_FAIL_RADIO_RELEASE_NORMAL (RRC connection release, normal)
2465  *      CALL_FAIL_RADIO_RELEASE_ABNORMAL (RRC connection release, abnormal)
2466  *      CALL_FAIL_ACCESS_CLASS_BLOCKED (Access class barring)
2467  *      CALL_FAIL_NETWORK_DETACH (Explicit network detach)
2468  *
2469  * OEM causes (CALL_FAIL_OEM_CAUSE_XX) must be used for debug purpose only
2470  *
2471  * If the implementation does not have access to the exact cause codes,
2472  * then it should return one of the values listed in RIL_LastCallFailCause,
2473  * as the UI layer needs to distinguish these cases for tone generation or
2474  * error notification.
2475  *
2476  * Valid errors:
2477  *  SUCCESS
2478  *  RADIO_NOT_AVAILABLE
2479  *  NO_MEMORY
2480  *
2481  * See also: RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE
2482  */
2483 #define RIL_REQUEST_LAST_CALL_FAIL_CAUSE 18
2484
2485 /**
2486  * RIL_REQUEST_SIGNAL_STRENGTH
2487  *
2488  * Requests current signal strength and associated information
2489  *
2490  * Must succeed if radio is on.
2491  *
2492  * "data" is NULL
2493  *
2494  * "response" is a const RIL_SignalStrength *
2495  *
2496  * Valid errors:
2497  *  SUCCESS
2498  *  RADIO_NOT_AVAILABLE
2499  *  NO_MEMORY
2500  *  INTERNAL_ERR
2501  *  SYSTEM_ERR
2502  *  MODEM_ERR
2503  *  NOT_PROVISIONED
2504  *  REQUEST_NOT_SUPPORTED
2505  */
2506 #define RIL_REQUEST_SIGNAL_STRENGTH 19
2507
2508 /**
2509  * RIL_REQUEST_VOICE_REGISTRATION_STATE
2510  *
2511  * Request current registration state
2512  *
2513  * "data" is NULL
2514  * "response" is a const RIL_VoiceRegistrationStateResponse *
2515  *
2516  * Valid errors:
2517  *  SUCCESS
2518  *  RADIO_NOT_AVAILABLE
2519  */
2520 #define RIL_REQUEST_VOICE_REGISTRATION_STATE 20
2521
2522 /**
2523  * RIL_REQUEST_DATA_REGISTRATION_STATE
2524  *
2525  * Request current DATA registration state
2526  *
2527  * "data" is NULL
2528  * "response" is a const RIL_DataRegistrationStateResponse *
2529  *
2530  * Valid errors:
2531  *  SUCCESS
2532  *  RADIO_NOT_AVAILABLE
2533  *  NO_MEMORY
2534  *  INTERNAL_ERR
2535  *  SYSTEM_ERR
2536  *  MODEM_ERR
2537  *  NOT_PROVISIONED
2538  *  REQUEST_NOT_SUPPORTED
2539  */
2540 #define RIL_REQUEST_DATA_REGISTRATION_STATE 21
2541
2542 /**
2543  * RIL_REQUEST_OPERATOR
2544  *
2545  * Request current operator ONS or EONS
2546  *
2547  * "data" is NULL
2548  * "response" is a "const char **"
2549  * ((const char **)response)[0] is long alpha ONS or EONS
2550  *                                  or NULL if unregistered
2551  *
2552  * ((const char **)response)[1] is short alpha ONS or EONS
2553  *                                  or NULL if unregistered
2554  * ((const char **)response)[2] is 5 or 6 digit numeric code (MCC + MNC)
2555  *                                  or NULL if unregistered
2556  *
2557  * Valid errors:
2558  *  SUCCESS
2559  *  RADIO_NOT_AVAILABLE
2560  *  NO_MEMORY
2561  *  INTERNAL_ERR
2562  *  SYSTEM_ERR
2563  *  REQUEST_NOT_SUPPORTED
2564  */
2565 #define RIL_REQUEST_OPERATOR 22
2566
2567 /**
2568  * RIL_REQUEST_RADIO_POWER
2569  *
2570  * Toggle radio on and off (for "airplane" mode)
2571  * If the radio is is turned off/on the radio modem subsystem
2572  * is expected return to an initialized state. For instance,
2573  * any voice and data calls will be terminated and all associated
2574  * lists emptied.
2575  *
2576  * "data" is int *
2577  * ((int *)data)[0] is > 0 for "Radio On"
2578  * ((int *)data)[0] is == 0 for "Radio Off"
2579  *
2580  * "response" is NULL
2581  *
2582  * Turn radio on if "on" > 0
2583  * Turn radio off if "on" == 0
2584  *
2585  * Valid errors:
2586  *  SUCCESS
2587  *  RADIO_NOT_AVAILABLE
2588  *  OPERATION_NOT_ALLOWED
2589  *  INVALID_STATE
2590  *  NO_MEMORY
2591  *  INTERNAL_ERR
2592  *  SYSTEM_ERR
2593  *  INVALID_ARGUMENTS
2594  *  MODEM_ERR
2595  *  DEVICE_IN_USE
2596  *  OPERATION_NOT_ALLOWED
2597  *  INVALID_MODEM_STATE
2598  *  REQUEST_NOT_SUPPORTED
2599  */
2600 #define RIL_REQUEST_RADIO_POWER 23
2601
2602 /**
2603  * RIL_REQUEST_DTMF
2604  *
2605  * Send a DTMF tone
2606  *
2607  * If the implementation is currently playing a tone requested via
2608  * RIL_REQUEST_DTMF_START, that tone should be cancelled and the new tone
2609  * should be played instead
2610  *
2611  * "data" is a char * containing a single character with one of 12 values: 0-9,*,#
2612  * "response" is NULL
2613  *
2614  * FIXME should this block/mute microphone?
2615  * How does this interact with local DTMF feedback?
2616  *
2617  * Valid errors:
2618  *  SUCCESS
2619  *  RADIO_NOT_AVAILABLE
2620  *  INVALID_ARGUMENTS
2621  *  NO_RESOURCES
2622  *  NO_MEMORY
2623  *  MODEM_ERR
2624  *  INTERNAL_ERR
2625  *  INVALID_CALL_ID
2626  *
2627  * See also: RIL_REQUEST_DTMF_STOP, RIL_REQUEST_DTMF_START
2628  *
2629  */
2630 #define RIL_REQUEST_DTMF 24
2631
2632 /**
2633  * RIL_REQUEST_SEND_SMS
2634  *
2635  * Send an SMS message
2636  *
2637  * "data" is const char **
2638  * ((const char **)data)[0] is SMSC address in GSM BCD format prefixed
2639  *      by a length byte (as expected by TS 27.005) or NULL for default SMSC
2640  * ((const char **)data)[1] is SMS in PDU format as an ASCII hex string
2641  *      less the SMSC address
2642  *      TP-Layer-Length is be "strlen(((const char **)data)[1])/2"
2643  *
2644  * "response" is a const RIL_SMS_Response *
2645  *
2646  * Based on the return error, caller decides to resend if sending sms
2647  * fails. SMS_SEND_FAIL_RETRY means retry (i.e. error cause is 332)
2648  *
2649  * Valid errors:
2650  *  SUCCESS
2651  *  RADIO_NOT_AVAILABLE
2652  *  SMS_SEND_FAIL_RETRY
2653  *  FDN_CHECK_FAILURE
2654  *  NETWORK_REJECT
2655  *  INVALID_STATE
2656  *  INVALID_ARGUMENTS
2657  *  NO_MEMORY
2658  *  REQUEST_RATE_LIMITED
2659  *  INVALID_SMS_FORMAT
2660  *  SYSTEM_ERR
2661  *  ENCODING_ERR
2662  *  INVALID_SMSC_ADDRESS
2663  *  MODEM_ERR
2664  *  NETWORK_ERR
2665  *  MODE_NOT_SUPPORTED
2666  *
2667  * FIXME how do we specify TP-Message-Reference if we need to resend?
2668  */
2669 #define RIL_REQUEST_SEND_SMS 25
2670
2671
2672 /**
2673  * RIL_REQUEST_SEND_SMS_EXPECT_MORE
2674  *
2675  * Send an SMS message. Identical to RIL_REQUEST_SEND_SMS,
2676  * except that more messages are expected to be sent soon. If possible,
2677  * keep SMS relay protocol link open (eg TS 27.005 AT+CMMS command)
2678  *
2679  * "data" is const char **
2680  * ((const char **)data)[0] is SMSC address in GSM BCD format prefixed
2681  *      by a length byte (as expected by TS 27.005) or NULL for default SMSC
2682  * ((const char **)data)[1] is SMS in PDU format as an ASCII hex string
2683  *      less the SMSC address
2684  *      TP-Layer-Length is be "strlen(((const char **)data)[1])/2"
2685  *
2686  * "response" is a const RIL_SMS_Response *
2687  *
2688  * Based on the return error, caller decides to resend if sending sms
2689  * fails. SMS_SEND_FAIL_RETRY means retry (i.e. error cause is 332)
2690  *
2691  * Valid errors:
2692  *  SUCCESS
2693  *  RADIO_NOT_AVAILABLE
2694  *  SMS_SEND_FAIL_RETRY
2695  *  NETWORK_REJECT
2696  *  INVALID_STATE
2697  *  INVALID_ARGUMENTS
2698  *  NO_MEMORY
2699  *  INVALID_SMS_FORMAT
2700  *  SYSTEM_ERR
2701  *  REQUEST_RATE_LIMITED
2702  *  FDN_CHECK_FAILURE
2703  *  MODEM_ERR
2704  *  NETWORK_ERR
2705  *  ENCODING_ERR
2706  *  INVALID_SMSC_ADDRESS
2707  *  MODE_NOT_SUPPORTED
2708  *
2709  */
2710 #define RIL_REQUEST_SEND_SMS_EXPECT_MORE 26
2711
2712
2713 /**
2714  * RIL_REQUEST_SETUP_DATA_CALL
2715  *
2716  * Setup a packet data connection. If RIL_Data_Call_Response_v6.status
2717  * return success it is added to the list of data calls and a
2718  * RIL_UNSOL_DATA_CALL_LIST_CHANGED is sent. The call remains in the
2719  * list until RIL_REQUEST_DEACTIVATE_DATA_CALL is issued or the
2720  * radio is powered off/on. This list is returned by RIL_REQUEST_DATA_CALL_LIST
2721  * and RIL_UNSOL_DATA_CALL_LIST_CHANGED.
2722  *
2723  * The RIL is expected to:
2724  *  - Create one data call context.
2725  *  - Create and configure a dedicated interface for the context
2726  *  - The interface must be point to point.
2727  *  - The interface is configured with one or more addresses and
2728  *    is capable of sending and receiving packets. The prefix length
2729  *    of the addresses must be /32 for IPv4 and /128 for IPv6.
2730  *  - Must NOT change the linux routing table.
2731  *  - Support up to RIL_REQUEST_DATA_REGISTRATION_STATE response[5]
2732  *    number of simultaneous data call contexts.
2733  *
2734  * "data" is a const char **
2735  * ((const char **)data)[0] Radio technology to use: 0-CDMA, 1-GSM/UMTS, 2...
2736  *                          for values above 2 this is RIL_RadioTechnology + 2.
2737  * ((const char **)data)[1] is a RIL_DataProfile (support is optional)
2738  * ((const char **)data)[2] is the APN to connect to if radio technology is GSM/UMTS. This APN will
2739  *                          override the one in the profile. NULL indicates no APN overrride.
2740  * ((const char **)data)[3] is the username for APN, or NULL
2741  * ((const char **)data)[4] is the password for APN, or NULL
2742  * ((const char **)data)[5] is the PAP / CHAP auth type. Values:
2743  *                          0 => PAP and CHAP is never performed.
2744  *                          1 => PAP may be performed; CHAP is never performed.
2745  *                          2 => CHAP may be performed; PAP is never performed.
2746  *                          3 => PAP / CHAP may be performed - baseband dependent.
2747  * ((const char **)data)[6] is the non-roaming/home connection type to request. Must be one of the
2748  *                          PDP_type values in TS 27.007 section 10.1.1.
2749  *                          For example, "IP", "IPV6", "IPV4V6", or "PPP".
2750  * ((const char **)data)[7] is the roaming connection type to request. Must be one of the
2751  *                          PDP_type values in TS 27.007 section 10.1.1.
2752  *                          For example, "IP", "IPV6", "IPV4V6", or "PPP".
2753  * ((const char **)data)[8] is the bitmask of APN type in decimal string format. The
2754  *                          bitmask will encapsulate the following values:
2755  *                          ia,mms,agps,supl,hipri,fota,dun,ims,default.
2756  * ((const char **)data)[9] is the bearer bitmask in decimal string format. Each bit is a
2757  *                          RIL_RadioAccessFamily. "0" or NULL indicates all RATs.
2758  * ((const char **)data)[10] is the boolean in string format indicating the APN setting was
2759  *                           sent to the modem through RIL_REQUEST_SET_DATA_PROFILE earlier.
2760  * ((const char **)data)[11] is the mtu size in bytes of the mobile interface to which
2761  *                           the apn is connected.
2762  * ((const char **)data)[12] is the MVNO type:
2763  *                           possible values are "imsi", "gid", "spn".
2764  * ((const char **)data)[13] is MVNO match data in string. Can be anything defined by the carrier.
2765  *                           For example,
2766  *                           SPN like: "A MOBILE", "BEN NL", etc...
2767  *                           IMSI like: "302720x94", "2060188", etc...
2768  *                           GID like: "4E", "33", etc...
2769  * ((const char **)data)[14] is the boolean string indicating data roaming is allowed or not. "1"
2770  *                           indicates data roaming is enabled by the user, "0" indicates disabled.
2771  *
2772  * "response" is a RIL_Data_Call_Response_v11
2773  *
2774  * FIXME may need way to configure QoS settings
2775  *
2776  * Valid errors:
2777  *  SUCCESS should be returned on both success and failure of setup with
2778  *  the RIL_Data_Call_Response_v6.status containing the actual status.
2779  *  For all other errors the RIL_Data_Call_Resonse_v6 is ignored.
2780  *
2781  *  Other errors could include:
2782  *    RADIO_NOT_AVAILABLE, OP_NOT_ALLOWED_BEFORE_REG_TO_NW,
2783  *    OP_NOT_ALLOWED_DURING_VOICE_CALL and REQUEST_NOT_SUPPORTED,
2784  *    INVALID_ARGUMENTS
2785  *
2786  * See also: RIL_REQUEST_DEACTIVATE_DATA_CALL
2787  */
2788 #define RIL_REQUEST_SETUP_DATA_CALL 27
2789
2790
2791 /**
2792  * RIL_REQUEST_SIM_IO
2793  *
2794  * Request SIM I/O operation.
2795  * This is similar to the TS 27.007 "restricted SIM" operation
2796  * where it assumes all of the EF selection will be done by the
2797  * callee.
2798  *
2799  * "data" is a const RIL_SIM_IO_v6 *
2800  * Please note that RIL_SIM_IO has a "PIN2" field which may be NULL,
2801  * or may specify a PIN2 for operations that require a PIN2 (eg
2802  * updating FDN records)
2803  *
2804  * "response" is a const RIL_SIM_IO_Response *
2805  *
2806  * Arguments and responses that are unused for certain
2807  * values of "command" should be ignored or set to NULL
2808  *
2809  * Valid errors:
2810  *  SUCCESS
2811  *  RADIO_NOT_AVAILABLE
2812  *  SIM_PIN2
2813  *  SIM_PUK2
2814  */
2815 #define RIL_REQUEST_SIM_IO 28
2816
2817 /**
2818  * RIL_REQUEST_SEND_USSD
2819  *
2820  * Send a USSD message
2821  *
2822  * If a USSD session already exists, the message should be sent in the
2823  * context of that session. Otherwise, a new session should be created.
2824  *
2825  * The network reply should be reported via RIL_UNSOL_ON_USSD
2826  *
2827  * Only one USSD session may exist at a time, and the session is assumed
2828  * to exist until:
2829  *   a) The android system invokes RIL_REQUEST_CANCEL_USSD
2830  *   b) The implementation sends a RIL_UNSOL_ON_USSD with a type code
2831  *      of "0" (USSD-Notify/no further action) or "2" (session terminated)
2832  *
2833  * "data" is a const char * containing the USSD request in UTF-8 format
2834  * "response" is NULL
2835  *
2836  * Valid errors:
2837  *  SUCCESS
2838  *  RADIO_NOT_AVAILABLE
2839  *  FDN_CHECK_FAILURE
2840  *  USSD_MODIFIED_TO_DIAL
2841  *  USSD_MODIFIED_TO_SS
2842  *  USSD_MODIFIED_TO_USSD
2843  *  SIM_BUSY
2844  *  OPERATION_NOT_ALLOWED
2845  *  INVALID_ARGUMENTS
2846  *  NO_MEMORY
2847  *  MODEM_ERR
2848  *  INTERNAL_ERR
2849  *  ABORTED
2850  *  SYSTEM_ERR
2851  *  INVALID_STATE
2852  *
2853  * See also: RIL_REQUEST_CANCEL_USSD, RIL_UNSOL_ON_USSD
2854  */
2855
2856 #define RIL_REQUEST_SEND_USSD 29
2857
2858 /**
2859  * RIL_REQUEST_CANCEL_USSD
2860  *
2861  * Cancel the current USSD session if one exists
2862  *
2863  * "data" is null
2864  * "response" is NULL
2865  *
2866  * Valid errors:
2867  *  SUCCESS
2868  *  RADIO_NOT_AVAILABLE
2869  *  SIM_BUSY
2870  *  OPERATION_NOT_ALLOWED
2871  *  MODEM_ERR
2872  *  INTERNAL_ERR
2873  *  NO_MEMORY
2874  *  INVALID_STATE
2875  */
2876
2877 #define RIL_REQUEST_CANCEL_USSD 30
2878
2879 /**
2880  * RIL_REQUEST_GET_CLIR
2881  *
2882  * Gets current CLIR status
2883  * "data" is NULL
2884  * "response" is int *
2885  * ((int *)data)[0] is "n" parameter from TS 27.007 7.7
2886  * ((int *)data)[1] is "m" parameter from TS 27.007 7.7
2887  *
2888  * Valid errors:
2889  *  SUCCESS
2890  *  RADIO_NOT_AVAILABLE
2891  *  SS_MODIFIED_TO_DIAL
2892  *  SS_MODIFIED_TO_USSD
2893  *  SS_MODIFIED_TO_SS
2894  *  NO_MEMORY
2895  *  MODEM_ERR
2896  *  INTERNAL_ERR
2897  *  FDN_CHECK_FAILURE
2898  *  SYSTEM_ERR
2899  */
2900 #define RIL_REQUEST_GET_CLIR 31
2901
2902 /**
2903  * RIL_REQUEST_SET_CLIR
2904  *
2905  * "data" is int *
2906  * ((int *)data)[0] is "n" parameter from TS 27.007 7.7
2907  *
2908  * "response" is NULL
2909  *
2910  * Valid errors:
2911  *  SUCCESS
2912  *  RADIO_NOT_AVAILABLE
2913  *  SS_MODIFIED_TO_DIAL
2914  *  SS_MODIFIED_TO_USSD
2915  *  SS_MODIFIED_TO_SS
2916  *  INVALID_ARGUMENTS
2917  *  SYSTEM_ERR
2918  */
2919 #define RIL_REQUEST_SET_CLIR 32
2920
2921 /**
2922  * RIL_REQUEST_QUERY_CALL_FORWARD_STATUS
2923  *
2924  * "data" is const RIL_CallForwardInfo *
2925  *
2926  * "response" is const RIL_CallForwardInfo **
2927  * "response" points to an array of RIL_CallForwardInfo *'s, one for
2928  * each distinct registered phone number.
2929  *
2930  * For example, if data is forwarded to +18005551212 and voice is forwarded
2931  * to +18005559999, then two separate RIL_CallForwardInfo's should be returned
2932  *
2933  * If, however, both data and voice are forwarded to +18005551212, then
2934  * a single RIL_CallForwardInfo can be returned with the service class
2935  * set to "data + voice = 3")
2936  *
2937  * Valid errors:
2938  *  SUCCESS
2939  *  RADIO_NOT_AVAILABLE
2940  *  SS_MODIFIED_TO_DIAL
2941  *  SS_MODIFIED_TO_USSD
2942  *  SS_MODIFIED_TO_SS
2943  *  INVALID_ARGUMENTS
2944  *  NO_MEMORY
2945  *  SYSTEM_ERR
2946  *  MODEM_ERR
2947  *  INTERNAL_ERR
2948  *  NO_MEMORY
2949  *  FDN_CHECK_FAILURE
2950  */
2951 #define RIL_REQUEST_QUERY_CALL_FORWARD_STATUS 33
2952
2953
2954 /**
2955  * RIL_REQUEST_SET_CALL_FORWARD
2956  *
2957  * Configure call forward rule
2958  *
2959  * "data" is const RIL_CallForwardInfo *
2960  * "response" is NULL
2961  *
2962  * Valid errors:
2963  *  SUCCESS
2964  *  RADIO_NOT_AVAILABLE
2965  *  SS_MODIFIED_TO_DIAL
2966  *  SS_MODIFIED_TO_USSD
2967  *  SS_MODIFIED_TO_SS
2968  *  INVALID_ARGUMENTS
2969  *  NO_MEMORY
2970  *  SYSTEM_ERR
2971  *  MODEM_ERR
2972  *  INTERNAL_ERR
2973  *  INVALID_STATE
2974  *  FDN_CHECK_FAILURE
2975  */
2976 #define RIL_REQUEST_SET_CALL_FORWARD 34
2977
2978
2979 /**
2980  * RIL_REQUEST_QUERY_CALL_WAITING
2981  *
2982  * Query current call waiting state
2983  *
2984  * "data" is const int *
2985  * ((const int *)data)[0] is the TS 27.007 service class to query.
2986  * "response" is a const int *
2987  * ((const int *)response)[0] is 0 for "disabled" and 1 for "enabled"
2988  *
2989  * If ((const int *)response)[0] is = 1, then ((const int *)response)[1]
2990  * must follow, with the TS 27.007 service class bit vector of services
2991  * for which call waiting is enabled.
2992  *
2993  * For example, if ((const int *)response)[0]  is 1 and
2994  * ((const int *)response)[1] is 3, then call waiting is enabled for data
2995  * and voice and disabled for everything else
2996  *
2997  * Valid errors:
2998  *  SUCCESS
2999  *  RADIO_NOT_AVAILABLE
3000  *  SS_MODIFIED_TO_DIAL
3001  *  SS_MODIFIED_TO_USSD
3002  *  SS_MODIFIED_TO_SS
3003  *  NO_MEMORY
3004  *  MODEM_ERR
3005  *  INTERNAL_ERR
3006  *  NO_MEMORY
3007  *  FDN_CHECK_FAILURE
3008  *  INVALID_ARGUMENTS
3009  */
3010 #define RIL_REQUEST_QUERY_CALL_WAITING 35
3011
3012
3013 /**
3014  * RIL_REQUEST_SET_CALL_WAITING
3015  *
3016  * Configure current call waiting state
3017  *
3018  * "data" is const int *
3019  * ((const int *)data)[0] is 0 for "disabled" and 1 for "enabled"
3020  * ((const int *)data)[1] is the TS 27.007 service class bit vector of
3021  *                           services to modify
3022  * "response" is NULL
3023  *
3024  * Valid errors:
3025  *  SUCCESS
3026  *  RADIO_NOT_AVAILABLE
3027  *  SS_MODIFIED_TO_DIAL
3028  *  SS_MODIFIED_TO_USSD
3029  *  SS_MODIFIED_TO_SS
3030  *  INVALID_ARGUMENTS
3031  *  NO_MEMORY
3032  *  MODEM_ERR
3033  *  INTERNAL_ERR
3034  *  INVALID_STATE
3035  *  FDN_CHECK_FAILURE
3036  */
3037 #define RIL_REQUEST_SET_CALL_WAITING 36
3038
3039 /**
3040  * RIL_REQUEST_SMS_ACKNOWLEDGE
3041  *
3042  * Acknowledge successful or failed receipt of SMS previously indicated
3043  * via RIL_UNSOL_RESPONSE_NEW_SMS
3044  *
3045  * "data" is int *
3046  * ((int *)data)[0] is 1 on successful receipt
3047  *                  (basically, AT+CNMA=1 from TS 27.005
3048  *                  is 0 on failed receipt
3049  *                  (basically, AT+CNMA=2 from TS 27.005)
3050  * ((int *)data)[1] if data[0] is 0, this contains the failure cause as defined
3051  *                  in TS 23.040, 9.2.3.22. Currently only 0xD3 (memory
3052  *                  capacity exceeded) and 0xFF (unspecified error) are
3053  *                  reported.
3054  *
3055  * "response" is NULL
3056  *
3057  * FIXME would like request that specified RP-ACK/RP-ERROR PDU
3058  *
3059  * Valid errors:
3060  *  SUCCESS
3061  *  RADIO_NOT_AVAILABLE
3062  */
3063 #define RIL_REQUEST_SMS_ACKNOWLEDGE  37
3064
3065 /**
3066  * RIL_REQUEST_GET_IMEI - DEPRECATED
3067  *
3068  * Get the device IMEI, including check digit
3069  *
3070  * The request is DEPRECATED, use RIL_REQUEST_DEVICE_IDENTITY
3071  * Valid when RadioState is not RADIO_STATE_UNAVAILABLE
3072  *
3073  * "data" is NULL
3074  * "response" is a const char * containing the IMEI
3075  *
3076  * Valid errors:
3077  *  SUCCESS
3078  *  RADIO_NOT_AVAILABLE (radio resetting)
3079  *  NO_MEMORY
3080  *  INTERNAL_ERR
3081  *  SYSTEM_ERR
3082  *  MODEM_ERR
3083  *  NOT_PROVISIONED
3084  *  REQUEST_NOT_SUPPORTED
3085  */
3086
3087 #define RIL_REQUEST_GET_IMEI 38
3088
3089 /**
3090  * RIL_REQUEST_GET_IMEISV - DEPRECATED
3091  *
3092  * Get the device IMEISV, which should be two decimal digits
3093  *
3094  * The request is DEPRECATED, use RIL_REQUEST_DEVICE_IDENTITY
3095  * Valid when RadioState is not RADIO_STATE_UNAVAILABLE
3096  *
3097  * "data" is NULL
3098  * "response" is a const char * containing the IMEISV
3099  *
3100  * Valid errors:
3101  *  SUCCESS
3102  *  RADIO_NOT_AVAILABLE (radio resetting)
3103  *  NO_MEMORY
3104  *  INTERNAL_ERR
3105  *  SYSTEM_ERR
3106  *  MODEM_ERR
3107  *  NOT_PROVISIONED
3108  *  REQUEST_NOT_SUPPORTED
3109  */
3110
3111 #define RIL_REQUEST_GET_IMEISV 39
3112
3113
3114 /**
3115  * RIL_REQUEST_ANSWER
3116  *
3117  * Answer incoming call
3118  *
3119  * Will not be called for WAITING calls.
3120  * RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE will be used in this case
3121  * instead
3122  *
3123  * "data" is NULL
3124  * "response" is NULL
3125  *
3126  * Valid errors:
3127  *  SUCCESS
3128  *  RADIO_NOT_AVAILABLE (radio resetting)
3129  *  INVALID_STATE
3130  *  NO_MEMORY
3131  *  SYSTEM_ERR
3132  *  MODEM_ERR
3133  *  INTERNAL_ERR
3134  *  INVALID_CALL_ID
3135  */
3136
3137 #define RIL_REQUEST_ANSWER 40
3138
3139 /**
3140  * RIL_REQUEST_DEACTIVATE_DATA_CALL
3141  *
3142  * Deactivate packet data connection and remove from the
3143  * data call list if SUCCESS is returned. Any other return
3144  * values should also try to remove the call from the list,
3145  * but that may not be possible. In any event a
3146  * RIL_REQUEST_RADIO_POWER off/on must clear the list. An
3147  * RIL_UNSOL_DATA_CALL_LIST_CHANGED is not expected to be
3148  * issued because of an RIL_REQUEST_DEACTIVATE_DATA_CALL.
3149  *
3150  * "data" is const char **
3151  * ((char**)data)[0] indicating CID
3152  * ((char**)data)[1] indicating Disconnect Reason
3153  *                   0 => No specific reason specified
3154  *                   1 => Radio shutdown requested
3155  *
3156  * "response" is NULL
3157  *
3158  * Valid errors:
3159  *  SUCCESS
3160  *  RADIO_NOT_AVAILABLE
3161  *  INVALID_CALL_ID
3162  *  INVALID_STATE
3163  *  INVALID_ARGUMENTS
3164  *  REQUEST_NOT_SUPPORTED
3165  *
3166  * See also: RIL_REQUEST_SETUP_DATA_CALL
3167  */
3168 #define RIL_REQUEST_DEACTIVATE_DATA_CALL 41
3169
3170 /**
3171  * RIL_REQUEST_QUERY_FACILITY_LOCK
3172  *
3173  * Query the status of a facility lock state
3174  *
3175  * "data" is const char **
3176  * ((const char **)data)[0] is the facility string code from TS 27.007 7.4
3177  *                      (eg "AO" for BAOC, "SC" for SIM lock)
3178  * ((const char **)data)[1] is the password, or "" if not required
3179  * ((const char **)data)[2] is the TS 27.007 service class bit vector of
3180  *                           services to query
3181  * ((const char **)data)[3] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
3182  *                            This is only applicable in the case of Fixed Dialing Numbers
3183  *                            (FDN) requests.
3184  *
3185  * "response" is an int *
3186  * ((const int *)response) 0 is the TS 27.007 service class bit vector of
3187  *                           services for which the specified barring facility
3188  *                           is active. "0" means "disabled for all"
3189  *
3190  *
3191  * Valid errors:
3192  *  SUCCESS
3193  *  RADIO_NOT_AVAILABLE
3194  *  SS_MODIFIED_TO_DIAL
3195  *  SS_MODIFIED_TO_USSD
3196  *  SS_MODIFIED_TO_SS
3197  *  INVALID_ARGUMENTS
3198  *  NO_MEMORY
3199  *  INTERNAL_ERR
3200  *  SYSTEM_ERR
3201  *  MODEM_ERR
3202  *  FDN_CHECK_FAILURE
3203  *
3204  */
3205 #define RIL_REQUEST_QUERY_FACILITY_LOCK 42
3206
3207 /**
3208  * RIL_REQUEST_SET_FACILITY_LOCK
3209  *
3210  * Enable/disable one facility lock
3211  *
3212  * "data" is const char **
3213  *
3214  * ((const char **)data)[0] = facility string code from TS 27.007 7.4
3215  * (eg "AO" for BAOC)
3216  * ((const char **)data)[1] = "0" for "unlock" and "1" for "lock"
3217  * ((const char **)data)[2] = password
3218  * ((const char **)data)[3] = string representation of decimal TS 27.007
3219  *                            service class bit vector. Eg, the string
3220  *                            "1" means "set this facility for voice services"
3221  * ((const char **)data)[4] = AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value.
3222  *                            This is only applicable in the case of Fixed Dialing Numbers
3223  *                            (FDN) requests.
3224  *
3225  * "response" is int *
3226  * ((int *)response)[0] is the number of retries remaining, or -1 if unknown
3227  *
3228  * Valid errors:
3229  *  SUCCESS
3230  *  RADIO_NOT_AVAILABLE
3231  *  SS_MODIFIED_TO_DIAL
3232  *  SS_MODIFIED_TO_USSD
3233  *  SS_MODIFIED_TO_SS
3234  *  INVALID_ARGUMENTS
3235  *  INTERNAL_ERR
3236  *  NO_MEMORY
3237  *  MODEM_ERR
3238  *  INVALID_STATE
3239  *  FDN_CHECK_FAILURE
3240  *
3241  */
3242 #define RIL_REQUEST_SET_FACILITY_LOCK 43
3243
3244 /**
3245  * RIL_REQUEST_CHANGE_BARRING_PASSWORD
3246  *
3247  * Change call barring facility password
3248  *
3249  * "data" is const char **
3250  *
3251  * ((const char **)data)[0] = facility string code from TS 27.007 7.4
3252  * (eg "AO" for BAOC)
3253  * ((const char **)data)[1] = old password
3254  * ((const char **)data)[2] = new password
3255  *
3256  * "response" is NULL
3257  *
3258  * Valid errors:
3259  *  SUCCESS
3260  *  RADIO_NOT_AVAILABLE
3261  *  SS_MODIFIED_TO_DIAL
3262  *  SS_MODIFIED_TO_USSD
3263  *  SS_MODIFIED_TO_SS
3264  *  INVALID_ARGUMENTS
3265  *  NO_MEMORY
3266  *  MODEM_ERR
3267  *  INTERNAL_ERR
3268  *  SYSTEM_ERR
3269  *  FDN_CHECK_FAILURE
3270  *
3271  */
3272 #define RIL_REQUEST_CHANGE_BARRING_PASSWORD 44
3273
3274 /**
3275  * RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE
3276  *
3277  * Query current network selectin mode
3278  *
3279  * "data" is NULL
3280  *
3281  * "response" is int *
3282  * ((const int *)response)[0] is
3283  *     0 for automatic selection
3284  *     1 for manual selection
3285  *
3286  * Valid errors:
3287  *  SUCCESS
3288  *  RADIO_NOT_AVAILABLE
3289  *  NO_MEMORY
3290  *  INTERNAL_ERR
3291  *  SYSTEM_ERR
3292  *  INVALID_ARGUMENTS
3293  *  MODEM_ERR
3294  *  REQUEST_NOT_SUPPORTED
3295  *
3296  */
3297 #define RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE 45
3298
3299 /**
3300  * RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC
3301  *
3302  * Specify that the network should be selected automatically
3303  *
3304  * "data" is NULL
3305  * "response" is NULL
3306  *
3307  * This request must not respond until the new operator is selected
3308  * and registered
3309  *
3310  * Valid errors:
3311  *  SUCCESS
3312  *  RADIO_NOT_AVAILABLE
3313  *  ILLEGAL_SIM_OR_ME
3314  *  OPERATION_NOT_ALLOWED
3315  *  NO_MEMORY
3316  *  INTERNAL_ERR
3317  *  SYSTEM_ERR
3318  *  INVALID_ARGUMENTS
3319  *  MODEM_ERR
3320  *  REQUEST_NOT_SUPPORTED
3321  *
3322  * Note: Returns ILLEGAL_SIM_OR_ME when the failure is permanent and
3323  *       no retries needed, such as illegal SIM or ME.
3324  *
3325  */
3326 #define RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC 46
3327
3328 /**
3329  * RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL
3330  *
3331  * Manually select a specified network.
3332  *
3333  * "data" is const char * specifying MCCMNC of network to select (eg "310170")
3334  * "response" is NULL
3335  *
3336  * This request must not respond until the new operator is selected
3337  * and registered
3338  *
3339  * Valid errors:
3340  *  SUCCESS
3341  *  RADIO_NOT_AVAILABLE
3342  *  ILLEGAL_SIM_OR_ME
3343  *  OPERATION_NOT_ALLOWED
3344  *  INVALID_STATE
3345  *  NO_MEMORY
3346  *  INTERNAL_ERR
3347  *  SYSTEM_ERR
3348  *  INVALID_ARGUMENTS
3349  *  MODEM_ERR
3350  *  REQUEST_NOT_SUPPORTED
3351  *
3352  * Note: Returns ILLEGAL_SIM_OR_ME when the failure is permanent and
3353  *       no retries needed, such as illegal SIM or ME.
3354  *
3355  */
3356 #define RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL 47
3357
3358 /**
3359  * RIL_REQUEST_QUERY_AVAILABLE_NETWORKS
3360  *
3361  * Scans for available networks
3362  *
3363  * "data" is NULL
3364  * "response" is const char ** that should be an array of n*4 strings, where
3365  *    n is the number of available networks
3366  * For each available network:
3367  *
3368  * ((const char **)response)[n+0] is long alpha ONS or EONS
3369  * ((const char **)response)[n+1] is short alpha ONS or EONS
3370  * ((const char **)response)[n+2] is 5 or 6 digit numeric code (MCC + MNC)
3371  * ((const char **)response)[n+3] is a string value of the status:
3372  *           "unknown"
3373  *           "available"
3374  *           "current"
3375  *           "forbidden"
3376  *
3377  * Valid errors:
3378  *  SUCCESS
3379  *  RADIO_NOT_AVAILABLE
3380  *  OPERATION_NOT_ALLOWED
3381  *  ABORTED
3382  *  DEVICE_IN_USE
3383  *  INTERNAL_ERR
3384  *  NO_MEMORY
3385  *  MODEM_ERR
3386  *  REQUEST_NOT_SUPPORTED
3387  *  CANCELLED
3388  *  OPERATION_NOT_ALLOWED
3389  *
3390  */
3391 #define RIL_REQUEST_QUERY_AVAILABLE_NETWORKS 48
3392
3393 /**
3394  * RIL_REQUEST_DTMF_START
3395  *
3396  * Start playing a DTMF tone. Continue playing DTMF tone until
3397  * RIL_REQUEST_DTMF_STOP is received
3398  *
3399  * If a RIL_REQUEST_DTMF_START is received while a tone is currently playing,
3400  * it should cancel the previous tone and play the new one.
3401  *
3402  * "data" is a char *
3403  * ((char *)data)[0] is a single character with one of 12 values: 0-9,*,#
3404  * "response" is NULL
3405  *
3406  * Valid errors:
3407  *  SUCCESS
3408  *  RADIO_NOT_AVAILABLE
3409  *  INVALID_ARGUMENTS
3410  *  NO_RESOURCES
3411  *  NO_MEMORY
3412  *  SYSTEM_ERR
3413  *  MODEM_ERR
3414  *  INTERNAL_ERR
3415  *  INVALID_CALL_ID
3416  *
3417  * See also: RIL_REQUEST_DTMF, RIL_REQUEST_DTMF_STOP
3418  */
3419 #define RIL_REQUEST_DTMF_START 49
3420
3421 /**
3422  * RIL_REQUEST_DTMF_STOP
3423  *
3424  * Stop playing a currently playing DTMF tone.
3425  *
3426  * "data" is NULL
3427  * "response" is NULL
3428  *
3429  * Valid errors:
3430  *  SUCCESS
3431  *  RADIO_NOT_AVAILABLE
3432  *  OPERATION_NOT_ALLOWED
3433  *  NO_RESOURCES
3434  *  NO_MEMORY
3435  *  INVALID_ARGUMENTS
3436  *  SYSTEM_ERR
3437  *  MODEM_ERR
3438  *  INTERNAL_ERR
3439  *  INVALID_CALL_ID
3440  *
3441  * See also: RIL_REQUEST_DTMF, RIL_REQUEST_DTMF_START
3442  */
3443 #define RIL_REQUEST_DTMF_STOP 50
3444
3445 /**
3446  * RIL_REQUEST_BASEBAND_VERSION
3447  *
3448  * Return string value indicating baseband version, eg
3449  * response from AT+CGMR
3450  *
3451  * "data" is NULL
3452  * "response" is const char * containing version string for log reporting
3453  *
3454  * Valid errors:
3455  *  SUCCESS
3456  *  RADIO_NOT_AVAILABLE
3457  *  EMPTY_RECORD
3458  *  NO_MEMORY
3459  *  INTERNAL_ERR
3460  *  SYSTEM_ERR
3461  *  MODEM_ERR
3462  *  NOT_PROVISIONED
3463  *  REQUEST_NOT_SUPPORTED
3464  *
3465  */
3466 #define RIL_REQUEST_BASEBAND_VERSION 51
3467
3468 /**
3469  * RIL_REQUEST_SEPARATE_CONNECTION
3470  *
3471  * Separate a party from a multiparty call placing the multiparty call
3472  * (less the specified party) on hold and leaving the specified party
3473  * as the only other member of the current (active) call
3474  *
3475  * Like AT+CHLD=2x
3476  *
3477  * See TS 22.084 1.3.8.2 (iii)
3478  * TS 22.030 6.5.5 "Entering "2X followed by send"
3479  * TS 27.007 "AT+CHLD=2x"
3480  *
3481  * "data" is an int *
3482  * (int *)data)[0] contains Connection index (value of 'x' in CHLD above) "response" is NULL
3483  *
3484  * "response" is NULL
3485  *
3486  * Valid errors:
3487  *  SUCCESS
3488  *  RADIO_NOT_AVAILABLE (radio resetting)
3489  *  INVALID_ARGUMENTS
3490  *  INVALID_STATE
3491  *  NO_RESOURCES
3492  *  NO_MEMORY
3493  *  SYSTEM_ERR
3494  *  MODEM_ERR
3495  *  INTERNAL_ERR
3496  *  INVALID_CALL_ID
3497  *  INVALID_STATE
3498  *  OPERATION_NOT_ALLOWED
3499  */
3500 #define RIL_REQUEST_SEPARATE_CONNECTION 52
3501
3502
3503 /**
3504  * RIL_REQUEST_SET_MUTE
3505  *
3506  * Turn on or off uplink (microphone) mute.
3507  *
3508  * Will only be sent while voice call is active.
3509  * Will always be reset to "disable mute" when a new voice call is initiated
3510  *
3511  * "data" is an int *
3512  * (int *)data)[0] is 1 for "enable mute" and 0 for "disable mute"
3513  *
3514  * "response" is NULL
3515  *
3516  * Valid errors:
3517  *  SUCCESS
3518  *  RADIO_NOT_AVAILABLE (radio resetting)
3519  *  INVALID_ARGUMENTS
3520  *  NO_MEMORY
3521  *  REQUEST_RATE_LIMITED
3522  */
3523
3524 #define RIL_REQUEST_SET_MUTE 53
3525
3526 /**
3527  * RIL_REQUEST_GET_MUTE
3528  *
3529  * Queries the current state of the uplink mute setting
3530  *
3531  * "data" is NULL
3532  * "response" is an int *
3533  * (int *)response)[0] is 1 for "mute enabled" and 0 for "mute disabled"
3534  *
3535  * Valid errors:
3536  *  SUCCESS
3537  *  RADIO_NOT_AVAILABLE (radio resetting)
3538  *  SS_MODIFIED_TO_DIAL
3539  *  SS_MODIFIED_TO_USSD
3540  *  SS_MODIFIED_TO_SS
3541  *  NO_MEMORY
3542  *  REQUEST_RATE_LIMITED
3543  */
3544
3545 #define RIL_REQUEST_GET_MUTE 54
3546
3547 /**
3548  * RIL_REQUEST_QUERY_CLIP
3549  *
3550  * Queries the status of the CLIP supplementary service
3551  *
3552  * (for MMI code "*#30#")
3553  *
3554  * "data" is NULL
3555  * "response" is an int *
3556  * (int *)response)[0] is 1 for "CLIP provisioned"
3557  *                           and 0 for "CLIP not provisioned"
3558  *                           and 2 for "unknown, e.g. no network etc"
3559  *
3560  * Valid errors:
3561  *  SUCCESS
3562  *  RADIO_NOT_AVAILABLE (radio resetting)
3563  *  NO_MEMORY
3564  *  SYSTEM_ERR
3565  *  MODEM_ERR
3566  *  INTERNAL_ERR
3567  *  FDN_CHECK_FAILURE
3568  */
3569
3570 #define RIL_REQUEST_QUERY_CLIP 55
3571
3572 /**
3573  * RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE - Deprecated use the status
3574  * field in RIL_Data_Call_Response_v6.
3575  *
3576  * Requests the failure cause code for the most recently failed PDP
3577  * context or CDMA data connection active
3578  * replaces RIL_REQUEST_LAST_PDP_FAIL_CAUSE
3579  *
3580  * "data" is NULL
3581  *
3582  * "response" is a "int *"
3583  * ((int *)response)[0] is an integer cause code defined in TS 24.008
3584  *   section 6.1.3.1.3 or close approximation
3585  *
3586  * If the implementation does not have access to the exact cause codes,
3587  * then it should return one of the values listed in
3588  * RIL_DataCallFailCause, as the UI layer needs to distinguish these
3589  * cases for error notification
3590  * and potential retries.
3591  *
3592  * Valid errors:
3593  *  SUCCESS
3594  *  RADIO_NOT_AVAILABLE
3595  *
3596  * See also: RIL_REQUEST_LAST_CALL_FAIL_CAUSE
3597  *
3598  * Deprecated use the status field in RIL_Data_Call_Response_v6.
3599  */
3600
3601 #define RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE 56
3602
3603 /**
3604  * RIL_REQUEST_DATA_CALL_LIST
3605  *
3606  * Returns the data call list. An entry is added when a
3607  * RIL_REQUEST_SETUP_DATA_CALL is issued and removed on a
3608  * RIL_REQUEST_DEACTIVATE_DATA_CALL. The list is emptied
3609  * when RIL_REQUEST_RADIO_POWER off/on is issued.
3610  *
3611  * "data" is NULL
3612  * "response" is an array of RIL_Data_Call_Response_v6
3613  *
3614  * Valid errors:
3615  *  SUCCESS
3616  *  RADIO_NOT_AVAILABLE (radio resetting)
3617  *
3618  * See also: RIL_UNSOL_DATA_CALL_LIST_CHANGED
3619  */
3620
3621 #define RIL_REQUEST_DATA_CALL_LIST 57
3622
3623 /**
3624  * RIL_REQUEST_RESET_RADIO - DEPRECATED
3625  *
3626  * Request a radio reset. The RIL implementation may postpone
3627  * the reset until after this request is responded to if the baseband
3628  * is presently busy.
3629  *
3630  * The request is DEPRECATED, use RIL_REQUEST_RADIO_POWER
3631  *
3632  * "data" is NULL
3633  * "response" is NULL
3634  *
3635  * Valid errors:
3636  *  SUCCESS
3637  *  RADIO_NOT_AVAILABLE (radio resetting)
3638  *  REQUEST_NOT_SUPPORTED
3639  */
3640
3641 #define RIL_REQUEST_RESET_RADIO 58
3642
3643 /**
3644  * RIL_REQUEST_OEM_HOOK_RAW
3645  *
3646  * This request reserved for OEM-specific uses. It passes raw byte arrays
3647  * back and forth.
3648  *
3649  * It can be invoked on the Java side from
3650  * com.android.internal.telephony.Phone.invokeOemRilRequestRaw()
3651  *
3652  * "data" is a char * of bytes copied from the byte[] data argument in java
3653  * "response" is a char * of bytes that will returned via the
3654  * caller's "response" Message here:
3655  * (byte[])(((AsyncResult)response.obj).result)
3656  *
3657  * An error response here will result in
3658  * (((AsyncResult)response.obj).result) == null and
3659  * (((AsyncResult)response.obj).exception) being an instance of
3660  * com.android.internal.telephony.gsm.CommandException
3661  *
3662  * Valid errors:
3663  *  All
3664  */
3665
3666 #define RIL_REQUEST_OEM_HOOK_RAW 59
3667
3668 /**
3669  * RIL_REQUEST_OEM_HOOK_STRINGS
3670  *
3671  * This request reserved for OEM-specific uses. It passes strings
3672  * back and forth.
3673  *
3674  * It can be invoked on the Java side from
3675  * com.android.internal.telephony.Phone.invokeOemRilRequestStrings()
3676  *
3677  * "data" is a const char **, representing an array of null-terminated UTF-8
3678  * strings copied from the "String[] strings" argument to
3679  * invokeOemRilRequestStrings()
3680  *
3681  * "response" is a const char **, representing an array of null-terminated UTF-8
3682  * stings that will be returned via the caller's response message here:
3683  *
3684  * (String[])(((AsyncResult)response.obj).result)
3685  *
3686  * An error response here will result in
3687  * (((AsyncResult)response.obj).result) == null and
3688  * (((AsyncResult)response.obj).exception) being an instance of
3689  * com.android.internal.telephony.gsm.CommandException
3690  *
3691  * Valid errors:
3692  *  All
3693  */
3694
3695 #define RIL_REQUEST_OEM_HOOK_STRINGS 60
3696
3697 /**
3698  * RIL_REQUEST_SCREEN_STATE - DEPRECATED
3699  *
3700  * Indicates the current state of the screen.  When the screen is off, the
3701  * RIL should notify the baseband to suppress certain notifications (eg,
3702  * signal strength and changes in LAC/CID or BID/SID/NID/latitude/longitude)
3703  * in an effort to conserve power.  These notifications should resume when the
3704  * screen is on.
3705  *
3706  * Note this request is deprecated. Use RIL_REQUEST_SEND_DEVICE_STATE to report the device state
3707  * to the modem and use RIL_REQUEST_SET_UNSOLICITED_RESPONSE_FILTER to turn on/off unsolicited
3708  * response from the modem in different scenarios.
3709  *
3710  * "data" is int *
3711  * ((int *)data)[0] is == 1 for "Screen On"
3712  * ((int *)data)[0] is == 0 for "Screen Off"
3713  *
3714  * "response" is NULL
3715  *
3716  * Valid errors:
3717  *  SUCCESS
3718  *  NO_MEMORY
3719  *  INTERNAL_ERR
3720  *  SYSTEM_ERR
3721  *  INVALID_ARGUMENTS
3722  *  REQUEST_NOT_SUPPORTED
3723  */
3724 #define RIL_REQUEST_SCREEN_STATE 61
3725
3726
3727 /**
3728  * RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION
3729  *
3730  * Enables/disables supplementary service related notifications
3731  * from the network.
3732  *
3733  * Notifications are reported via RIL_UNSOL_SUPP_SVC_NOTIFICATION.
3734  *
3735  * "data" is int *
3736  * ((int *)data)[0] is == 1 for notifications enabled
3737  * ((int *)data)[0] is == 0 for notifications disabled
3738  *
3739  * "response" is NULL
3740  *
3741  * Valid errors:
3742  *  SUCCESS
3743  *  RADIO_NOT_AVAILABLE
3744  *  SIM_BUSY
3745  *  INVALID_ARGUMENTS
3746  *  NO_MEMORY
3747  *  SYSTEM_ERR
3748  *  MODEM_ERR
3749  *  INTERNAL_ERR
3750  *
3751  * See also: RIL_UNSOL_SUPP_SVC_NOTIFICATION.
3752  */
3753 #define RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION 62
3754
3755 /**
3756  * RIL_REQUEST_WRITE_SMS_TO_SIM
3757  *
3758  * Stores a SMS message to SIM memory.
3759  *
3760  * "data" is RIL_SMS_WriteArgs *
3761  *
3762  * "response" is int *
3763  * ((const int *)response)[0] is the record index where the message is stored.
3764  *
3765  * Valid errors:
3766  *  SUCCESS
3767  *  SIM_FULL
3768  *  INVALID_ARGUMENTS
3769  *  INVALID_SMS_FORMAT
3770  *  INTERNAL_ERR
3771  *  MODEM_ERR
3772  *  ENCODING_ERR
3773  *  NO_MEMORY
3774  *  NO_RESOURCES
3775  *  INVALID_MODEM_STATE
3776  *  MODE_NOT_SUPPORTED
3777  *  INVALID_SMSC_ADDRESS
3778  *
3779  */
3780 #define RIL_REQUEST_WRITE_SMS_TO_SIM 63
3781
3782 /**
3783  * RIL_REQUEST_DELETE_SMS_ON_SIM
3784  *
3785  * Deletes a SMS message from SIM memory.
3786  *
3787  * "data" is int  *
3788  * ((int *)data)[0] is the record index of the message to delete.
3789  *
3790  * "response" is NULL
3791  *
3792  * Valid errors:
3793  *  SUCCESS
3794  *  SIM_FULL
3795  *  INVALID_ARGUMENTS
3796  *  NO_MEMORY
3797  *  REQUEST_RATE_LIMITED
3798  *  SYSTEM_ERR
3799  *  MODEM_ERR
3800  *  NO_SUCH_ENTRY
3801  *
3802  */
3803 #define RIL_REQUEST_DELETE_SMS_ON_SIM 64
3804
3805 /**
3806  * RIL_REQUEST_SET_BAND_MODE
3807  *
3808  * Assign a specified band for RF configuration.
3809  *
3810  * "data" is int *
3811  * ((int *)data)[0] is a RIL_RadioBandMode
3812  *
3813  * "response" is NULL
3814  *
3815  * Valid errors:
3816  *  SUCCESS
3817  *  RADIO_NOT_AVAILABLE
3818  *  OPERATION_NOT_ALLOWED
3819  *  NO_MEMORY
3820  *  INTERNAL_ERR
3821  *  SYSTEM_ERR
3822  *  INVALID_ARGUMENTS
3823  *  MODEM_ERR
3824  *  REQUEST_NOT_SUPPORTED
3825  *
3826  * See also: RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE
3827  */
3828 #define RIL_REQUEST_SET_BAND_MODE 65
3829
3830 /**
3831  * RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE
3832  *
3833  * Query the list of band mode supported by RF.
3834  *
3835  * "data" is NULL
3836  *
3837  * "response" is int *
3838  * "response" points to an array of int's, the int[0] is the size of array;
3839  * subsequent values are a list of RIL_RadioBandMode listing supported modes.
3840  *
3841  * Valid errors:
3842  *  SUCCESS
3843  *  RADIO_NOT_AVAILABLE
3844  *  NO_MEMORY
3845  *  INTERNAL_ERR
3846  *  SYSTEM_ERR
3847  *  MODEM_ERR
3848  *  REQUEST_NOT_SUPPORTED
3849  *
3850  * See also: RIL_REQUEST_SET_BAND_MODE
3851  */
3852 #define RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE 66
3853
3854 /**
3855  * RIL_REQUEST_STK_GET_PROFILE
3856  *
3857  * Requests the profile of SIM tool kit.
3858  * The profile indicates the SAT/USAT features supported by ME.
3859  * The SAT/USAT features refer to 3GPP TS 11.14 and 3GPP TS 31.111
3860  *
3861  * "data" is NULL
3862  *
3863  * "response" is a const char * containing SAT/USAT profile
3864  * in hexadecimal format string starting with first byte of terminal profile
3865  *
3866  * Valid errors:
3867  *  RIL_E_SUCCESS
3868  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
3869  */
3870 #define RIL_REQUEST_STK_GET_PROFILE 67
3871
3872 /**
3873  * RIL_REQUEST_STK_SET_PROFILE
3874  *
3875  * Download the STK terminal profile as part of SIM initialization
3876  * procedure
3877  *
3878  * "data" is a const char * containing SAT/USAT profile
3879  * in hexadecimal format string starting with first byte of terminal profile
3880  *
3881  * "response" is NULL
3882  *
3883  * Valid errors:
3884  *  RIL_E_SUCCESS
3885  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
3886  */
3887 #define RIL_REQUEST_STK_SET_PROFILE 68
3888
3889 /**
3890  * RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND
3891  *
3892  * Requests to send a SAT/USAT envelope command to SIM.
3893  * The SAT/USAT envelope command refers to 3GPP TS 11.14 and 3GPP TS 31.111
3894  *
3895  * "data" is a const char * containing SAT/USAT command
3896  * in hexadecimal format string starting with command tag
3897  *
3898  * "response" is a const char * containing SAT/USAT response
3899  * in hexadecimal format string starting with first byte of response
3900  * (May be NULL)
3901  *
3902  * Valid errors:
3903  *  RIL_E_SUCCESS
3904  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
3905  *  SIM_BUSY
3906  *  OPERATION_NOT_ALLOWED
3907  */
3908 #define RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND 69
3909
3910 /**
3911  * RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE
3912  *
3913  * Requests to send a terminal response to SIM for a received
3914  * proactive command
3915  *
3916  * "data" is a const char * containing SAT/USAT response
3917  * in hexadecimal format string starting with first byte of response data
3918  *
3919  * "response" is NULL
3920  *
3921  * Valid errors:
3922  *  RIL_E_SUCCESS
3923  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
3924  *  RIL_E_OPERATION_NOT_ALLOWED
3925  */
3926 #define RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE 70
3927
3928 /**
3929  * RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM
3930  *
3931  * When STK application gets RIL_UNSOL_STK_CALL_SETUP, the call actually has
3932  * been initialized by ME already. (We could see the call has been in the 'call
3933  * list') So, STK application needs to accept/reject the call according as user
3934  * operations.
3935  *
3936  * "data" is int *
3937  * ((int *)data)[0] is > 0 for "accept" the call setup
3938  * ((int *)data)[0] is == 0 for "reject" the call setup
3939  *
3940  * "response" is NULL
3941  *
3942  * Valid errors:
3943  *  RIL_E_SUCCESS
3944  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
3945  *  RIL_E_OPERATION_NOT_ALLOWED
3946  */
3947 #define RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM 71
3948
3949 /**
3950  * RIL_REQUEST_EXPLICIT_CALL_TRANSFER
3951  *
3952  * Connects the two calls and disconnects the subscriber from both calls.
3953  *
3954  * "data" is NULL
3955  * "response" is NULL
3956  *
3957  * Valid errors:
3958  *  SUCCESS
3959  *  RADIO_NOT_AVAILABLE (radio resetting)
3960  *  INVALID_STATE
3961  *  NO_RESOURCES
3962  *  NO_MEMORY
3963  *  INVALID_ARGUMENTS
3964  *  SYSTEM_ERR
3965  *  MODEM_ERR
3966  *  INTERNAL_ERR
3967  *  INVALID_CALL_ID
3968  *  INVALID_STATE
3969  *  OPERATION_NOT_ALLOWED
3970  */
3971 #define RIL_REQUEST_EXPLICIT_CALL_TRANSFER 72
3972
3973 /**
3974  * RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE
3975  *
3976  * Requests to set the preferred network type for searching and registering
3977  * (CS/PS domain, RAT, and operation mode)
3978  *
3979  * "data" is int * which is RIL_PreferredNetworkType
3980  *
3981  * "response" is NULL
3982  *
3983  * Valid errors:
3984  *  SUCCESS
3985  *  RADIO_NOT_AVAILABLE (radio resetting)
3986  *  OPERATION_NOT_ALLOWED
3987  *  MODE_NOT_SUPPORTED
3988  *  NO_MEMORY
3989  *  INTERNAL_ERR
3990  *  SYSTEM_ERR
3991  *  INVALID_ARGUMENTS
3992  *  MODEM_ERR
3993  *  REQUEST_NOT_SUPPORTED
3994  */
3995 #define RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE 73
3996
3997 /**
3998  * RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE
3999  *
4000  * Query the preferred network type (CS/PS domain, RAT, and operation mode)
4001  * for searching and registering
4002  *
4003  * "data" is NULL
4004  *
4005  * "response" is int *
4006  * ((int *)reponse)[0] is == RIL_PreferredNetworkType
4007  *
4008  * Valid errors:
4009  *  SUCCESS
4010  *  RADIO_NOT_AVAILABLE
4011  *  NO_MEMORY
4012  *  INTERNAL_ERR
4013  *  SYSTEM_ERR
4014  *  INVALID_ARGUMENTS
4015  *  MODEM_ERR
4016  *  REQUEST_NOT_SUPPORTED
4017  *
4018  * See also: RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE
4019  */
4020 #define RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE 74
4021
4022 /**
4023  * RIL_REQUEST_NEIGHBORING_CELL_IDS
4024  *
4025  * Request neighboring cell id in GSM network
4026  *
4027  * "data" is NULL
4028  * "response" must be a " const RIL_NeighboringCell** "
4029  *
4030  * Valid errors:
4031  *  SUCCESS
4032  *  RADIO_NOT_AVAILABLE
4033  *  NO_MEMORY
4034  *  INTERNAL_ERR
4035  *  SYSTEM_ERR
4036  *  MODEM_ERR
4037  *  NO_NETWORK_FOUND
4038  *  REQUEST_NOT_SUPPORTED
4039  */
4040 #define RIL_REQUEST_GET_NEIGHBORING_CELL_IDS 75
4041
4042 /**
4043  * RIL_REQUEST_SET_LOCATION_UPDATES
4044  *
4045  * Enables/disables network state change notifications due to changes in
4046  * LAC and/or CID (for GSM) or BID/SID/NID/latitude/longitude (for CDMA).
4047  * Basically +CREG=2 vs. +CREG=1 (TS 27.007).
4048  *
4049  * Note:  The RIL implementation should default to "updates enabled"
4050  * when the screen is on and "updates disabled" when the screen is off.
4051  *
4052  * "data" is int *
4053  * ((int *)data)[0] is == 1 for updates enabled (+CREG=2)
4054  * ((int *)data)[0] is == 0 for updates disabled (+CREG=1)
4055  *
4056  * "response" is NULL
4057  *
4058  * Valid errors:
4059  *  SUCCESS
4060  *  RADIO_NOT_AVAILABLE
4061  *  NO_MEMORY
4062  *  INTERNAL_ERR
4063  *  SYSTEM_ERR
4064  *  INVALID_ARGUMENTS
4065  *  MODEM_ERR
4066  *  REQUEST_NOT_SUPPORTED
4067  *
4068  * See also: RIL_REQUEST_SCREEN_STATE, RIL_UNSOL_RESPONSE_NETWORK_STATE_CHANGED
4069  */
4070 #define RIL_REQUEST_SET_LOCATION_UPDATES 76
4071
4072 /**
4073  * RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE
4074  *
4075  * Request to set the location where the CDMA subscription shall
4076  * be retrieved
4077  *
4078  * "data" is int *
4079  * ((int *)data)[0] is == RIL_CdmaSubscriptionSource
4080  *
4081  * "response" is NULL
4082  *
4083  * Valid errors:
4084  *  SUCCESS
4085  *  RADIO_NOT_AVAILABLE
4086  *  SIM_ABSENT
4087  *  SUBSCRIPTION_NOT_AVAILABLE
4088  *
4089  * See also: RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE
4090  */
4091 #define RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE 77
4092
4093 /**
4094  * RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE
4095  *
4096  * Request to set the roaming preferences in CDMA
4097  *
4098  * "data" is int *
4099  * ((int *)data)[0] is == 0 for Home Networks only, as defined in PRL
4100  * ((int *)data)[0] is == 1 for Roaming on Affiliated networks, as defined in PRL
4101  * ((int *)data)[0] is == 2 for Roaming on Any Network, as defined in the PRL
4102  *
4103  * "response" is NULL
4104  *
4105  * Valid errors:
4106  *  SUCCESS
4107  *  RADIO_NOT_AVAILABLE
4108  *  NO_MEMORY
4109  *  INTERNAL_ERR
4110  *  SYSTEM_ERR
4111  *  INVALID_ARGUMENTS
4112  *  MODEM_ERR
4113  *  REQUEST_NOT_SUPPORTED
4114  *  OPERATION_NOT_ALLOWED
4115  */
4116 #define RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE 78
4117
4118 /**
4119  * RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE
4120  *
4121  * Request the actual setting of the roaming preferences in CDMA in the modem
4122  *
4123  * "data" is NULL
4124  *
4125  * "response" is int *
4126  * ((int *)response)[0] is == 0 for Home Networks only, as defined in PRL
4127  * ((int *)response)[0] is == 1 for Roaming on Affiliated networks, as defined in PRL
4128  * ((int *)response)[0] is == 2 for Roaming on Any Network, as defined in the PRL
4129  *
4130  * "response" is NULL
4131  *
4132  * Valid errors:
4133  *  SUCCESS
4134  *  RADIO_NOT_AVAILABLE
4135  *  NO_MEMORY
4136  *  INTERNAL_ERR
4137  *  SYSTEM_ERR
4138  *  INVALID_ARGUMENTS
4139  *  MODEM_ERR
4140  *  REQUEST_NOT_SUPPORTED
4141  */
4142 #define RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE 79
4143
4144 /**
4145  * RIL_REQUEST_SET_TTY_MODE
4146  *
4147  * Request to set the TTY mode
4148  *
4149  * "data" is int *
4150  * ((int *)data)[0] is == 0 for TTY off
4151  * ((int *)data)[0] is == 1 for TTY Full
4152  * ((int *)data)[0] is == 2 for TTY HCO (hearing carryover)
4153  * ((int *)data)[0] is == 3 for TTY VCO (voice carryover)
4154  *
4155  * "response" is NULL
4156  *
4157  * Valid errors:
4158  *  SUCCESS
4159  *  RADIO_NOT_AVAILABLE
4160  *  INVALID_ARGUMENTS
4161  *  MODEM_ERR
4162  *  INTERNAL_ERR
4163  *  NO_MEMOR
4164  *  INVALID_ARGUMENTS
4165  *  MODEM_ERR
4166  *  INTERNAL_ERR
4167  *  NO_MEMORYY
4168  */
4169 #define RIL_REQUEST_SET_TTY_MODE 80
4170
4171 /**
4172  * RIL_REQUEST_QUERY_TTY_MODE
4173  *
4174  * Request the setting of TTY mode
4175  *
4176  * "data" is NULL
4177  *
4178  * "response" is int *
4179  * ((int *)response)[0] is == 0 for TTY off
4180  * ((int *)response)[0] is == 1 for TTY Full
4181  * ((int *)response)[0] is == 2 for TTY HCO (hearing carryover)
4182  * ((int *)response)[0] is == 3 for TTY VCO (voice carryover)
4183  *
4184  * "response" is NULL
4185  *
4186  * Valid errors:
4187  *  SUCCESS
4188  *  RADIO_NOT_AVAILABLE
4189  *  MODEM_ERR
4190  *  INTERNAL_ERR
4191  *  NO_MEMORY
4192  *  INVALID_ARGUMENTS
4193  */
4194 #define RIL_REQUEST_QUERY_TTY_MODE 81
4195
4196 /**
4197  * RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE
4198  *
4199  * Request to set the preferred voice privacy mode used in voice
4200  * scrambling
4201  *
4202  * "data" is int *
4203  * ((int *)data)[0] is == 0 for Standard Privacy Mode (Public Long Code Mask)
4204  * ((int *)data)[0] is == 1 for Enhanced Privacy Mode (Private Long Code Mask)
4205  *
4206  * "response" is NULL
4207  *
4208  * Valid errors:
4209  *  SUCCESS
4210  *  RADIO_NOT_AVAILABLE
4211  *  INVALID_ARGUMENTS
4212  *  SYSTEM_ERR
4213  *  MODEM_ERR
4214  *  INTERNAL_ERR
4215  *  NO_MEMORY
4216  *  INVALID_CALL_ID
4217  */
4218 #define RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE 82
4219
4220 /**
4221  * RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE
4222  *
4223  * Request the setting of preferred voice privacy mode
4224  *
4225  * "data" is NULL
4226  *
4227  * "response" is int *
4228  * ((int *)response)[0] is == 0 for Standard Privacy Mode (Public Long Code Mask)
4229  * ((int *)response)[0] is == 1 for Enhanced Privacy Mode (Private Long Code Mask)
4230  *
4231  * "response" is NULL
4232  *
4233  * Valid errors:
4234  *  SUCCESS
4235  *  RADIO_NOT_AVAILABLE
4236  *  MODEM_ERR
4237  *  INTERNAL_ERR
4238  *  NO_MEMORY
4239  *  INVALID_ARGUMENTS
4240  */
4241 #define RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE 83
4242
4243 /**
4244  * RIL_REQUEST_CDMA_FLASH
4245  *
4246  * Send FLASH
4247  *
4248  * "data" is const char *
4249  * ((const char *)data)[0] is a FLASH string
4250  *
4251  * "response" is NULL
4252  *
4253  * Valid errors:
4254  *  SUCCESS
4255  *  RADIO_NOT_AVAILABLE
4256  *  INVALID_ARGUMENTS
4257  *  NO_MEMORY
4258  *  SYSTEM_ERR
4259  *  MODEM_ERR
4260  *  INTERNAL_ERR
4261  *  INVALID_CALL_ID
4262  *  INVALID_STATE
4263  *
4264  */
4265 #define RIL_REQUEST_CDMA_FLASH 84
4266
4267 /**
4268  * RIL_REQUEST_CDMA_BURST_DTMF
4269  *
4270  * Send DTMF string
4271  *
4272  * "data" is const char **
4273  * ((const char **)data)[0] is a DTMF string
4274  * ((const char **)data)[1] is the DTMF ON length in milliseconds, or 0 to use
4275  *                          default
4276  * ((const char **)data)[2] is the DTMF OFF length in milliseconds, or 0 to use
4277  *                          default
4278  *
4279  * "response" is NULL
4280  *
4281  * Valid errors:
4282  *  SUCCESS
4283  *  RADIO_NOT_AVAILABLE
4284  *  INVALID_ARGUMENTS
4285  *  NO_MEMORY
4286  *  SYSTEM_ERR
4287  *  MODEM_ERR
4288  *  INTERNAL_ERR
4289  *  INVALID_CALL_ID
4290  *
4291  */
4292 #define RIL_REQUEST_CDMA_BURST_DTMF 85
4293
4294 /**
4295  * RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY
4296  *
4297  * Takes a 26 digit string (20 digit AKEY + 6 digit checksum).
4298  * If the checksum is valid the 20 digit AKEY is written to NV,
4299  * replacing the existing AKEY no matter what it was before.
4300  *
4301  * "data" is const char *
4302  * ((const char *)data)[0] is a 26 digit string (ASCII digits '0'-'9')
4303  *                         where the last 6 digits are a checksum of the
4304  *                         first 20, as specified in TR45.AHAG
4305  *                         "Common Cryptographic Algorithms, Revision D.1
4306  *                         Section 2.2"
4307  *
4308  * "response" is NULL
4309  *
4310  * Valid errors:
4311  *  SUCCESS
4312  *  RADIO_NOT_AVAILABLE
4313  *  NO_MEMORY
4314  *  INTERNAL_ERR
4315  *  SYSTEM_ERR
4316  *  INVALID_ARGUMENTS
4317  *  MODEM_ERR
4318  *  REQUEST_NOT_SUPPORTED
4319  *
4320  */
4321 #define RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY 86
4322
4323 /**
4324  * RIL_REQUEST_CDMA_SEND_SMS
4325  *
4326  * Send a CDMA SMS message
4327  *
4328  * "data" is const RIL_CDMA_SMS_Message *
4329  *
4330  * "response" is a const RIL_SMS_Response *
4331  *
4332  * Based on the return error, caller decides to resend if sending sms
4333  * fails. The CDMA error class is derived as follows,
4334  * SUCCESS is error class 0 (no error)
4335  * SMS_SEND_FAIL_RETRY is error class 2 (temporary failure)
4336  *
4337  * Valid errors:
4338  *  SUCCESS
4339  *  RADIO_NOT_AVAILABLE
4340  *  SMS_SEND_FAIL_RETRY
4341  *  NETWORK_REJECT
4342  *  INVALID_STATE
4343  *  INVALID_ARGUMENTS
4344  *  NO_MEMORY
4345  *  REQUEST_RATE_LIMITED
4346  *  INVALID_SMS_FORMAT
4347  *  SYSTEM_ERR
4348  *  FDN_CHECK_FAILURE
4349  *  MODEM_ERR
4350  *  NETWORK_ERR
4351  *  ENCODING_ERR
4352  *  INVALID_SMSC_ADDRESS
4353  *  MODE_NOT_SUPPORTED
4354  *
4355  */
4356 #define RIL_REQUEST_CDMA_SEND_SMS 87
4357
4358 /**
4359  * RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE
4360  *
4361  * Acknowledge the success or failure in the receipt of SMS
4362  * previously indicated via RIL_UNSOL_RESPONSE_CDMA_NEW_SMS
4363  *
4364  * "data" is const RIL_CDMA_SMS_Ack *
4365  *
4366  * "response" is NULL
4367  *
4368  * Valid errors:
4369  *  SUCCESS
4370  *  RADIO_NOT_AVAILABLE
4371  *  INVALID_ARGUMENTS
4372  *  NO_SMS_TO_ACK
4373  *  INVALID_STATE
4374  *  NO_MEMORY
4375  *  REQUEST_RATE_LIMITED
4376  *  SYSTEM_ERR
4377  *  MODEM_ERR
4378  *  INVALID_STATE
4379  *  MODE_NOT_SUPPORTED
4380  *  NETWORK_NOT_READY
4381  *  INVALID_MODEM_STATE
4382  *
4383  */
4384 #define RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE 88
4385
4386 /**
4387  * RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG
4388  *
4389  * Request the setting of GSM/WCDMA Cell Broadcast SMS config.
4390  *
4391  * "data" is NULL
4392  *
4393  * "response" is a const RIL_GSM_BroadcastSmsConfigInfo **
4394  * "responselen" is count * sizeof (RIL_GSM_BroadcastSmsConfigInfo *)
4395  *
4396  * Valid errors:
4397  *  SUCCESS
4398  *  RADIO_NOT_AVAILABLE
4399  *  INVALID_STATE
4400  *  NO_MEMORY
4401  *  REQUEST_RATE_LIMITED
4402  *  SYSTEM_ERR
4403  *  NO_RESOURCES
4404  *  MODEM_ERR
4405  *  SYSTEM_ERR
4406  *
4407  */
4408 #define RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG 89
4409
4410 /**
4411  * RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG
4412  *
4413  * Set GSM/WCDMA Cell Broadcast SMS config
4414  *
4415  * "data" is a const RIL_GSM_BroadcastSmsConfigInfo **
4416  * "datalen" is count * sizeof(RIL_GSM_BroadcastSmsConfigInfo *)
4417  *
4418  * "response" is NULL
4419  *
4420  * Valid errors:
4421  *  SUCCESS
4422  *  RADIO_NOT_AVAILABLE
4423  *  INVALID_STATE
4424  *  INVALID_ARGUMENTS
4425  *  NO_MEMORY
4426  *  SYSTEM_ERR
4427  *  REQUEST_RATE_LIMITED
4428  *  MODEM_ERR
4429  *  SYSTEM_ERR
4430  *
4431  */
4432 #define RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG 90
4433
4434 /**
4435  * RIL_REQUEST_GSM_SMS_BROADCAST_ACTIVATION
4436  *
4437 * Enable or disable the reception of GSM/WCDMA Cell Broadcast SMS
4438  *
4439  * "data" is const int *
4440  * (const int *)data[0] indicates to activate or turn off the
4441  * reception of GSM/WCDMA Cell Broadcast SMS, 0-1,
4442  *                       0 - Activate, 1 - Turn off
4443  *
4444  * "response" is NULL
4445  *
4446  * Valid errors:
4447  *  SUCCESS
4448  *  RADIO_NOT_AVAILABLE
4449  *  INVALID_STATE
4450  *  INVALID_ARGUMENTS
4451  *  NO_MEMORY
4452  *  SYSTEM_ERR
4453  *  REQUEST_RATE_LIMITED
4454  *  MODEM_ERR
4455  *
4456  */
4457 #define RIL_REQUEST_GSM_SMS_BROADCAST_ACTIVATION 91
4458
4459 /**
4460  * RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG
4461  *
4462  * Request the setting of CDMA Broadcast SMS config
4463  *
4464  * "data" is NULL
4465  *
4466  * "response" is a const RIL_CDMA_BroadcastSmsConfigInfo **
4467  * "responselen" is count * sizeof (RIL_CDMA_BroadcastSmsConfigInfo *)
4468  *
4469  * Valid errors:
4470  *  SUCCESS
4471  *  RADIO_NOT_AVAILABLE
4472  *  INVALID_STATE
4473  *  NO_MEMORY
4474  *  REQUEST_RATE_LIMITED
4475  *  SYSTEM_ERR
4476  *  NO_RESOURCES
4477  *  MODEM_ERR
4478  *  SYSTEM_ERR
4479  *
4480  */
4481 #define RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG 92
4482
4483 /**
4484  * RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG
4485  *
4486  * Set CDMA Broadcast SMS config
4487  *
4488  * "data" is a const RIL_CDMA_BroadcastSmsConfigInfo **
4489  * "datalen" is count * sizeof(const RIL_CDMA_BroadcastSmsConfigInfo *)
4490  *
4491  * "response" is NULL
4492  *
4493  * Valid errors:
4494  *  SUCCESS
4495  *  RADIO_NOT_AVAILABLE
4496  *  INVALID_STATE
4497  *  INVALID_ARGUMENTS
4498  *  NO_MEMORY
4499  *  SYSTEM_ERR
4500  *  REQUEST_RATE_LIMITED
4501  *  MODEM_ERR
4502  *  SYSTEM_ERR
4503  *
4504  */
4505 #define RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG 93
4506
4507 /**
4508  * RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION
4509  *
4510  * Enable or disable the reception of CDMA Broadcast SMS
4511  *
4512  * "data" is const int *
4513  * (const int *)data[0] indicates to activate or turn off the
4514  * reception of CDMA Broadcast SMS, 0-1,
4515  *                       0 - Activate, 1 - Turn off
4516  *
4517  * "response" is NULL
4518  *
4519  * Valid errors:
4520  *  SUCCESS
4521  *  RADIO_NOT_AVAILABLE
4522  *  INVALID_STATE
4523  *  INVALID_ARGUMENTS
4524  *  NO_MEMORY
4525  *  SYSTEM_ERR
4526  *  REQUEST_RATE_LIMITED
4527  *  MODEM_ERR
4528  *
4529  */
4530 #define RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION 94
4531
4532 /**
4533  * RIL_REQUEST_CDMA_SUBSCRIPTION
4534  *
4535  * Request the device MDN / H_SID / H_NID.
4536  *
4537  * The request is only allowed when CDMA subscription is available.  When CDMA
4538  * subscription is changed, application layer should re-issue the request to
4539  * update the subscription information.
4540  *
4541  * If a NULL value is returned for any of the device id, it means that error
4542  * accessing the device.
4543  *
4544  * "response" is const char **
4545  * ((const char **)response)[0] is MDN if CDMA subscription is available
4546  * ((const char **)response)[1] is a comma separated list of H_SID (Home SID) if
4547  *                              CDMA subscription is available, in decimal format
4548  * ((const char **)response)[2] is a comma separated list of H_NID (Home NID) if
4549  *                              CDMA subscription is available, in decimal format
4550  * ((const char **)response)[3] is MIN (10 digits, MIN2+MIN1) if CDMA subscription is available
4551  * ((const char **)response)[4] is PRL version if CDMA subscription is available
4552  *
4553  * Valid errors:
4554  *  SUCCESS
4555  *  RIL_E_SUBSCRIPTION_NOT_AVAILABLE
4556  *  NO_MEMORY
4557  *  INTERNAL_ERR
4558  *  SYSTEM_ERR
4559  *  INVALID_ARGUMENTS
4560  *  MODEM_ERR
4561  *  NOT_PROVISIONED
4562  *  REQUEST_NOT_SUPPORTED
4563  *
4564  */
4565
4566 #define RIL_REQUEST_CDMA_SUBSCRIPTION 95
4567
4568 /**
4569  * RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM
4570  *
4571  * Stores a CDMA SMS message to RUIM memory.
4572  *
4573  * "data" is RIL_CDMA_SMS_WriteArgs *
4574  *
4575  * "response" is int *
4576  * ((const int *)response)[0] is the record index where the message is stored.
4577  *
4578  * Valid errors:
4579  *  SUCCESS
4580  *  RADIO_NOT_AVAILABLE
4581  *  SIM_FULL
4582  *  INVALID_ARGUMENTS
4583  *  INVALID_SMS_FORMAT
4584  *  INTERNAL_ERR
4585  *  MODEM_ERR
4586  *  ENCODING_ERR
4587  *  NO_MEMORY
4588  *  NO_RESOURCES
4589  *  INVALID_MODEM_STATE
4590  *  MODE_NOT_SUPPORTED
4591  *  INVALID_SMSC_ADDRESS
4592  *
4593  */
4594 #define RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM 96
4595
4596 /**
4597  * RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM
4598  *
4599  * Deletes a CDMA SMS message from RUIM memory.
4600  *
4601  * "data" is int  *
4602  * ((int *)data)[0] is the record index of the message to delete.
4603  *
4604  * "response" is NULL
4605  *
4606  * Valid errors:
4607  *  SUCCESS
4608  *  RADIO_NOT_AVAILABLE
4609  *  INVALID_ARGUMENTS
4610  *  NO_MEMORY
4611  *  REQUEST_RATE_LIMITED
4612  *  SYSTEM_ERR
4613  *  MODEM_ERR
4614  *  NO_SUCH_ENTRY
4615  *
4616  */
4617 #define RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM 97
4618
4619 /**
4620  * RIL_REQUEST_DEVICE_IDENTITY
4621  *
4622  * Request the device ESN / MEID / IMEI / IMEISV.
4623  *
4624  * The request is always allowed and contains GSM and CDMA device identity;
4625  * it substitutes the deprecated requests RIL_REQUEST_GET_IMEI and
4626  * RIL_REQUEST_GET_IMEISV.
4627  *
4628  * If a NULL value is returned for any of the device id, it means that error
4629  * accessing the device.
4630  *
4631  * When CDMA subscription is changed the ESN/MEID may change.  The application
4632  * layer should re-issue the request to update the device identity in this case.
4633  *
4634  * "response" is const char **
4635  * ((const char **)response)[0] is IMEI if GSM subscription is available
4636  * ((const char **)response)[1] is IMEISV if GSM subscription is available
4637  * ((const char **)response)[2] is ESN if CDMA subscription is available
4638  * ((const char **)response)[3] is MEID if CDMA subscription is available
4639  *
4640  * Valid errors:
4641  *  SUCCESS
4642  *  RADIO_NOT_AVAILABLE
4643  *  NO_MEMORY
4644  *  INTERNAL_ERR
4645  *  SYSTEM_ERR
4646  *  INVALID_ARGUMENTS
4647  *  MODEM_ERR
4648  *  NOT_PROVISIONED
4649  *  REQUEST_NOT_SUPPORTED
4650  *
4651  */
4652 #define RIL_REQUEST_DEVICE_IDENTITY 98
4653
4654 /**
4655  * RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE
4656  *
4657  * Request the radio's system selection module to exit emergency
4658  * callback mode.  RIL will not respond with SUCCESS until the modem has
4659  * completely exited from Emergency Callback Mode.
4660  *
4661  * "data" is NULL
4662  *
4663  * "response" is NULL
4664  *
4665  * Valid errors:
4666  *  SUCCESS
4667  *  RADIO_NOT_AVAILABLE
4668  *  OPERATION_NOT_ALLOWED
4669  *  NO_MEMORY
4670  *  INTERNAL_ERR
4671  *  SYSTEM_ERR
4672  *  INVALID_ARGUMENTS
4673  *  MODEM_ERR
4674  *  REQUEST_NOT_SUPPORTED
4675  *
4676  */
4677 #define RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE 99
4678
4679 /**
4680  * RIL_REQUEST_GET_SMSC_ADDRESS
4681  *
4682  * Queries the default Short Message Service Center address on the device.
4683  *
4684  * "data" is NULL
4685  *
4686  * "response" is const char * containing the SMSC address.
4687  *
4688  * Valid errors:
4689  *  SUCCESS
4690  *  RADIO_NOT_AVAILABLE
4691  *  NO_MEMORY
4692  *  REQUEST_RATE_LIMITED
4693  *  SYSTEM_ERR
4694  *  INTERNAL_ERR
4695  *  MODEM_ERR
4696  *  INVALID_ARGUMENTS
4697  *  INVALID_MODEM_STATE
4698  *  NOT_PROVISIONED
4699  *
4700  */
4701 #define RIL_REQUEST_GET_SMSC_ADDRESS 100
4702
4703 /**
4704  * RIL_REQUEST_SET_SMSC_ADDRESS
4705  *
4706  * Sets the default Short Message Service Center address on the device.
4707  *
4708  * "data" is const char * containing the SMSC address.
4709  *
4710  * "response" is NULL
4711  *
4712  * Valid errors:
4713  *  SUCCESS
4714  *  RADIO_NOT_AVAILABLE
4715  *  INVALID_ARGUMENTS
4716  *  INVALID_SMS_FORMAT
4717  *  NO_MEMORY
4718  *  SYSTEM_ERR
4719  *  REQUEST_RATE_LIMITED
4720  *  MODEM_ERR
4721  *  NO_RESOURCES
4722  *
4723  */
4724 #define RIL_REQUEST_SET_SMSC_ADDRESS 101
4725
4726 /**
4727  * RIL_REQUEST_REPORT_SMS_MEMORY_STATUS
4728  *
4729  * Indicates whether there is storage available for new SMS messages.
4730  *
4731  * "data" is int *
4732  * ((int *)data)[0] is 1 if memory is available for storing new messages
4733  *                  is 0 if memory capacity is exceeded
4734  *
4735  * "response" is NULL
4736  *
4737  * Valid errors:
4738  *  SUCCESS
4739  *  RADIO_NOT_AVAILABLE
4740  *  INVALID_ARGUMENTS
4741  *  NO_MEMORY
4742  *  INVALID_STATE
4743  *  SYSTEM_ERR
4744  *  REQUEST_RATE_LIMITED
4745  *  MODEM_ERR
4746  *
4747  */
4748 #define RIL_REQUEST_REPORT_SMS_MEMORY_STATUS 102
4749
4750 /**
4751  * RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING
4752  *
4753  * Indicates that the StkSerivce is running and is
4754  * ready to receive RIL_UNSOL_STK_XXXXX commands.
4755  *
4756  * "data" is NULL
4757  * "response" is NULL
4758  *
4759  * Valid errors:
4760  *  SUCCESS
4761  *  RADIO_NOT_AVAILABLE
4762  *
4763  */
4764 #define RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING 103
4765
4766 /**
4767  * RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE
4768  *
4769  * Request to query the location where the CDMA subscription shall
4770  * be retrieved
4771  *
4772  * "data" is NULL
4773  *
4774  * "response" is int *
4775  * ((int *)data)[0] is == RIL_CdmaSubscriptionSource
4776  *
4777  * Valid errors:
4778  *  SUCCESS
4779  *  RADIO_NOT_AVAILABLE
4780  *  SUBSCRIPTION_NOT_AVAILABLE
4781  *
4782  * See also: RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE
4783  */
4784 #define RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE 104
4785
4786 /**
4787  * RIL_REQUEST_ISIM_AUTHENTICATION
4788  *
4789  * Request the ISIM application on the UICC to perform AKA
4790  * challenge/response algorithm for IMS authentication
4791  *
4792  * "data" is a const char * containing the challenge string in Base64 format
4793  * "response" is a const char * containing the response in Base64 format
4794  *
4795  * Valid errors:
4796  *  SUCCESS
4797  *  RADIO_NOT_AVAILABLE
4798  */
4799 #define RIL_REQUEST_ISIM_AUTHENTICATION 105
4800
4801 /**
4802  * RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU
4803  *
4804  * Acknowledge successful or failed receipt of SMS previously indicated
4805  * via RIL_UNSOL_RESPONSE_NEW_SMS, including acknowledgement TPDU to send
4806  * as the RP-User-Data element of the RP-ACK or RP-ERROR PDU.
4807  *
4808  * "data" is const char **
4809  * ((const char **)data)[0] is "1" on successful receipt (send RP-ACK)
4810  *                          is "0" on failed receipt (send RP-ERROR)
4811  * ((const char **)data)[1] is the acknowledgement TPDU in hexadecimal format
4812  *
4813  * "response" is NULL
4814  *
4815  * Valid errors:
4816  *  SUCCESS
4817  *  RADIO_NOT_AVAILABLE
4818  */
4819 #define RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU 106
4820
4821 /**
4822  * RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS
4823  *
4824  * Requests to send a SAT/USAT envelope command to SIM.
4825  * The SAT/USAT envelope command refers to 3GPP TS 11.14 and 3GPP TS 31.111.
4826  *
4827  * This request has one difference from RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND:
4828  * the SW1 and SW2 status bytes from the UICC response are returned along with
4829  * the response data, using the same structure as RIL_REQUEST_SIM_IO.
4830  *
4831  * The RIL implementation shall perform the normal processing of a '91XX'
4832  * response in SW1/SW2 to retrieve the pending proactive command and send it
4833  * as an unsolicited response, as RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND does.
4834  *
4835  * "data" is a const char * containing the SAT/USAT command
4836  * in hexadecimal format starting with command tag
4837  *
4838  * "response" is a const RIL_SIM_IO_Response *
4839  *
4840  * Valid errors:
4841  *  RIL_E_SUCCESS
4842  *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting)
4843  *  SIM_BUSY
4844  *  OPERATION_NOT_ALLOWED
4845  */
4846 #define RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS 107
4847
4848 /**
4849  * RIL_REQUEST_VOICE_RADIO_TECH
4850  *
4851  * Query the radio technology type (3GPP/3GPP2) used for voice. Query is valid only
4852  * when radio state is not RADIO_STATE_UNAVAILABLE
4853  *
4854  * "data" is NULL
4855  * "response" is int *
4856  * ((int *) response)[0] is of type const RIL_RadioTechnology
4857  *
4858  * Valid errors:
4859  *  SUCCESS
4860  *  RADIO_NOT_AVAILABLE
4861  */
4862 #define RIL_REQUEST_VOICE_RADIO_TECH 108
4863
4864 /**
4865  * RIL_REQUEST_GET_CELL_INFO_LIST
4866  *
4867  * Request all of the current cell information known to the radio. The radio
4868  * must a list of all current cells, including the neighboring cells. If for a particular
4869  * cell information isn't known then the appropriate unknown value will be returned.
4870  * This does not cause or change the rate of RIL_UNSOL_CELL_INFO_LIST.
4871  *
4872  * "data" is NULL
4873  *
4874  * "response" is an array of  RIL_CellInfo_v12.
4875  *
4876  * Valid errors:
4877  *  SUCCESS
4878  *  RADIO_NOT_AVAILABLE
4879  *  NO_MEMORY
4880  *  INTERNAL_ERR
4881  *  SYSTEM_ERR
4882  *  MODEM_ERR
4883  *  NO_NETWORK_FOUND
4884  *  REQUEST_NOT_SUPPORTED
4885  *
4886  */
4887 #define RIL_REQUEST_GET_CELL_INFO_LIST 109
4888
4889 /**
4890  * RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE
4891  *
4892  * Sets the minimum time between when RIL_UNSOL_CELL_INFO_LIST should be invoked.
4893  * A value of 0, means invoke RIL_UNSOL_CELL_INFO_LIST when any of the reported
4894  * information changes. Setting the value to INT_MAX(0x7fffffff) means never issue
4895  * a RIL_UNSOL_CELL_INFO_LIST.
4896  *
4897  * "data" is int *
4898  * ((int *)data)[0] is minimum time in milliseconds
4899  *
4900  * "response" is NULL
4901  *
4902  * Valid errors:
4903  *  SUCCESS
4904  *  RADIO_NOT_AVAILABLE
4905  *  NO_MEMORY
4906  *  INTERNAL_ERR
4907  *  SYSTEM_ERR
4908  *  INVALID_ARGUMENTS
4909  *  REQUEST_NOT_SUPPORTED
4910  */
4911 #define RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE 110
4912
4913 /**
4914  * RIL_REQUEST_SET_INITIAL_ATTACH_APN
4915  *
4916  * Set an apn to initial attach network
4917  *
4918  * "data" is a const char **
4919  * ((const char **)data)[0] is the APN to connect if radio technology is LTE
4920  * ((const char **)data)[1] is the connection type to request must be one of the
4921  *                          PDP_type values in TS 27.007 section 10.1.1.
4922  *                          For example, "IP", "IPV6", "IPV4V6", or "PPP".
4923  * ((const char **)data)[2] is the PAP / CHAP auth type. Values:
4924  *                          0 => PAP and CHAP is never performed.
4925  *                          1 => PAP may be performed; CHAP is never performed.
4926  *                          2 => CHAP may be performed; PAP is never performed.
4927  *                          3 => PAP / CHAP may be performed - baseband dependent.
4928  * ((const char **)data)[3] is the username for APN, or NULL
4929  * ((const char **)data)[4] is the password for APN, or NULL
4930  *
4931  * "response" is NULL
4932  *
4933  * Valid errors:
4934  *  SUCCESS
4935  *  RADIO_NOT_AVAILABLE (radio resetting)
4936  *  SUBSCRIPTION_NOT_AVAILABLE
4937  *  NO_MEMORY
4938  *  INTERNAL_ERR
4939  *  SYSTEM_ERR
4940  *  INVALID_ARGUMENTS
4941  *  MODEM_ERR
4942  *  NOT_PROVISIONED
4943  *  REQUEST_NOT_SUPPORTED
4944  *
4945  */
4946 #define RIL_REQUEST_SET_INITIAL_ATTACH_APN 111
4947
4948 /**
4949  * RIL_REQUEST_IMS_REGISTRATION_STATE
4950  *
4951  * This message is DEPRECATED and shall be removed in a future release (target: 2018);
4952  * instead, provide IMS registration status via an IMS Service.
4953  *
4954  * Request current IMS registration state
4955  *
4956  * "data" is NULL
4957  *
4958  * "response" is int *
4959  * ((int *)response)[0] is registration state:
4960  *              0 - Not registered
4961  *              1 - Registered
4962  *
4963  * If ((int*)response)[0] is = 1, then ((int *) response)[1]
4964  * must follow with IMS SMS format:
4965  *
4966  * ((int *) response)[1] is of type RIL_RadioTechnologyFamily
4967  *
4968  * Valid errors:
4969  *  SUCCESS
4970  *  RADIO_NOT_AVAILABLE
4971  */
4972 #define RIL_REQUEST_IMS_REGISTRATION_STATE 112
4973
4974 /**
4975  * RIL_REQUEST_IMS_SEND_SMS
4976  *
4977  * Send a SMS message over IMS
4978  *
4979  * "data" is const RIL_IMS_SMS_Message *
4980  *
4981  * "response" is a const RIL_SMS_Response *
4982  *
4983  * Based on the return error, caller decides to resend if sending sms
4984  * fails. SMS_SEND_FAIL_RETRY means retry, and other errors means no retry.
4985  * In case of retry, data is encoded based on Voice Technology available.
4986  *
4987  * Valid errors:
4988  *  SUCCESS
4989  *  RADIO_NOT_AVAILABLE
4990  *  SMS_SEND_FAIL_RETRY
4991  *  FDN_CHECK_FAILURE
4992  *  NETWORK_REJECT
4993  *  INVALID_ARGUMENTS
4994  *  INVALID_STATE
4995  *  NO_MEMORY
4996  *  INVALID_SMS_FORMAT
4997  *  SYSTEM_ERR
4998  *  REQUEST_RATE_LIMITED
4999  *  MODEM_ERR
5000  *  NETWORK_ERR
5001  *  ENCODING_ERR
5002  *  INVALID_SMSC_ADDRESS
5003  *  MODE_NOT_SUPPORTED
5004  *
5005  */
5006 #define RIL_REQUEST_IMS_SEND_SMS 113
5007
5008 /**
5009  * RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC
5010  *
5011  * Request APDU exchange on the basic channel. This command reflects TS 27.007
5012  * "generic SIM access" operation (+CSIM). The modem must ensure proper function
5013  * of GSM/CDMA, and filter commands appropriately. It should filter
5014  * channel management and SELECT by DF name commands.
5015  *
5016  * "data" is a const RIL_SIM_APDU *
5017  * "sessionid" field should be ignored.
5018  *
5019  * "response" is a const RIL_SIM_IO_Response *
5020  *
5021  * Valid errors:
5022  *  SUCCESS
5023  *  RADIO_NOT_AVAILABLE
5024  */
5025 #define RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC 114
5026
5027 /**
5028  * RIL_REQUEST_SIM_OPEN_CHANNEL
5029  *
5030  * Open a new logical channel and select the given application. This command
5031  * reflects TS 27.007 "open logical channel" operation (+CCHO). This request
5032  * also specifies the P2 parameter (described in ISO 7816-4).
5033  *
5034  * "data" is a const RIL_OpenChannelParam *
5035  *
5036  * "response" is int *
5037  * ((int *)data)[0] contains the session id of the logical channel.
5038  * ((int *)data)[1] onwards may optionally contain the select response for the
5039  *     open channel command with one byte per integer.
5040  *
5041  * Valid errors:
5042  *  SUCCESS
5043  *  RADIO_NOT_AVAILABLE
5044  *  MISSING_RESOURCE
5045  *  NO_SUCH_ELEMENT
5046  */
5047 #define RIL_REQUEST_SIM_OPEN_CHANNEL 115
5048
5049 /**
5050  * RIL_REQUEST_SIM_CLOSE_CHANNEL
5051  *
5052  * Close a previously opened logical channel. This command reflects TS 27.007
5053  * "close logical channel" operation (+CCHC).
5054  *
5055  * "data" is int *
5056  * ((int *)data)[0] is the session id of logical the channel to close.
5057  *
5058  * "response" is NULL
5059  *
5060  * Valid errors:
5061  *  SUCCESS
5062  *  RADIO_NOT_AVAILABLE
5063  */
5064 #define RIL_REQUEST_SIM_CLOSE_CHANNEL 116
5065
5066 /**
5067  * RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL
5068  *
5069  * Exchange APDUs with a UICC over a previously opened logical channel. This
5070  * command reflects TS 27.007 "generic logical channel access" operation
5071  * (+CGLA). The modem should filter channel management and SELECT by DF name
5072  * commands.
5073  *
5074  * "data" is a const RIL_SIM_APDU*
5075  *
5076  * "response" is a const RIL_SIM_IO_Response *
5077  *
5078  * Valid errors:
5079  *  SUCCESS
5080  *  RADIO_NOT_AVAILABLE
5081  */
5082 #define RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL 117
5083
5084 /**
5085  * RIL_REQUEST_NV_READ_ITEM
5086  *
5087  * Read one of the radio NV items defined in RadioNVItems.java / ril_nv_items.h.
5088  * This is used for device configuration by some CDMA operators.
5089  *
5090  * "data" is a const RIL_NV_ReadItem *
5091  *
5092  * "response" is const char * containing the contents of the NV item
5093  *
5094  * Valid errors:
5095  *  SUCCESS
5096  *  RADIO_NOT_AVAILABLE
5097  */
5098 #define RIL_REQUEST_NV_READ_ITEM 118
5099
5100 /**
5101  * RIL_REQUEST_NV_WRITE_ITEM
5102  *
5103  * Write one of the radio NV items defined in RadioNVItems.java / ril_nv_items.h.
5104  * This is used for device configuration by some CDMA operators.
5105  *
5106  * "data" is a const RIL_NV_WriteItem *
5107  *
5108  * "response" is NULL
5109  *
5110  * Valid errors:
5111  *  SUCCESS
5112  *  RADIO_NOT_AVAILABLE
5113  */
5114 #define RIL_REQUEST_NV_WRITE_ITEM 119
5115
5116 /**
5117  * RIL_REQUEST_NV_WRITE_CDMA_PRL
5118  *
5119  * Update the CDMA Preferred Roaming List (PRL) in the radio NV storage.
5120  * This is used for device configuration by some CDMA operators.
5121  *
5122  * "data" is a const char * containing the PRL as a byte array
5123  *
5124  * "response" is NULL
5125  *
5126  * Valid errors:
5127  *  SUCCESS
5128  *  RADIO_NOT_AVAILABLE
5129  */
5130 #define RIL_REQUEST_NV_WRITE_CDMA_PRL 120
5131
5132 /**
5133  * RIL_REQUEST_NV_RESET_CONFIG
5134  *
5135  * Reset the radio NV configuration to the factory state.
5136  * This is used for device configuration by some CDMA operators.
5137  *
5138  * "data" is int *
5139  * ((int *)data)[0] is 1 to reload all NV items
5140  * ((int *)data)[0] is 2 for erase NV reset (SCRTN)
5141  * ((int *)data)[0] is 3 for factory reset (RTN)
5142  *
5143  * "response" is NULL
5144  *
5145  * Valid errors:
5146  *  SUCCESS
5147  *  RADIO_NOT_AVAILABLE
5148  */
5149 #define RIL_REQUEST_NV_RESET_CONFIG 121
5150
5151  /** RIL_REQUEST_SET_UICC_SUBSCRIPTION
5152  * FIXME This API needs to have more documentation.
5153  *
5154  * Selection/de-selection of a subscription from a SIM card
5155  * "data" is const  RIL_SelectUiccSub*
5156
5157  *
5158  * "response" is NULL
5159  *
5160  *  Valid errors:
5161  *  SUCCESS
5162  *  RADIO_NOT_AVAILABLE (radio resetting)
5163  *  SUBSCRIPTION_NOT_SUPPORTED
5164  *  NO_MEMORY
5165  *  INTERNAL_ERR
5166  *  SYSTEM_ERR
5167  *  INVALID_ARGUMENTS
5168  *  MODEM_ERR
5169  *  REQUEST_NOT_SUPPORTED
5170  *
5171  */
5172 #define RIL_REQUEST_SET_UICC_SUBSCRIPTION  122
5173
5174 /**
5175  *  RIL_REQUEST_ALLOW_DATA
5176  *
5177  *  Tells the modem whether data calls are allowed or not
5178  *
5179  * "data" is int *
5180  * FIXME slotId and aid will be added.
5181  * ((int *)data)[0] is == 0 to allow data calls
5182  * ((int *)data)[0] is == 1 to disallow data calls
5183  *
5184  * "response" is NULL
5185  *
5186  *  Valid errors:
5187  *
5188  *  SUCCESS
5189  *  RADIO_NOT_AVAILABLE (radio resetting)
5190  *  NO_MEMORY
5191  *  INTERNAL_ERR
5192  *  SYSTEM_ERR
5193  *  MODEM_ERR
5194  *  INVALID_ARGUMENTS
5195  *  DEVICE_IN_USE
5196  *  INVALID_MODEM_STATE
5197  *  REQUEST_NOT_SUPPORTED
5198  *
5199  */
5200 #define RIL_REQUEST_ALLOW_DATA  123
5201
5202 /**
5203  * RIL_REQUEST_GET_HARDWARE_CONFIG
5204  *
5205  * Request all of the current hardware (modem and sim) associated
5206  * with the RIL.
5207  *
5208  * "data" is NULL
5209  *
5210  * "response" is an array of  RIL_HardwareConfig.
5211  */
5212 #define RIL_REQUEST_GET_HARDWARE_CONFIG 124
5213
5214 /**
5215  * RIL_REQUEST_SIM_AUTHENTICATION
5216  *
5217  * Returns the response of SIM Authentication through RIL to a
5218  * challenge request.
5219  *
5220  * "data" Base64 encoded string containing challenge:
5221  *      int   authContext;          P2 value of authentication command, see P2 parameter in
5222  *                                  3GPP TS 31.102 7.1.2
5223  *      char *authData;             the challenge string in Base64 format, see 3GPP
5224  *                                  TS 31.102 7.1.2
5225  *      char *aid;                  AID value, See ETSI 102.221 8.1 and 101.220 4,
5226  *                                  NULL if no value
5227  *
5228  * "response" Base64 encoded strings containing response:
5229  *      int   sw1;                  Status bytes per 3GPP TS 31.102 section 7.3
5230  *      int   sw2;
5231  *      char *simResponse;          Response in Base64 format, see 3GPP TS 31.102 7.1.2
5232  */
5233 #define RIL_REQUEST_SIM_AUTHENTICATION 125
5234
5235 /**
5236  * RIL_REQUEST_GET_DC_RT_INFO
5237  *
5238  * The request is DEPRECATED, use RIL_REQUEST_GET_ACTIVITY_INFO
5239  * Requests the Data Connection Real Time Info
5240  *
5241  * "data" is NULL
5242  *
5243  * "response" is the most recent RIL_DcRtInfo
5244  *
5245  * Valid errors:
5246  *  SUCCESS
5247  *  RADIO_NOT_AVAILABLE
5248  *  REQUEST_NOT_SUPPORTED
5249  *
5250  * See also: RIL_UNSOL_DC_RT_INFO_CHANGED
5251  */
5252 #define RIL_REQUEST_GET_DC_RT_INFO 126
5253
5254 /**
5255  * RIL_REQUEST_SET_DC_RT_INFO_RATE
5256  *
5257  * The request is DEPRECATED
5258  * This is the minimum number of milliseconds between successive
5259  * RIL_UNSOL_DC_RT_INFO_CHANGED messages and defines the highest rate
5260  * at which RIL_UNSOL_DC_RT_INFO_CHANGED's will be sent. A value of
5261  * 0 means send as fast as possible.
5262  *
5263  * "data" The number of milliseconds as an int
5264  *
5265  * "response" is null
5266  *
5267  * Valid errors:
5268  *  SUCCESS must not fail
5269  */
5270 #define RIL_REQUEST_SET_DC_RT_INFO_RATE 127
5271
5272 /**
5273  * RIL_REQUEST_SET_DATA_PROFILE
5274  *
5275  * Set data profile in modem
5276  * Modem should erase existed profiles from framework, and apply new profiles
5277  * "data" is a const RIL_DataProfileInfo **
5278  * "datalen" is count * sizeof(const RIL_DataProfileInfo *)
5279  * "response" is NULL
5280  *
5281  * Valid errors:
5282  *  SUCCESS
5283  *  RADIO_NOT_AVAILABLE (radio resetting)
5284  *  SUBSCRIPTION_NOT_AVAILABLE
5285  */
5286 #define RIL_REQUEST_SET_DATA_PROFILE 128
5287
5288 /**
5289  * RIL_REQUEST_SHUTDOWN
5290  *
5291  * Device is shutting down. All further commands are ignored
5292  * and RADIO_NOT_AVAILABLE must be returned.
5293  *
5294  * "data" is null
5295  * "response" is NULL
5296  *
5297  * Valid errors:
5298  *  SUCCESS
5299  *  RADIO_NOT_AVAILABLE
5300  *  OPERATION_NOT_ALLOWED
5301  *  NO_MEMORY
5302  *  INTERNAL_ERR
5303  *  SYSTEM_ERR
5304  *  REQUEST_NOT_SUPPORTED
5305  */
5306 #define RIL_REQUEST_SHUTDOWN 129
5307
5308 /**
5309  * RIL_REQUEST_GET_RADIO_CAPABILITY
5310  *
5311  * Used to get phone radio capablility.
5312  *
5313  * "data" is the RIL_RadioCapability structure
5314  *
5315  * Valid errors:
5316  *  SUCCESS
5317  *  RADIO_NOT_AVAILABLE
5318  *  OPERATION_NOT_ALLOWED
5319  *  INVALID_STATE
5320  *  REQUEST_NOT_SUPPORTED
5321  */
5322 #define RIL_REQUEST_GET_RADIO_CAPABILITY 130
5323
5324 /**
5325  * RIL_REQUEST_SET_RADIO_CAPABILITY
5326  *
5327  * Used to set the phones radio capability. Be VERY careful
5328  * using this request as it may cause some vendor modems to reset. Because
5329  * of the possible modem reset any RIL commands after this one may not be
5330  * processed.
5331  *
5332  * "data" is the RIL_RadioCapability structure
5333  *
5334  * "response" is the RIL_RadioCapability structure, used to feedback return status
5335  *
5336  * Valid errors:
5337  *  SUCCESS means a RIL_UNSOL_RADIO_CAPABILITY will be sent within 30 seconds.
5338  *  RADIO_NOT_AVAILABLE
5339  *  OPERATION_NOT_ALLOWED
5340  *  NO_MEMORY
5341  *  INTERNAL_ERR
5342  *  SYSTEM_ERR
5343  *  INVALID_ARGUMENTS
5344  *  MODEM_ERR
5345  *  INVALID_STATE
5346  *  REQUEST_NOT_SUPPORTED
5347  */
5348 #define RIL_REQUEST_SET_RADIO_CAPABILITY 131
5349
5350 /**
5351  * RIL_REQUEST_START_LCE
5352  *
5353  * Start Link Capacity Estimate (LCE) service if supported by the radio.
5354  *
5355  * "data" is const int *
5356  * ((const int*)data)[0] specifies the desired reporting interval (ms).
5357  * ((const int*)data)[1] specifies the LCE service mode. 1: PULL; 0: PUSH.
5358  *
5359  * "response" is the RIL_LceStatusInfo.
5360  *
5361  * Valid errors:
5362  * SUCCESS
5363  * RADIO_NOT_AVAILABLE
5364  * LCE_NOT_SUPPORTED
5365  * INTERNAL_ERR
5366  * REQUEST_NOT_SUPPORTED
5367  */
5368 #define RIL_REQUEST_START_LCE 132
5369
5370 /**
5371  * RIL_REQUEST_STOP_LCE
5372  *
5373  * Stop Link Capacity Estimate (LCE) service, the STOP operation should be
5374  * idempotent for the radio modem.
5375  *
5376  * "response" is the RIL_LceStatusInfo.
5377  *
5378  * Valid errors:
5379  * SUCCESS
5380  * RADIO_NOT_AVAILABLE
5381  * LCE_NOT_SUPPORTED
5382  */
5383 #define RIL_REQUEST_STOP_LCE 133
5384
5385 /**
5386  * RIL_REQUEST_PULL_LCEDATA
5387  *
5388  * Pull LCE service for capacity information.
5389  *
5390  * "response" is the RIL_LceDataInfo.
5391  *
5392  * Valid errors:
5393  * SUCCESS
5394  * RADIO_NOT_AVAILABLE
5395  * LCE_NOT_SUPPORTED
5396  */
5397 #define RIL_REQUEST_PULL_LCEDATA 134
5398
5399 /**
5400  * RIL_REQUEST_GET_ACTIVITY_INFO
5401  *
5402  * Get modem activity information for power consumption estimation.
5403  *
5404  * Request clear-on-read statistics information that is used for
5405  * estimating the per-millisecond power consumption of the cellular
5406  * modem.
5407  *
5408  * "data" is null
5409  * "response" is const RIL_ActivityStatsInfo *
5410  *
5411  * Valid errors:
5412  *
5413  * SUCCESS
5414  * RADIO_NOT_AVAILABLE (radio resetting)
5415  * NO_MEMORY
5416  * INTERNAL_ERR
5417  * SYSTEM_ERR
5418  * MODEM_ERR
5419  * NOT_PROVISIONED
5420  * REQUEST_NOT_SUPPORTED
5421  */
5422 #define RIL_REQUEST_GET_ACTIVITY_INFO 135
5423
5424 /**
5425  * RIL_REQUEST_SET_CARRIER_RESTRICTIONS
5426  *
5427  * Set carrier restrictions for this sim slot. Expected modem behavior:
5428  *  If never receives this command
5429  *  - Must allow all carriers
5430  *  Receives this command with data being NULL
5431  *  - Must allow all carriers. If a previously allowed SIM is present, modem must not reload
5432  *    the SIM. If a previously disallowed SIM is present, reload the SIM and notify Android.
5433  *  Receives this command with a list of carriers
5434  *  - Only allow specified carriers, persist across power cycles and FDR. If a present SIM
5435  *    is in the allowed list, modem must not reload the SIM. If a present SIM is *not* in
5436  *    the allowed list, modem must detach from the registered network and only keep emergency
5437  *    service, and notify Android SIM refresh reset with new SIM state being
5438  *    RIL_CARDSTATE_RESTRICTED. Emergency service must be enabled.
5439  *
5440  * "data" is const RIL_CarrierRestrictions *
5441  * A list of allowed carriers and possibly a list of excluded carriers.
5442  * If data is NULL, means to clear previous carrier restrictions and allow all carriers
5443  *
5444  * "response" is int *
5445  * ((int *)data)[0] contains the number of allowed carriers which have been set correctly.
5446  * On success, it should match the length of list data->allowed_carriers.
5447  * If data is NULL, the value must be 0.
5448  *
5449  * Valid errors:
5450  *  RIL_E_SUCCESS
5451  *  RIL_E_INVALID_ARGUMENTS
5452  *  RIL_E_RADIO_NOT_AVAILABLE
5453  *  RIL_E_REQUEST_NOT_SUPPORTED
5454  */
5455 #define RIL_REQUEST_SET_CARRIER_RESTRICTIONS 136
5456
5457 /**
5458  * RIL_REQUEST_GET_CARRIER_RESTRICTIONS
5459  *
5460  * Get carrier restrictions for this sim slot. Expected modem behavior:
5461  *  Return list of allowed carriers, or null if all carriers are allowed.
5462  *
5463  * "data" is NULL
5464  *
5465  * "response" is const RIL_CarrierRestrictions *.
5466  * If response is NULL, it means all carriers are allowed.
5467  *
5468  * Valid errors:
5469  *  RIL_E_SUCCESS
5470  *  RIL_E_RADIO_NOT_AVAILABLE
5471  *  RIL_E_REQUEST_NOT_SUPPORTED
5472  */
5473 #define RIL_REQUEST_GET_CARRIER_RESTRICTIONS 137
5474
5475 /**
5476  * RIL_REQUEST_SEND_DEVICE_STATE
5477  *
5478  * Send the updated device state.
5479  * Modem can perform power saving based on the provided device state.
5480  * "data" is const int *
5481  * ((const int*)data)[0] A RIL_DeviceStateType that specifies the device state type.
5482  * ((const int*)data)[1] Specifies the state. See RIL_DeviceStateType for the definition of each
5483  *                       type.
5484  *
5485  * "datalen" is count * sizeof(const RIL_DeviceState *)
5486  * "response" is NULL
5487  *
5488  * Valid errors:
5489  *  SUCCESS
5490  *  RADIO_NOT_AVAILABLE (radio resetting)
5491  *  NO_MEMORY
5492  *  INTERNAL_ERR
5493  *  SYSTEM_ERR
5494  *  INVALID_ARGUMENTS
5495  *  REQUEST_NOT_SUPPORTED
5496  */
5497 #define RIL_REQUEST_SEND_DEVICE_STATE 138
5498
5499 /**
5500  * RIL_REQUEST_SET_UNSOLICITED_RESPONSE_FILTER
5501  *
5502  * Set the unsolicited response filter
5503  * This is used to prevent unnecessary application processor
5504  * wake up for power saving purposes by suppressing the
5505  * unsolicited responses in certain scenarios.
5506  *
5507  * "data" is an int *
5508  *
5509  * ((int *)data)[0] is a 32-bit bitmask of RIL_UnsolicitedResponseFilter
5510  *
5511  * "response" is NULL
5512  *
5513  * Valid errors:
5514  *  SUCCESS
5515  *  INVALID_ARGUMENTS (e.g. the requested filter doesn't exist)
5516  *  RADIO_NOT_AVAILABLE (radio resetting)
5517  *  NO_MEMORY
5518  *  INTERNAL_ERR
5519  *  SYSTEM_ERR
5520  *  REQUEST_NOT_SUPPORTED
5521  */
5522 #define RIL_REQUEST_SET_UNSOLICITED_RESPONSE_FILTER 139
5523
5524  /**
5525   * RIL_REQUEST_SET_SIM_CARD_POWER
5526   *
5527   * Set SIM card power up or down
5528   *
5529   * Request is equivalent to inserting and removing the card, with
5530   * an additional effect where the ability to detect card removal/insertion
5531   * is disabled when the SIM card is powered down.
5532   *
5533   * This will generate RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED
5534   * as if the SIM had been inserted or removed.
5535   *
5536   * "data" is int *
5537   * ((int *)data)[0] is 1 for "SIM POWER UP"
5538   * ((int *)data)[0] is 0 for "SIM POWER DOWN"
5539   *
5540   * "response" is NULL
5541   *
5542   * Valid errors:
5543   *  SUCCESS
5544   *  RADIO_NOT_AVAILABLE
5545   *  REQUEST_NOT_SUPPORTED
5546   *  SIM_ABSENT
5547   *  INVALID_ARGUMENTS
5548   */
5549 #define RIL_REQUEST_SET_SIM_CARD_POWER 140
5550 /***********************************************************************/
5551
5552 /**
5553  * RIL_RESPONSE_ACKNOWLEDGEMENT
5554  *
5555  * This is used by Asynchronous solicited messages and Unsolicited messages
5556  * to acknowledge the receipt of those messages in RIL.java so that the ack
5557  * can be used to let ril.cpp to release wakelock.
5558  *
5559  * Valid errors
5560  * SUCCESS
5561  * RADIO_NOT_AVAILABLE
5562  */
5563
5564 #define RIL_RESPONSE_ACKNOWLEDGEMENT 800
5565
5566 /***********************************************************************/
5567
5568
5569 #define RIL_UNSOL_RESPONSE_BASE 1000
5570
5571 /**
5572  * RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED
5573  *
5574  * Indicate when value of RIL_RadioState has changed.
5575  *
5576  * Callee will invoke RIL_RadioStateRequest method on main thread
5577  *
5578  * "data" is NULL
5579  */
5580
5581 #define RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED 1000
5582
5583
5584 /**
5585  * RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED
5586  *
5587  * Indicate when call state has changed
5588  *
5589  * Callee will invoke RIL_REQUEST_GET_CURRENT_CALLS on main thread
5590  *
5591  * "data" is NULL
5592  *
5593  * Response should be invoked on, for example,
5594  * "RING", "BUSY", "NO CARRIER", and also call state
5595  * transitions (DIALING->ALERTING ALERTING->ACTIVE)
5596  *
5597  * Redundent or extraneous invocations are tolerated
5598  */
5599 #define RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED 1001
5600
5601
5602 /**
5603  * RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED
5604  *
5605  * Called when the voice network state changed
5606  *
5607  * Callee will invoke the following requests on main thread:
5608  *
5609  * RIL_REQUEST_VOICE_REGISTRATION_STATE
5610  * RIL_REQUEST_OPERATOR
5611  *
5612  * "data" is NULL
5613  *
5614  * FIXME should this happen when SIM records are loaded? (eg, for
5615  * EONS)
5616  */
5617 #define RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED 1002
5618
5619 /**
5620  * RIL_UNSOL_RESPONSE_NEW_SMS
5621  *
5622  * Called when new SMS is received.
5623  *
5624  * "data" is const char *
5625  * This is a pointer to a string containing the PDU of an SMS-DELIVER
5626  * as an ascii string of hex digits. The PDU starts with the SMSC address
5627  * per TS 27.005 (+CMT:)
5628  *
5629  * Callee will subsequently confirm the receipt of thei SMS with a
5630  * RIL_REQUEST_SMS_ACKNOWLEDGE
5631  *
5632  * No new RIL_UNSOL_RESPONSE_NEW_SMS
5633  * or RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT messages should be sent until a
5634  * RIL_REQUEST_SMS_ACKNOWLEDGE has been received
5635  */
5636
5637 #define RIL_UNSOL_RESPONSE_NEW_SMS 1003
5638
5639 /**
5640  * RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT
5641  *
5642  * Called when new SMS Status Report is received.
5643  *
5644  * "data" is const char *
5645  * This is a pointer to a string containing the PDU of an SMS-STATUS-REPORT
5646  * as an ascii string of hex digits. The PDU starts with the SMSC address
5647  * per TS 27.005 (+CDS:).
5648  *
5649  * Callee will subsequently confirm the receipt of the SMS with a
5650  * RIL_REQUEST_SMS_ACKNOWLEDGE
5651  *
5652  * No new RIL_UNSOL_RESPONSE_NEW_SMS
5653  * or RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT messages should be sent until a
5654  * RIL_REQUEST_SMS_ACKNOWLEDGE has been received
5655  */
5656
5657 #define RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT 1004
5658
5659 /**
5660  * RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM
5661  *
5662  * Called when new SMS has been stored on SIM card
5663  *
5664  * "data" is const int *
5665  * ((const int *)data)[0] contains the slot index on the SIM that contains
5666  * the new message
5667  */
5668
5669 #define RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM 1005
5670
5671 /**
5672  * RIL_UNSOL_ON_USSD
5673  *
5674  * Called when a new USSD message is received.
5675  *
5676  * "data" is const char **
5677  * ((const char **)data)[0] points to a type code, which is
5678  *  one of these string values:
5679  *      "0"   USSD-Notify -- text in ((const char **)data)[1]
5680  *      "1"   USSD-Request -- text in ((const char **)data)[1]
5681  *      "2"   Session terminated by network
5682  *      "3"   other local client (eg, SIM Toolkit) has responded
5683  *      "4"   Operation not supported
5684  *      "5"   Network timeout
5685  *
5686  * The USSD session is assumed to persist if the type code is "1", otherwise
5687  * the current session (if any) is assumed to have terminated.
5688  *
5689  * ((const char **)data)[1] points to a message string if applicable, which
5690  * should always be in UTF-8.
5691  */
5692 #define RIL_UNSOL_ON_USSD 1006
5693 /* Previously #define RIL_UNSOL_ON_USSD_NOTIFY 1006   */
5694
5695 /**
5696  * RIL_UNSOL_ON_USSD_REQUEST
5697  *
5698  * Obsolete. Send via RIL_UNSOL_ON_USSD
5699  */
5700 #define RIL_UNSOL_ON_USSD_REQUEST 1007
5701
5702 /**
5703  * RIL_UNSOL_NITZ_TIME_RECEIVED
5704  *
5705  * Called when radio has received a NITZ time message
5706  *
5707  * "data" is const char * pointing to NITZ time string
5708  * in the form "yy/mm/dd,hh:mm:ss(+/-)tz,dt"
5709  */
5710 #define RIL_UNSOL_NITZ_TIME_RECEIVED  1008
5711
5712 /**
5713  * RIL_UNSOL_SIGNAL_STRENGTH
5714  *
5715  * Radio may report signal strength rather han have it polled.
5716  *
5717  * "data" is a const RIL_SignalStrength *
5718  */
5719 #define RIL_UNSOL_SIGNAL_STRENGTH  1009
5720
5721
5722 /**
5723  * RIL_UNSOL_DATA_CALL_LIST_CHANGED
5724  *
5725  * "data" is an array of RIL_Data_Call_Response_v6 identical to that
5726  * returned by RIL_REQUEST_DATA_CALL_LIST. It is the complete list
5727  * of current data contexts including new contexts that have been
5728  * activated. A data call is only removed from this list when the
5729  * framework sends a RIL_REQUEST_DEACTIVATE_DATA_CALL or the radio
5730  * is powered off/on.
5731  *
5732  * See also: RIL_REQUEST_DATA_CALL_LIST
5733  */
5734
5735 #define RIL_UNSOL_DATA_CALL_LIST_CHANGED 1010
5736
5737 /**
5738  * RIL_UNSOL_SUPP_SVC_NOTIFICATION
5739  *
5740  * Reports supplementary service related notification from the network.
5741  *
5742  * "data" is a const RIL_SuppSvcNotification *
5743  *
5744  */
5745
5746 #define RIL_UNSOL_SUPP_SVC_NOTIFICATION 1011
5747
5748 /**
5749  * RIL_UNSOL_STK_SESSION_END
5750  *
5751  * Indicate when STK session is terminated by SIM.
5752  *
5753  * "data" is NULL
5754  */
5755 #define RIL_UNSOL_STK_SESSION_END 1012
5756
5757 /**
5758  * RIL_UNSOL_STK_PROACTIVE_COMMAND
5759  *
5760  * Indicate when SIM issue a STK proactive command to applications
5761  *
5762  * "data" is a const char * containing SAT/USAT proactive command
5763  * in hexadecimal format string starting with command tag
5764  *
5765  */
5766 #define RIL_UNSOL_STK_PROACTIVE_COMMAND 1013
5767
5768 /**
5769  * RIL_UNSOL_STK_EVENT_NOTIFY
5770  *
5771  * Indicate when SIM notifies applcations some event happens.
5772  * Generally, application does not need to have any feedback to
5773  * SIM but shall be able to indicate appropriate messages to users.
5774  *
5775  * "data" is a const char * containing SAT/USAT commands or responses
5776  * sent by ME to SIM or commands handled by ME, in hexadecimal format string
5777  * starting with first byte of response data or command tag
5778  *
5779  */
5780 #define RIL_UNSOL_STK_EVENT_NOTIFY 1014
5781
5782 /**
5783  * RIL_UNSOL_STK_CALL_SETUP
5784  *
5785  * Indicate when SIM wants application to setup a voice call.
5786  *
5787  * "data" is const int *
5788  * ((const int *)data)[0] contains timeout value (in milliseconds)
5789  */
5790 #define RIL_UNSOL_STK_CALL_SETUP 1015
5791
5792 /**
5793  * RIL_UNSOL_SIM_SMS_STORAGE_FULL
5794  *
5795  * Indicates that SMS storage on the SIM is full.  Sent when the network
5796  * attempts to deliver a new SMS message.  Messages cannot be saved on the
5797  * SIM until space is freed.  In particular, incoming Class 2 messages
5798  * cannot be stored.
5799  *
5800  * "data" is null
5801  *
5802  */
5803 #define RIL_UNSOL_SIM_SMS_STORAGE_FULL 1016
5804
5805 /**
5806  * RIL_UNSOL_SIM_REFRESH
5807  *
5808  * Indicates that file(s) on the SIM have been updated, or the SIM
5809  * has been reinitialized.
5810  *
5811  * In the case where RIL is version 6 or older:
5812  * "data" is an int *
5813  * ((int *)data)[0] is a RIL_SimRefreshResult.
5814  * ((int *)data)[1] is the EFID of the updated file if the result is
5815  * SIM_FILE_UPDATE or NULL for any other result.
5816  *
5817  * In the case where RIL is version 7:
5818  * "data" is a RIL_SimRefreshResponse_v7 *
5819  *
5820  * Note: If the SIM state changes as a result of the SIM refresh (eg,
5821  * SIM_READY -> SIM_LOCKED_OR_ABSENT), RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED
5822  * should be sent.
5823  */
5824 #define RIL_UNSOL_SIM_REFRESH 1017
5825
5826 /**
5827  * RIL_UNSOL_CALL_RING
5828  *
5829  * Ring indication for an incoming call (eg, RING or CRING event).
5830  * There must be at least one RIL_UNSOL_CALL_RING at the beginning
5831  * of a call and sending multiple is optional. If the system property
5832  * ro.telephony.call_ring.multiple is false then the upper layers
5833  * will generate the multiple events internally. Otherwise the vendor
5834  * ril must generate multiple RIL_UNSOL_CALL_RING if
5835  * ro.telephony.call_ring.multiple is true or if it is absent.
5836  *
5837  * The rate of these events is controlled by ro.telephony.call_ring.delay
5838  * and has a default value of 3000 (3 seconds) if absent.
5839  *
5840  * "data" is null for GSM
5841  * "data" is const RIL_CDMA_SignalInfoRecord * if CDMA
5842  */
5843 #define RIL_UNSOL_CALL_RING 1018
5844
5845 /**
5846  * RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED
5847  *
5848  * Indicates that SIM state changes.
5849  *
5850  * Callee will invoke RIL_REQUEST_GET_SIM_STATUS on main thread
5851
5852  * "data" is null
5853  */
5854 #define RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED 1019
5855
5856 /**
5857  * RIL_UNSOL_RESPONSE_CDMA_NEW_SMS
5858  *
5859  * Called when new CDMA SMS is received
5860  *
5861  * "data" is const RIL_CDMA_SMS_Message *
5862  *
5863  * Callee will subsequently confirm the receipt of the SMS with
5864  * a RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE
5865  *
5866  * No new RIL_UNSOL_RESPONSE_CDMA_NEW_SMS should be sent until
5867  * RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE has been received
5868  *
5869  */
5870 #define RIL_UNSOL_RESPONSE_CDMA_NEW_SMS 1020
5871
5872 /**
5873  * RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS
5874  *
5875  * Called when new Broadcast SMS is received
5876  *
5877  * "data" can be one of the following:
5878  * If received from GSM network, "data" is const char of 88 bytes
5879  * which indicates each page of a CBS Message sent to the MS by the
5880  * BTS as coded in 3GPP 23.041 Section 9.4.1.2.
5881  * If received from UMTS network, "data" is const char of 90 up to 1252
5882  * bytes which contain between 1 and 15 CBS Message pages sent as one
5883  * packet to the MS by the BTS as coded in 3GPP 23.041 Section 9.4.2.2.
5884  *
5885  */
5886 #define RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS 1021
5887
5888 /**
5889  * RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL
5890  *
5891  * Indicates that SMS storage on the RUIM is full.  Messages
5892  * cannot be saved on the RUIM until space is freed.
5893  *
5894  * "data" is null
5895  *
5896  */
5897 #define RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL 1022
5898
5899 /**
5900  * RIL_UNSOL_RESTRICTED_STATE_CHANGED
5901  *
5902  * Indicates a restricted state change (eg, for Domain Specific Access Control).
5903  *
5904  * Radio need send this msg after radio off/on cycle no matter it is changed or not.
5905  *
5906  * "data" is an int *
5907  * ((int *)data)[0] contains a bitmask of RIL_RESTRICTED_STATE_* values.
5908  */
5909 #define RIL_UNSOL_RESTRICTED_STATE_CHANGED 1023
5910
5911 /**
5912  * RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE
5913  *
5914  * Indicates that the radio system selection module has
5915  * autonomously entered emergency callback mode.
5916  *
5917  * "data" is null
5918  *
5919  */
5920 #define RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE 1024
5921
5922 /**
5923  * RIL_UNSOL_CDMA_CALL_WAITING
5924  *
5925  * Called when CDMA radio receives a call waiting indication.
5926  *
5927  * "data" is const RIL_CDMA_CallWaiting *
5928  *
5929  */
5930 #define RIL_UNSOL_CDMA_CALL_WAITING 1025
5931
5932 /**
5933  * RIL_UNSOL_CDMA_OTA_PROVISION_STATUS
5934  *
5935  * Called when CDMA radio receives an update of the progress of an
5936  * OTASP/OTAPA call.
5937  *
5938  * "data" is const int *
5939  *  For CDMA this is an integer OTASP/OTAPA status listed in
5940  *  RIL_CDMA_OTA_ProvisionStatus.
5941  *
5942  */
5943 #define RIL_UNSOL_CDMA_OTA_PROVISION_STATUS 1026
5944
5945 /**
5946  * RIL_UNSOL_CDMA_INFO_REC
5947  *
5948  * Called when CDMA radio receives one or more info recs.
5949  *
5950  * "data" is const RIL_CDMA_InformationRecords *
5951  *
5952  */
5953 #define RIL_UNSOL_CDMA_INFO_REC 1027
5954
5955 /**
5956  * RIL_UNSOL_OEM_HOOK_RAW
5957  *
5958  * This is for OEM specific use.
5959  *
5960  * "data" is a byte[]
5961  */
5962 #define RIL_UNSOL_OEM_HOOK_RAW 1028
5963
5964 /**
5965  * RIL_UNSOL_RINGBACK_TONE
5966  *
5967  * Indicates that nework doesn't have in-band information,  need to
5968  * play out-band tone.
5969  *
5970  * "data" is an int *
5971  * ((int *)data)[0] == 0 for stop play ringback tone.
5972  * ((int *)data)[0] == 1 for start play ringback tone.
5973  */
5974 #define RIL_UNSOL_RINGBACK_TONE 1029
5975
5976 /**
5977  * RIL_UNSOL_RESEND_INCALL_MUTE
5978  *
5979  * Indicates that framework/application need reset the uplink mute state.
5980  *
5981  * There may be situations where the mute state becomes out of sync
5982  * between the application and device in some GSM infrastructures.
5983  *
5984  * "data" is null
5985  */
5986 #define RIL_UNSOL_RESEND_INCALL_MUTE 1030
5987
5988 /**
5989  * RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED
5990  *
5991  * Called when CDMA subscription source changed.
5992  *
5993  * "data" is int *
5994  * ((int *)data)[0] is == RIL_CdmaSubscriptionSource
5995  */
5996 #define RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED 1031
5997
5998 /**
5999  * RIL_UNSOL_CDMA_PRL_CHANGED
6000  *
6001  * Called when PRL (preferred roaming list) changes.
6002  *
6003  * "data" is int *
6004  * ((int *)data)[0] is PRL_VERSION as would be returned by RIL_REQUEST_CDMA_SUBSCRIPTION
6005  */
6006 #define RIL_UNSOL_CDMA_PRL_CHANGED 1032
6007
6008 /**
6009  * RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE
6010  *
6011  * Called when Emergency Callback Mode Ends
6012  *
6013  * Indicates that the radio system selection module has
6014  * proactively exited emergency callback mode.
6015  *
6016  * "data" is NULL
6017  *
6018  */
6019 #define RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE 1033
6020
6021 /**
6022  * RIL_UNSOL_RIL_CONNECTED
6023  *
6024  * Called the ril connects and returns the version
6025  *
6026  * "data" is int *
6027  * ((int *)data)[0] is RIL_VERSION
6028  */
6029 #define RIL_UNSOL_RIL_CONNECTED 1034
6030
6031 /**
6032  * RIL_UNSOL_VOICE_RADIO_TECH_CHANGED
6033  *
6034  * Indicates that voice technology has changed. Contains new radio technology
6035  * as a data in the message.
6036  *
6037  * "data" is int *
6038  * ((int *)data)[0] is of type const RIL_RadioTechnology
6039  *
6040  */
6041 #define RIL_UNSOL_VOICE_RADIO_TECH_CHANGED 1035
6042
6043 /**
6044  * RIL_UNSOL_CELL_INFO_LIST
6045  *
6046  * Same information as returned by RIL_REQUEST_GET_CELL_INFO_LIST, but returned
6047  * at the rate no greater than specified by RIL_REQUEST_SET_UNSOL_CELL_INFO_RATE.
6048  *
6049  * "data" is NULL
6050  *
6051  * "response" is an array of RIL_CellInfo_v12.
6052  */
6053 #define RIL_UNSOL_CELL_INFO_LIST 1036
6054
6055 /**
6056  * RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED
6057  *
6058  * This message is DEPRECATED and shall be removed in a future release (target: 2018);
6059  * instead, provide IMS registration status via an IMS Service.
6060  *
6061  * Called when IMS registration state has changed
6062  *
6063  * To get IMS registration state and IMS SMS format, callee needs to invoke the
6064  * following request on main thread:
6065  *
6066  * RIL_REQUEST_IMS_REGISTRATION_STATE
6067  *
6068  * "data" is NULL
6069  *
6070  */
6071 #define RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED 1037
6072
6073 /**
6074  * RIL_UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED
6075  *
6076  * Indicated when there is a change in subscription status.
6077  * This event will be sent in the following scenarios
6078  *  - subscription readiness at modem, which was selected by telephony layer
6079  *  - when subscription is deactivated by modem due to UICC card removal
6080  *  - When network invalidates the subscription i.e. attach reject due to authentication reject
6081  *
6082  * "data" is const int *
6083  * ((const int *)data)[0] == 0 for Subscription Deactivated
6084  * ((const int *)data)[0] == 1 for Subscription Activated
6085  *
6086  */
6087 #define RIL_UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED 1038
6088
6089 /**
6090  * RIL_UNSOL_SRVCC_STATE_NOTIFY
6091  *
6092  * Called when Single Radio Voice Call Continuity(SRVCC)
6093  * progress state has changed
6094  *
6095  * "data" is int *
6096  * ((int *)data)[0] is of type const RIL_SrvccState
6097  *
6098  */
6099
6100 #define RIL_UNSOL_SRVCC_STATE_NOTIFY 1039
6101
6102 /**
6103  * RIL_UNSOL_HARDWARE_CONFIG_CHANGED
6104  *
6105  * Called when the hardware configuration associated with the RILd changes
6106  *
6107  * "data" is an array of RIL_HardwareConfig
6108  *
6109  */
6110 #define RIL_UNSOL_HARDWARE_CONFIG_CHANGED 1040
6111
6112 /**
6113  * RIL_UNSOL_DC_RT_INFO_CHANGED
6114  *
6115  * The message is DEPRECATED, use RIL_REQUEST_GET_ACTIVITY_INFO
6116  * Sent when the DC_RT_STATE changes but the time
6117  * between these messages must not be less than the
6118  * value set by RIL_REQUEST_SET_DC_RT_RATE.
6119  *
6120  * "data" is the most recent RIL_DcRtInfo
6121  *
6122  */
6123 #define RIL_UNSOL_DC_RT_INFO_CHANGED 1041
6124
6125 /**
6126  * RIL_UNSOL_RADIO_CAPABILITY
6127  *
6128  * Sent when RIL_REQUEST_SET_RADIO_CAPABILITY completes.
6129  * Returns the phone radio capability exactly as
6130  * RIL_REQUEST_GET_RADIO_CAPABILITY and should be the
6131  * same set as sent by RIL_REQUEST_SET_RADIO_CAPABILITY.
6132  *
6133  * "data" is the RIL_RadioCapability structure
6134  */
6135 #define RIL_UNSOL_RADIO_CAPABILITY 1042
6136
6137 /*
6138  * RIL_UNSOL_ON_SS
6139  *
6140  * Called when SS response is received when DIAL/USSD/SS is changed to SS by
6141  * call control.
6142  *
6143  * "data" is const RIL_StkCcUnsolSsResponse *
6144  *
6145  */
6146 #define RIL_UNSOL_ON_SS 1043
6147
6148 /**
6149  * RIL_UNSOL_STK_CC_ALPHA_NOTIFY
6150  *
6151  * Called when there is an ALPHA from UICC during Call Control.
6152  *
6153  * "data" is const char * containing ALPHA string from UICC in UTF-8 format.
6154  *
6155  */
6156 #define RIL_UNSOL_STK_CC_ALPHA_NOTIFY 1044
6157
6158 /**
6159  * RIL_UNSOL_LCEDATA_RECV
6160  *
6161  * Called when there is an incoming Link Capacity Estimate (LCE) info report.
6162  *
6163  * "data" is the RIL_LceDataInfo structure.
6164  *
6165  */
6166 #define RIL_UNSOL_LCEDATA_RECV 1045
6167
6168  /**
6169   * RIL_UNSOL_PCO_DATA
6170   *
6171   * Called when there is new Carrier PCO data received for a data call.  Ideally
6172   * only new data will be forwarded, though this is not required.  Multiple
6173   * boxes of carrier PCO data for a given call should result in a series of
6174   * RIL_UNSOL_PCO_DATA calls.
6175   *
6176   * "data" is the RIL_PCO_Data structure.
6177   *
6178   */
6179 #define RIL_UNSOL_PCO_DATA 1046
6180
6181  /**
6182   * RIL_UNSOL_MODEM_RESTART
6183   *
6184   * Called when there is a modem reset.
6185   *
6186   * "reason" is "const char *" containing the reason for the reset. It
6187   * could be a crash signature if the restart was due to a crash or some
6188   * string such as "user-initiated restart" or "AT command initiated
6189   * restart" that explains the cause of the modem restart.
6190   *
6191   * When modem restarts, one of the following radio state transitions will happen
6192   * 1) RADIO_STATE_ON->RADIO_STATE_UNAVAILABLE->RADIO_STATE_ON or
6193   * 2) RADIO_STATE_OFF->RADIO_STATE_UNAVAILABLE->RADIO_STATE_OFF
6194   * This message can be sent either just before the RADIO_STATE changes to RADIO_STATE_UNAVAILABLE
6195   * or just after but should never be sent after the RADIO_STATE changes from UNAVAILABLE to
6196   * AVAILABLE(RADIO_STATE_ON/RADIO_STATE_OFF) again.
6197   *
6198   * It should NOT be sent after the RADIO_STATE changes to AVAILABLE after the
6199   * modem restart as that could be interpreted as a second modem reset by the
6200   * framework.
6201   */
6202 #define RIL_UNSOL_MODEM_RESTART 1047
6203
6204 /***********************************************************************/
6205
6206
6207 #if defined(ANDROID_MULTI_SIM)
6208 /**
6209  * RIL_Request Function pointer
6210  *
6211  * @param request is one of RIL_REQUEST_*
6212  * @param data is pointer to data defined for that RIL_REQUEST_*
6213  *        data is owned by caller, and should not be modified or freed by callee
6214  *        structures passed as data may contain pointers to non-contiguous memory
6215  * @param t should be used in subsequent call to RIL_onResponse
6216  * @param datalen is the length of "data" which is defined as other argument. It may or may
6217  *        not be equal to sizeof(data). Refer to the documentation of individual structures
6218  *        to find if pointers listed in the structure are contiguous and counted in the datalen
6219  *        length or not.
6220  *        (Eg: RIL_IMS_SMS_Message where we don't have datalen equal to sizeof(data))
6221  *
6222  */
6223 typedef void (*RIL_RequestFunc) (int request, void *data,
6224                                     size_t datalen, RIL_Token t, RIL_SOCKET_ID socket_id);
6225
6226 /**
6227  * This function should return the current radio state synchronously
6228  */
6229 typedef RIL_RadioState (*RIL_RadioStateRequest)(RIL_SOCKET_ID socket_id);
6230
6231 #else
6232 /* Backward compatible */
6233
6234 /**
6235  * RIL_Request Function pointer
6236  *
6237  * @param request is one of RIL_REQUEST_*
6238  * @param data is pointer to data defined for that RIL_REQUEST_*
6239  *        data is owned by caller, and should not be modified or freed by callee
6240  *        structures passed as data may contain pointers to non-contiguous memory
6241  * @param t should be used in subsequent call to RIL_onResponse
6242  * @param datalen is the length of "data" which is defined as other argument. It may or may
6243  *        not be equal to sizeof(data). Refer to the documentation of individual structures
6244  *        to find if pointers listed in the structure are contiguous and counted in the datalen
6245  *        length or not.
6246  *        (Eg: RIL_IMS_SMS_Message where we don't have datalen equal to sizeof(data))
6247  *
6248  */
6249 typedef void (*RIL_RequestFunc) (int request, void *data,
6250                                     size_t datalen, RIL_Token t);
6251
6252 /**
6253  * This function should return the current radio state synchronously
6254  */
6255 typedef RIL_RadioState (*RIL_RadioStateRequest)();
6256
6257 #endif
6258
6259
6260 /**
6261  * This function returns "1" if the specified RIL_REQUEST code is
6262  * supported and 0 if it is not
6263  *
6264  * @param requestCode is one of RIL_REQUEST codes
6265  */
6266
6267 typedef int (*RIL_Supports)(int requestCode);
6268
6269 /**
6270  * This function is called from a separate thread--not the
6271  * thread that calls RIL_RequestFunc--and indicates that a pending
6272  * request should be cancelled.
6273  *
6274  * On cancel, the callee should do its best to abandon the request and
6275  * call RIL_onRequestComplete with RIL_Errno CANCELLED at some later point.
6276  *
6277  * Subsequent calls to  RIL_onRequestComplete for this request with
6278  * other results will be tolerated but ignored. (That is, it is valid
6279  * to ignore the cancellation request)
6280  *
6281  * RIL_Cancel calls should return immediately, and not wait for cancellation
6282  *
6283  * Please see ITU v.250 5.6.1 for how one might implement this on a TS 27.007
6284  * interface
6285  *
6286  * @param t token wants to be canceled
6287  */
6288
6289 typedef void (*RIL_Cancel)(RIL_Token t);
6290
6291 typedef void (*RIL_TimedCallback) (void *param);
6292
6293 /**
6294  * Return a version string for your RIL implementation
6295  */
6296 typedef const char * (*RIL_GetVersion) (void);
6297
6298 typedef struct {
6299     int version;        /* set to RIL_VERSION */
6300     RIL_RequestFunc onRequest;
6301     RIL_RadioStateRequest onStateRequest;
6302     RIL_Supports supports;
6303     RIL_Cancel onCancel;
6304     RIL_GetVersion getVersion;
6305 } RIL_RadioFunctions;
6306
6307 typedef struct {
6308     char *apn;                  /* the APN to connect to */
6309     char *protocol;             /* one of the PDP_type values in TS 27.007 section 10.1.1 used on
6310                                    roaming network. For example, "IP", "IPV6", "IPV4V6", or "PPP".*/
6311     int authtype;               /* authentication protocol used for this PDP context
6312                                    (None: 0, PAP: 1, CHAP: 2, PAP&CHAP: 3) */
6313     char *username;             /* the username for APN, or NULL */
6314     char *password;             /* the password for APN, or NULL */
6315 } RIL_InitialAttachApn;
6316
6317 typedef struct {
6318     char *apn;                  /* the APN to connect to */
6319     char *protocol;             /* one of the PDP_type values in TS 27.007 section 10.1.1 used on
6320                                    home network. For example, "IP", "IPV6", "IPV4V6", or "PPP". */
6321     char *roamingProtocol;      /* one of the PDP_type values in TS 27.007 section 10.1.1 used on
6322                                    roaming network. For example, "IP", "IPV6", "IPV4V6", or "PPP".*/
6323     int authtype;               /* authentication protocol used for this PDP context
6324                                    (None: 0, PAP: 1, CHAP: 2, PAP&CHAP: 3) */
6325     char *username;             /* the username for APN, or NULL */
6326     char *password;             /* the password for APN, or NULL */
6327     int supportedTypesBitmask;  /* supported APN types bitmask. See RIL_ApnTypes for the value of
6328                                    each bit. */
6329     int bearerBitmask;          /* the bearer bitmask. See RIL_RadioAccessFamily for the value of
6330                                    each bit. */
6331     int modemCognitive;         /* indicating the APN setting was sent to the modem through
6332                                    setDataProfile earlier. */
6333     int mtu;                    /* maximum transmission unit (MTU) size in bytes */
6334     char *mvnoType;             /* the MVNO type: possible values are "imsi", "gid", "spn" */
6335     char *mvnoMatchData;        /* MVNO match data. Can be anything defined by the carrier.
6336                                    For example,
6337                                      SPN like: "A MOBILE", "BEN NL", etc...
6338                                      IMSI like: "302720x94", "2060188", etc...
6339                                      GID like: "4E", "33", etc... */
6340 } RIL_InitialAttachApn_v15;
6341
6342 typedef struct {
6343     int authContext;            /* P2 value of authentication command, see P2 parameter in
6344                                    3GPP TS 31.102 7.1.2 */
6345     char *authData;             /* the challenge string in Base64 format, see 3GPP
6346                                    TS 31.102 7.1.2 */
6347     char *aid;                  /* AID value, See ETSI 102.221 8.1 and 101.220 4,
6348                                    NULL if no value. */
6349 } RIL_SimAuthentication;
6350
6351 typedef struct {
6352     int cid;                    /* Context ID, uniquely identifies this call */
6353     char *bearer_proto;         /* One of the PDP_type values in TS 27.007 section 10.1.1.
6354                                    For example, "IP", "IPV6", "IPV4V6". */
6355     int pco_id;                 /* The protocol ID for this box.  Note that only IDs from
6356                                    FF00H - FFFFH are accepted.  If more than one is included
6357                                    from the network, multiple calls should be made to send all
6358                                    of them. */
6359     int contents_length;        /* The number of octets in the contents. */
6360     char *contents;             /* Carrier-defined content.  It is binary, opaque and
6361                                    loosely defined in LTE Layer 3 spec 24.008 */
6362 } RIL_PCO_Data;
6363
6364 #ifdef RIL_SHLIB
6365 struct RIL_Env {
6366     /**
6367      * "t" is parameter passed in on previous call to RIL_Notification
6368      * routine.
6369      *
6370      * If "e" != SUCCESS, then response can be null/is ignored
6371      *
6372      * "response" is owned by caller, and should not be modified or
6373      * freed by callee
6374      *
6375      * RIL_onRequestComplete will return as soon as possible
6376      */
6377     void (*OnRequestComplete)(RIL_Token t, RIL_Errno e,
6378                            void *response, size_t responselen);
6379
6380 #if defined(ANDROID_MULTI_SIM)
6381     /**
6382      * "unsolResponse" is one of RIL_UNSOL_RESPONSE_*
6383      * "data" is pointer to data defined for that RIL_UNSOL_RESPONSE_*
6384      *
6385      * "data" is owned by caller, and should not be modified or freed by callee
6386      */
6387     void (*OnUnsolicitedResponse)(int unsolResponse, const void *data, size_t datalen, RIL_SOCKET_ID socket_id);
6388 #else
6389     /**
6390      * "unsolResponse" is one of RIL_UNSOL_RESPONSE_*
6391      * "data" is pointer to data defined for that RIL_UNSOL_RESPONSE_*
6392      *
6393      * "data" is owned by caller, and should not be modified or freed by callee
6394      */
6395     void (*OnUnsolicitedResponse)(int unsolResponse, const void *data, size_t datalen);
6396 #endif
6397     /**
6398      * Call user-specifed "callback" function on on the same thread that
6399      * RIL_RequestFunc is called. If "relativeTime" is specified, then it specifies
6400      * a relative time value at which the callback is invoked. If relativeTime is
6401      * NULL or points to a 0-filled structure, the callback will be invoked as
6402      * soon as possible
6403      */
6404
6405     void (*RequestTimedCallback) (RIL_TimedCallback callback,
6406                                    void *param, const struct timeval *relativeTime);
6407    /**
6408     * "t" is parameter passed in on previous call RIL_Notification routine
6409     *
6410     * RIL_onRequestAck will be called by vendor when an Async RIL request was received
6411     * by them and an ack needs to be sent back to java ril.
6412     */
6413     void (*OnRequestAck) (RIL_Token t);
6414 };
6415
6416
6417 /**
6418  *  RIL implementations must defined RIL_Init
6419  *  argc and argv will be command line arguments intended for the RIL implementation
6420  *  Return NULL on error
6421  *
6422  * @param env is environment point defined as RIL_Env
6423  * @param argc number of arguments
6424  * @param argv list fo arguments
6425  *
6426  */
6427 const RIL_RadioFunctions *RIL_Init(const struct RIL_Env *env, int argc, char **argv);
6428
6429 /**
6430  *  If BT SAP(SIM Access Profile) is supported, then RIL implementations must define RIL_SAP_Init
6431  *  for initializing RIL_RadioFunctions used for BT SAP communcations. It is called whenever RILD
6432  *  starts or modem restarts. Returns handlers for SAP related request that are made on SAP
6433  *  sepecific socket, analogous to the RIL_RadioFunctions returned by the call to RIL_Init
6434  *  and used on the general RIL socket.
6435  *  argc and argv will be command line arguments intended for the RIL implementation
6436  *  Return NULL on error.
6437  *
6438  * @param env is environment point defined as RIL_Env
6439  * @param argc number of arguments
6440  * @param argv list fo arguments
6441  *
6442  */
6443 const RIL_RadioFunctions *RIL_SAP_Init(const struct RIL_Env *env, int argc, char **argv);
6444
6445 #else /* RIL_SHLIB */
6446
6447 /**
6448  * Call this once at startup to register notification routine
6449  *
6450  * @param callbacks user-specifed callback function
6451  */
6452 void RIL_register (const RIL_RadioFunctions *callbacks);
6453
6454 void rilc_thread_pool();
6455
6456
6457 /**
6458  *
6459  * RIL_onRequestComplete will return as soon as possible
6460  *
6461  * @param t is parameter passed in on previous call to RIL_Notification
6462  *          routine.
6463  * @param e error code
6464  *          if "e" != SUCCESS, then response can be null/is ignored
6465  * @param response is owned by caller, and should not be modified or
6466  *                 freed by callee
6467  * @param responselen the length of response in byte
6468  */
6469 void RIL_onRequestComplete(RIL_Token t, RIL_Errno e,
6470                            void *response, size_t responselen);
6471
6472 /**
6473  * RIL_onRequestAck will be called by vendor when an Async RIL request was received by them and
6474  * an ack needs to be sent back to java ril. This doesn't mark the end of the command or it's
6475  * results, just that the command was received and will take a while. After sending this Ack
6476  * its vendor's responsibility to make sure that AP is up whenever needed while command is
6477  * being processed.
6478  *
6479  * @param t is parameter passed in on previous call to RIL_Notification
6480  *          routine.
6481  */
6482 void RIL_onRequestAck(RIL_Token t);
6483
6484 #if defined(ANDROID_MULTI_SIM)
6485 /**
6486  * @param unsolResponse is one of RIL_UNSOL_RESPONSE_*
6487  * @param data is pointer to data defined for that RIL_UNSOL_RESPONSE_*
6488  *     "data" is owned by caller, and should not be modified or freed by callee
6489  * @param datalen the length of data in byte
6490  */
6491
6492 void RIL_onUnsolicitedResponse(int unsolResponse, const void *data,
6493                                 size_t datalen, RIL_SOCKET_ID socket_id);
6494 #else
6495 /**
6496  * @param unsolResponse is one of RIL_UNSOL_RESPONSE_*
6497  * @param data is pointer to data defined for that RIL_UNSOL_RESPONSE_*
6498  *     "data" is owned by caller, and should not be modified or freed by callee
6499  * @param datalen the length of data in byte
6500  */
6501
6502 void RIL_onUnsolicitedResponse(int unsolResponse, const void *data,
6503                                 size_t datalen);
6504 #endif
6505
6506 /**
6507  * Call user-specifed "callback" function on on the same thread that
6508  * RIL_RequestFunc is called. If "relativeTime" is specified, then it specifies
6509  * a relative time value at which the callback is invoked. If relativeTime is
6510  * NULL or points to a 0-filled structure, the callback will be invoked as
6511  * soon as possible
6512  *
6513  * @param callback user-specifed callback function
6514  * @param param parameter list
6515  * @param relativeTime a relative time value at which the callback is invoked
6516  */
6517
6518 void RIL_requestTimedCallback (RIL_TimedCallback callback,
6519                                void *param, const struct timeval *relativeTime);
6520
6521 #endif /* RIL_SHLIB */
6522
6523 #ifdef __cplusplus
6524 }
6525 #endif
6526
6527 #endif /*ANDROID_RIL_H*/