diff options
| -rw-r--r-- | BoardConfig.mk | 4 | ||||
| -rw-r--r-- | cm.mk | 3 | ||||
| -rw-r--r-- | include/telephony/ril.h | 5394 | ||||
| -rw-r--r-- | selinux/device.te | 4 | ||||
| -rwxr-xr-x | selinux/dhcp.te | 1 | ||||
| -rw-r--r-- | selinux/domain.te | 4 | ||||
| -rw-r--r-- | selinux/file.te | 9 | ||||
| -rw-r--r-- | selinux/file_contexts | 70 | ||||
| -rw-r--r-- | selinux/init.te | 3 | ||||
| -rwxr-xr-x | selinux/kickstart.te | 44 | ||||
| -rw-r--r-- | selinux/mediaserver.te | 8 | ||||
| -rwxr-xr-x | selinux/netmgrd.te | 29 | ||||
| -rwxr-xr-x | selinux/qmux.te | 21 | ||||
| -rwxr-xr-x | selinux/rild.te | 14 | ||||
| -rw-r--r-- | selinux/secril.te | 25 | ||||
| -rwxr-xr-x | selinux/system.te | 12 | ||||
| -rwxr-xr-x | selinux/te_macros | 12 | ||||
| -rw-r--r-- | selinux/ueventd.te | 11 | ||||
| -rwxr-xr-x | selinux/wpa_supplicant.te | 10 | 
19 files changed, 5397 insertions, 281 deletions
diff --git a/BoardConfig.mk b/BoardConfig.mk index 660414c..f5f2f2d 100644 --- a/BoardConfig.mk +++ b/BoardConfig.mk @@ -14,11 +14,13 @@  # limitations under the License.  # --include device/samsung/smdk4412-qcom-common/BoardCommonConfig.mk  -include device/samsung/smdk4412-common/BoardCommonConfig.mk +-include device/samsung/smdk4412-qcom-common/BoardCommonConfig.mk  LOCAL_PATH := device/samsung/i9305 +TARGET_SPECIFIC_HEADER_PATH += $(LOCAL_PATH)/include +  # Bluetooth  BOARD_BLUETOOTH_BDROID_BUILDCFG_INCLUDE_DIR := $(LOCAL_PATH)/bluetooth @@ -1,6 +1,3 @@ -# Specify phone tech before including full_phone -$(call inherit-product, vendor/cm/config/gsm.mk) -  # Release name  PRODUCT_RELEASE_NAME := i9305 diff --git a/include/telephony/ril.h b/include/telephony/ril.h new file mode 100644 index 0000000..e13ad9f --- /dev/null +++ b/include/telephony/ril.h @@ -0,0 +1,5394 @@ +/* + * Copyright (C) 2006 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + *      http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef ANDROID_RIL_H +#define ANDROID_RIL_H 1 + +#include <stdlib.h> +#include <stdint.h> +#include <telephony/ril_cdma_sms.h> +#include <telephony/ril_nv_items.h> +#include <telephony/ril_msim.h> + +#ifndef FEATURE_UNIT_TEST +#include <sys/time.h> +#endif /* !FEATURE_UNIT_TEST */ + +#ifdef __cplusplus +extern "C" { +#endif + + +#if defined(ANDROID_SIM_COUNT_2) +#define SIM_COUNT 2 +#elif defined(ANDROID_SIM_COUNT_3) +#define SIM_COUNT 3 +#elif defined(ANDROID_SIM_COUNT_4) +#define SIM_COUNT 4 +#else +#define SIM_COUNT 1 +#endif + +#ifndef ANDROID_MULTI_SIM +#define SIM_COUNT 1 +#endif + +#define RIL_VERSION 11     /* Current version */ +#define RIL_VERSION_MIN 6 /* Minimum RIL_VERSION supported */ + +#define CDMA_ALPHA_INFO_BUFFER_LENGTH 64 +#define CDMA_NUMBER_INFO_BUFFER_LENGTH 81 + +#define MAX_RILDS 3 +#define MAX_SOCKET_NAME_LENGTH 6 +#define MAX_CLIENT_ID_LENGTH 2 +#define MAX_DEBUG_SOCKET_NAME_LENGTH 12 +#define MAX_QEMU_PIPE_NAME_LENGTH  11 +#define MAX_UUID_LENGTH 64 + + +typedef void * RIL_Token; + +typedef enum { +    RIL_SOCKET_1, +#if (SIM_COUNT >= 2) +    RIL_SOCKET_2, +#if (SIM_COUNT >= 3) +    RIL_SOCKET_3, +#endif +#if (SIM_COUNT >= 4) +    RIL_SOCKET_4, +#endif +#endif +    RIL_SOCKET_NUM +} RIL_SOCKET_ID; + + +typedef enum { +    RIL_E_SUCCESS = 0, +    RIL_E_RADIO_NOT_AVAILABLE = 1,     /* If radio did not start or is resetting */ +    RIL_E_GENERIC_FAILURE = 2, +    RIL_E_PASSWORD_INCORRECT = 3,      /* for PIN/PIN2 methods only! */ +    RIL_E_SIM_PIN2 = 4,                /* Operation requires SIM PIN2 to be entered */ +    RIL_E_SIM_PUK2 = 5,                /* Operation requires SIM PIN2 to be entered */ +    RIL_E_REQUEST_NOT_SUPPORTED = 6, +    RIL_E_CANCELLED = 7, +    RIL_E_OP_NOT_ALLOWED_DURING_VOICE_CALL = 8, /* data ops are not allowed during voice +                                                   call on a Class C GPRS device */ +    RIL_E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW = 9,  /* data ops are not allowed before device +                                                   registers in network */ +    RIL_E_SMS_SEND_FAIL_RETRY = 10,             /* fail to send sms and need retry */ +    RIL_E_SIM_ABSENT = 11,                      /* fail to set the location where CDMA subscription +                                                   shall be retrieved because of SIM or RUIM +                                                   card absent */ +    RIL_E_SUBSCRIPTION_NOT_AVAILABLE = 12,      /* fail to find CDMA subscription from specified +                                                   location */ +    RIL_E_MODE_NOT_SUPPORTED = 13,              /* HW does not support preferred network type */ +    RIL_E_FDN_CHECK_FAILURE = 14,               /* command failed because recipient is not on FDN list */ +    RIL_E_ILLEGAL_SIM_OR_ME = 15,               /* network selection failed due to +                                                   illegal SIM or ME */ +    RIL_E_MISSING_RESOURCE = 16,                /* no logical channel available */ +    RIL_E_NO_SUCH_ELEMENT = 17,                  /* application not found on SIM */ +    RIL_E_DIAL_MODIFIED_TO_USSD = 18,           /* DIAL request modified to USSD */ +    RIL_E_DIAL_MODIFIED_TO_SS = 19,             /* DIAL request modified to SS */ +    RIL_E_DIAL_MODIFIED_TO_DIAL = 20,           /* DIAL request modified to DIAL with different +                                                   data */ +    RIL_E_USSD_MODIFIED_TO_DIAL = 21,           /* USSD request modified to DIAL */ +    RIL_E_USSD_MODIFIED_TO_SS = 22,             /* USSD request modified to SS */ +    RIL_E_USSD_MODIFIED_TO_USSD = 23,           /* USSD request modified to different USSD +                                                   request */ +    RIL_E_SS_MODIFIED_TO_DIAL = 24,             /* SS request modified to DIAL */ +    RIL_E_SS_MODIFIED_TO_USSD = 25,             /* SS request modified to USSD */ +    RIL_E_SUBSCRIPTION_NOT_SUPPORTED = 26,      /* Subscription not supported by RIL */ +    RIL_E_SS_MODIFIED_TO_SS = 27                /* SS request modified to different SS request */ + + +} RIL_Errno; + +typedef enum { +    RIL_CALL_ACTIVE = 0, +    RIL_CALL_HOLDING = 1, +    RIL_CALL_DIALING = 2,    /* MO call only */ +    RIL_CALL_ALERTING = 3,   /* MO call only */ +    RIL_CALL_INCOMING = 4,   /* MT call only */ +    RIL_CALL_WAITING = 5     /* MT call only */ +} RIL_CallState; + +typedef enum { +    RADIO_STATE_OFF = 0,                   /* Radio explictly powered off (eg CFUN=0) */ +    RADIO_STATE_UNAVAILABLE = 1,           /* Radio unavailable (eg, resetting or not booted) */ +    /* States 2-9 below are deprecated. Just leaving them here for backward compatibility. */ +    RADIO_STATE_SIM_NOT_READY = 2,         /* Radio is on, but the SIM interface is not ready */ +    RADIO_STATE_SIM_LOCKED_OR_ABSENT = 3,  /* SIM PIN locked, PUK required, network +                                              personalization locked, or SIM absent */ +    RADIO_STATE_SIM_READY = 4,             /* Radio is on and SIM interface is available */ +    RADIO_STATE_RUIM_NOT_READY = 5,        /* Radio is on, but the RUIM interface is not ready */ +    RADIO_STATE_RUIM_READY = 6,            /* Radio is on and the RUIM interface is available */ +    RADIO_STATE_RUIM_LOCKED_OR_ABSENT = 7, /* RUIM PIN locked, PUK required, network +                                              personalization locked, or RUIM absent */ +    RADIO_STATE_NV_NOT_READY = 8,          /* Radio is on, but the NV interface is not available */ +    RADIO_STATE_NV_READY = 9,              /* Radio is on and the NV interface is available */ +    RADIO_STATE_ON = 10                    /* Radio is on */ +} RIL_RadioState; + +typedef enum { +    RADIO_TECH_UNKNOWN = 0, +    RADIO_TECH_GPRS = 1, +    RADIO_TECH_EDGE = 2, +    RADIO_TECH_UMTS = 3, +    RADIO_TECH_IS95A = 4, +    RADIO_TECH_IS95B = 5, +    RADIO_TECH_1xRTT =  6, +    RADIO_TECH_EVDO_0 = 7, +    RADIO_TECH_EVDO_A = 8, +    RADIO_TECH_HSDPA = 9, +    RADIO_TECH_HSUPA = 10, +    RADIO_TECH_HSPA = 11, +    RADIO_TECH_EVDO_B = 12, +    RADIO_TECH_EHRPD = 13, +    RADIO_TECH_LTE = 14, +    RADIO_TECH_HSPAP = 15, // HSPA+ +    RADIO_TECH_GSM = 16, // Only supports voice +    RADIO_TECH_TD_SCDMA = 17, +    RADIO_TECH_IWLAN = 18 +} RIL_RadioTechnology; + +typedef enum { +    RAF_UNKNOWN =  (1 <<  RADIO_TECH_UNKNOWN), +    RAF_GPRS = (1 << RADIO_TECH_GPRS), +    RAF_EDGE = (1 << RADIO_TECH_EDGE), +    RAF_UMTS = (1 << RADIO_TECH_UMTS), +    RAF_IS95A = (1 << RADIO_TECH_IS95A), +    RAF_IS95B = (1 << RADIO_TECH_IS95B), +    RAF_1xRTT = (1 << RADIO_TECH_1xRTT), +    RAF_EVDO_0 = (1 << RADIO_TECH_EVDO_0), +    RAF_EVDO_A = (1 << RADIO_TECH_EVDO_A), +    RAF_HSDPA = (1 << RADIO_TECH_HSDPA), +    RAF_HSUPA = (1 << RADIO_TECH_HSUPA), +    RAF_HSPA = (1 << RADIO_TECH_HSPA), +    RAF_EVDO_B = (1 << RADIO_TECH_EVDO_B), +    RAF_EHRPD = (1 << RADIO_TECH_EHRPD), +    RAF_LTE = (1 << RADIO_TECH_LTE), +    RAF_HSPAP = (1 << RADIO_TECH_HSPAP), +    RAF_GSM = (1 << RADIO_TECH_GSM), +    RAF_TD_SCDMA = (1 << RADIO_TECH_TD_SCDMA), +} RIL_RadioAccessFamily; + +typedef enum { +    RC_PHASE_CONFIGURED = 0,  // LM is configured is initial value and value after FINISH completes +    RC_PHASE_START      = 1,  // START is sent before Apply and indicates that an APPLY will be +                              // forthcoming with these same parameters +    RC_PHASE_APPLY      = 2,  // APPLY is sent after all LM's receive START and returned +                              // RIL_RadioCapability.status = 0, if any START's fail no +                              // APPLY will be sent +    RC_PHASE_UNSOL_RSP  = 3,  // UNSOL_RSP is sent with RIL_UNSOL_RADIO_CAPABILITY +    RC_PHASE_FINISH     = 4   // FINISH is sent after all commands have completed. If an error +                              // occurs in any previous command the RIL_RadioAccessesFamily and +                              // logicalModemUuid fields will be the prior configuration thus +                              // restoring the configuration to the previous value. An error +                              // returned by this command will generally be ignored or may +                              // cause that logical modem to be removed from service. +} RadioCapabilityPhase; + +typedef enum { +    RC_STATUS_NONE       = 0, // This parameter has no meaning with RC_PHASE_START, +                              // RC_PHASE_APPLY +    RC_STATUS_SUCCESS    = 1, // Tell modem the action transaction of set radio +                              // capability was success with RC_PHASE_FINISH +    RC_STATUS_FAIL       = 2, // Tell modem the action transaction of set radio +                              // capability is fail with RC_PHASE_FINISH. +} RadioCapabilityStatus; + +#define RIL_RADIO_CAPABILITY_VERSION 1 +typedef struct { +    int version;            // Version of structure, RIL_RADIO_CAPABILITY_VERSION +    int session;            // Unique session value defined by framework returned in all "responses/unsol" +    int phase;              // CONFIGURED, START, APPLY, FINISH +    int rat;                // RIL_RadioAccessFamily for the radio +    char logicalModemUuid[MAX_UUID_LENGTH]; // A UUID typically "com.xxxx.lmX where X is the logical modem. +    int status;             // Return status and an input parameter for RC_PHASE_FINISH +} RIL_RadioCapability; + +// Do we want to split Data from Voice and the use +// RIL_RadioTechnology for get/setPreferredVoice/Data ? +typedef enum { +    PREF_NET_TYPE_GSM_WCDMA                = 0, /* GSM/WCDMA (WCDMA preferred) */ +    PREF_NET_TYPE_GSM_ONLY                 = 1, /* GSM only */ +    PREF_NET_TYPE_WCDMA                    = 2, /* WCDMA  */ +    PREF_NET_TYPE_GSM_WCDMA_AUTO           = 3, /* GSM/WCDMA (auto mode, according to PRL) */ +    PREF_NET_TYPE_CDMA_EVDO_AUTO           = 4, /* CDMA and EvDo (auto mode, according to PRL) */ +    PREF_NET_TYPE_CDMA_ONLY                = 5, /* CDMA only */ +    PREF_NET_TYPE_EVDO_ONLY                = 6, /* EvDo only */ +    PREF_NET_TYPE_GSM_WCDMA_CDMA_EVDO_AUTO = 7, /* GSM/WCDMA, CDMA, and EvDo (auto mode, according to PRL) */ +    PREF_NET_TYPE_LTE_CDMA_EVDO            = 8, /* LTE, CDMA and EvDo */ +    PREF_NET_TYPE_LTE_GSM_WCDMA            = 9, /* LTE, GSM/WCDMA */ +    PREF_NET_TYPE_LTE_CMDA_EVDO_GSM_WCDMA  = 10, /* LTE, CDMA, EvDo, GSM/WCDMA */ +    PREF_NET_TYPE_LTE_ONLY                 = 11, /* LTE only */ +    PREF_NET_TYPE_LTE_WCDMA                = 12  /* LTE/WCDMA */ +} RIL_PreferredNetworkType; + +/* Source for cdma subscription */ +typedef enum { +   CDMA_SUBSCRIPTION_SOURCE_RUIM_SIM = 0, +   CDMA_SUBSCRIPTION_SOURCE_NV = 1 +} RIL_CdmaSubscriptionSource; + +/* User-to-User signaling Info activation types derived from 3GPP 23.087 v8.0 */ +typedef enum { +    RIL_UUS_TYPE1_IMPLICIT = 0, +    RIL_UUS_TYPE1_REQUIRED = 1, +    RIL_UUS_TYPE1_NOT_REQUIRED = 2, +    RIL_UUS_TYPE2_REQUIRED = 3, +    RIL_UUS_TYPE2_NOT_REQUIRED = 4, +    RIL_UUS_TYPE3_REQUIRED = 5, +    RIL_UUS_TYPE3_NOT_REQUIRED = 6 +} RIL_UUS_Type; + +/* User-to-User Signaling Information data coding schemes. Possible values for + * Octet 3 (Protocol Discriminator field) in the UUIE. The values have been + * specified in section 10.5.4.25 of 3GPP TS 24.008 */ +typedef enum { +    RIL_UUS_DCS_USP = 0,          /* User specified protocol */ +    RIL_UUS_DCS_OSIHLP = 1,       /* OSI higher layer protocol */ +    RIL_UUS_DCS_X244 = 2,         /* X.244 */ +    RIL_UUS_DCS_RMCF = 3,         /* Reserved for system mangement +                                     convergence function */ +    RIL_UUS_DCS_IA5c = 4          /* IA5 characters */ +} RIL_UUS_DCS; + +/* User-to-User Signaling Information defined in 3GPP 23.087 v8.0 + * This data is passed in RIL_ExtensionRecord and rec contains this + * structure when type is RIL_UUS_INFO_EXT_REC */ +typedef struct { +  RIL_UUS_Type    uusType;    /* UUS Type */ +  RIL_UUS_DCS     uusDcs;     /* UUS Data Coding Scheme */ +  int             uusLength;  /* Length of UUS Data */ +  char *          uusData;    /* UUS Data */ +} RIL_UUS_Info; + +/* CDMA Signal Information Record as defined in C.S0005 section 3.7.5.5 */ +typedef struct { +  char isPresent;    /* non-zero if signal information record is present */ +  char signalType;   /* as defined 3.7.5.5-1 */ +  char alertPitch;   /* as defined 3.7.5.5-2 */ +  char signal;       /* as defined 3.7.5.5-3, 3.7.5.5-4 or 3.7.5.5-5 */ +} RIL_CDMA_SignalInfoRecord; + +typedef struct { +    RIL_CallState   state; +    int             index;      /* Connection Index for use with, eg, AT+CHLD */ +    int             toa;        /* type of address, eg 145 = intl */ +    char            isMpty;     /* nonzero if is mpty call */ +    char            isMT;       /* nonzero if call is mobile terminated */ +    char            als;        /* ALS line indicator if available +                                   (0 = line 1) */ +    char            isVoice;    /* nonzero if this is is a voice call */ +    char            isVoicePrivacy;     /* nonzero if CDMA voice privacy mode is active */ +    char *          number;     /* Remote party number */ +    int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown 3=Payphone */ +    char *          name;       /* Remote party name */ +    int             namePresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown 3=Payphone */ +    RIL_UUS_Info *  uusInfo;    /* NULL or Pointer to User-User Signaling Information */ +} RIL_Call; + +/* Deprecated, use RIL_Data_Call_Response_v6 */ +typedef struct { +    int             cid;        /* Context ID, uniquely identifies this call */ +    int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */ +    char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1. +                                   For example, "IP", "IPV6", "IPV4V6", or "PPP". */ +    char *          apn;        /* ignored */ +    char *          address;    /* An address, e.g., "192.0.1.3" or "2001:db8::1". */ +} RIL_Data_Call_Response_v4; + +/* + * Returned by RIL_REQUEST_SETUP_DATA_CALL, RIL_REQUEST_DATA_CALL_LIST + * and RIL_UNSOL_DATA_CALL_LIST_CHANGED, on error status != 0. + */ +typedef struct { +    int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */ +    int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry +                                           back-off timer value RIL wants to override the one +                                           pre-configured in FW. +                                           The unit is miliseconds. +                                           The value < 0 means no value is suggested. +                                           The value 0 means retry should be done ASAP. +                                           The value of INT_MAX(0x7fffffff) means no retry. */ +    int             cid;        /* Context ID, uniquely identifies this call */ +    int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */ +    char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1. +                                   For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is +                                   PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported +                                   such as "IP" or "IPV6" */ +    char *          ifname;     /* The network interface name */ +    char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length, +                                   e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64". +                                   May not be empty, typically 1 IPv4 or 1 IPv6 or +                                   one of each. If the prefix length is absent the addresses +                                   are assumed to be point to point with IPv4 having a prefix +                                   length of 32 and IPv6 128. */ +    char *          dnses;      /* A space-delimited list of DNS server addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty. */ +    char *          gateways;   /* A space-delimited list of default gateway addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty in which case the addresses represent point +                                   to point connections. */ +} RIL_Data_Call_Response_v6; + +typedef struct { +    int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */ +    int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry +                                           back-off timer value RIL wants to override the one +                                           pre-configured in FW. +                                           The unit is miliseconds. +                                           The value < 0 means no value is suggested. +                                           The value 0 means retry should be done ASAP. +                                           The value of INT_MAX(0x7fffffff) means no retry. */ +    int             cid;        /* Context ID, uniquely identifies this call */ +    int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */ +    char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1. +                                   For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is +                                   PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported +                                   such as "IP" or "IPV6" */ +    char *          ifname;     /* The network interface name */ +    char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length, +                                   e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64". +                                   May not be empty, typically 1 IPv4 or 1 IPv6 or +                                   one of each. If the prefix length is absent the addresses +                                   are assumed to be point to point with IPv4 having a prefix +                                   length of 32 and IPv6 128. */ +    char *          dnses;      /* A space-delimited list of DNS server addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty. */ +    char *          gateways;   /* A space-delimited list of default gateway addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty in which case the addresses represent point +                                   to point connections. */ +    char *          pcscf;    /* the Proxy Call State Control Function address +                                 via PCO(Protocol Configuration Option) for IMS client. */ +} RIL_Data_Call_Response_v9; + +typedef struct { +    int             status;     /* A RIL_DataCallFailCause, 0 which is PDP_FAIL_NONE if no error */ +    int             suggestedRetryTime; /* If status != 0, this fields indicates the suggested retry +                                           back-off timer value RIL wants to override the one +                                           pre-configured in FW. +                                           The unit is miliseconds. +                                           The value < 0 means no value is suggested. +                                           The value 0 means retry should be done ASAP. +                                           The value of INT_MAX(0x7fffffff) means no retry. */ +    int             cid;        /* Context ID, uniquely identifies this call */ +    int             active;     /* 0=inactive, 1=active/physical link down, 2=active/physical link up */ +    char *          type;       /* One of the PDP_type values in TS 27.007 section 10.1.1. +                                   For example, "IP", "IPV6", "IPV4V6", or "PPP". If status is +                                   PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED this is the type supported +                                   such as "IP" or "IPV6" */ +    char *          ifname;     /* The network interface name */ +    char *          addresses;  /* A space-delimited list of addresses with optional "/" prefix length, +                                   e.g., "192.0.1.3" or "192.0.1.11/16 2001:db8::1/64". +                                   May not be empty, typically 1 IPv4 or 1 IPv6 or +                                   one of each. If the prefix length is absent the addresses +                                   are assumed to be point to point with IPv4 having a prefix +                                   length of 32 and IPv6 128. */ +    char *          dnses;      /* A space-delimited list of DNS server addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty. */ +    char *          gateways;   /* A space-delimited list of default gateway addresses, +                                   e.g., "192.0.1.3" or "192.0.1.11 2001:db8::1". +                                   May be empty in which case the addresses represent point +                                   to point connections. */ +    char *          pcscf;    /* the Proxy Call State Control Function address +                                 via PCO(Protocol Configuration Option) for IMS client. */ +    int             mtu;        /* MTU received from network +                                   Value <= 0 means network has either not sent a value or +                                   sent an invalid value */ +} RIL_Data_Call_Response_v11; + +typedef enum { +    RADIO_TECH_3GPP = 1, /* 3GPP Technologies - GSM, WCDMA */ +    RADIO_TECH_3GPP2 = 2 /* 3GPP2 Technologies - CDMA */ +} RIL_RadioTechnologyFamily; + +typedef struct { +    RIL_RadioTechnologyFamily tech; +    unsigned char             retry;       /* 0 == not retry, nonzero == retry */ +    int                       messageRef;  /* Valid field if retry is set to nonzero. +                                              Contains messageRef from RIL_SMS_Response +                                              corresponding to failed MO SMS. +                                            */ + +    union { +        /* Valid field if tech is RADIO_TECH_3GPP2. See RIL_REQUEST_CDMA_SEND_SMS */ +        RIL_CDMA_SMS_Message* cdmaMessage; + +        /* Valid field if tech is RADIO_TECH_3GPP. See RIL_REQUEST_SEND_SMS */ +        char**                gsmMessage; +    } message; +} RIL_IMS_SMS_Message; + +typedef struct { +    int messageRef;   /* TP-Message-Reference for GSM, +                         and BearerData MessageId for CDMA +                         (See 3GPP2 C.S0015-B, v2.0, table 4.5-1). */ +    char *ackPDU;     /* or NULL if n/a */ +    int errorCode;    /* See 3GPP 27.005, 3.2.5 for GSM/UMTS, +                         3GPP2 N.S0005 (IS-41C) Table 171 for CDMA, +                         -1 if unknown or not applicable*/ +} RIL_SMS_Response; + +/** Used by RIL_REQUEST_WRITE_SMS_TO_SIM */ +typedef struct { +    int status;     /* Status of message.  See TS 27.005 3.1, "<stat>": */ +                    /*      0 = "REC UNREAD"    */ +                    /*      1 = "REC READ"      */ +                    /*      2 = "STO UNSENT"    */ +                    /*      3 = "STO SENT"      */ +    char * pdu;     /* PDU of message to write, as an ASCII hex string less the SMSC address, +                       the TP-layer length is "strlen(pdu)/2". */ +    char * smsc;    /* SMSC address in GSM BCD format prefixed by a length byte +                       (as expected by TS 27.005) or NULL for default SMSC */ +} RIL_SMS_WriteArgs; + +/** Used by RIL_REQUEST_DIAL */ +typedef struct { +    char * address; +    int clir; +            /* (same as 'n' paremeter in TS 27.007 7.7 "+CLIR" +             * clir == 0 on "use subscription default value" +             * clir == 1 on "CLIR invocation" (restrict CLI presentation) +             * clir == 2 on "CLIR suppression" (allow CLI presentation) +             */ +    RIL_UUS_Info *  uusInfo;    /* NULL or Pointer to User-User Signaling Information */ +} RIL_Dial; + +typedef struct { +    int command;    /* one of the commands listed for TS 27.007 +CRSM*/ +    int fileid;     /* EF id */ +    char *path;     /* "pathid" from TS 27.007 +CRSM command. +                       Path is in hex asciii format eg "7f205f70" +                       Path must always be provided. +                     */ +    int p1; +    int p2; +    int p3; +    char *data;     /* May be NULL*/ +    char *pin2;     /* May be NULL*/ +} RIL_SIM_IO_v5; + +typedef struct { +    int command;    /* one of the commands listed for TS 27.007 +CRSM*/ +    int fileid;     /* EF id */ +    char *path;     /* "pathid" from TS 27.007 +CRSM command. +                       Path is in hex asciii format eg "7f205f70" +                       Path must always be provided. +                     */ +    int p1; +    int p2; +    int p3; +    char *data;     /* May be NULL*/ +    char *pin2;     /* May be NULL*/ +    char *aidPtr;   /* AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. */ +} RIL_SIM_IO_v6; + +/* Used by RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL and + * RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC. */ +typedef struct { +    int sessionid;  /* "sessionid" from TS 27.007 +CGLA command. Should be +                       ignored for +CSIM command. */ + +    /* Following fields are used to derive the APDU ("command" and "length" +       values in TS 27.007 +CSIM and +CGLA commands). */ +    int cla; +    int instruction; +    int p1; +    int p2; +    int p3;         /* A negative P3 implies a 4 byte APDU. */ +    char *data;     /* May be NULL. In hex string format. */ +} RIL_SIM_APDU; + +typedef struct { +    int sw1; +    int sw2; +    char *simResponse;  /* In hex string format ([a-fA-F0-9]*), except for SIM_AUTHENTICATION +                           response for which it is in Base64 format, see 3GPP TS 31.102 7.1.2 */ +} RIL_SIM_IO_Response; + +/* See also com.android.internal.telephony.gsm.CallForwardInfo */ + +typedef struct { +    int             status;     /* +                                 * For RIL_REQUEST_QUERY_CALL_FORWARD_STATUS +                                 * status 1 = active, 0 = not active +                                 * +                                 * For RIL_REQUEST_SET_CALL_FORWARD: +                                 * status is: +                                 * 0 = disable +                                 * 1 = enable +                                 * 2 = interrogate +                                 * 3 = registeration +                                 * 4 = erasure +                                 */ + +    int             reason;      /* from TS 27.007 7.11 "reason" */ +    int             serviceClass;/* From 27.007 +CCFC/+CLCK "class" +                                    See table for Android mapping from +                                    MMI service code +                                    0 means user doesn't input class */ +    int             toa;         /* "type" from TS 27.007 7.11 */ +    char *          number;      /* "number" from TS 27.007 7.11. May be NULL */ +    int             timeSeconds; /* for CF no reply only */ +}RIL_CallForwardInfo; + +typedef struct { +   char * cid;         /* Combination of LAC and Cell Id in 32 bits in GSM. +                        * Upper 16 bits is LAC and lower 16 bits +                        * is CID (as described in TS 27.005) +                        * Primary Scrambling Code (as described in TS 25.331) +                        *         in 9 bits in UMTS +                        * Valid values are hexadecimal 0x0000 - 0xffffffff. +                        */ +   int    rssi;        /* Received RSSI in GSM, +                        * Level index of CPICH Received Signal Code Power in UMTS +                        */ +} RIL_NeighboringCell; + +typedef struct { +  char lce_status;                 /* LCE service status: +                                    * -1 = not supported; +                                    * 0 = stopped; +                                    * 1 = active. +                                    */ +  unsigned int actual_interval_ms; /* actual LCE reporting interval, +                                    * meaningful only if LCEStatus = 1. +                                    */ +} RIL_LceStatusInfo; + +typedef struct { +  unsigned int last_hop_capacity_kbps; /* last-hop cellular capacity: kilobits/second. */ +  unsigned char confidence_level;      /* capacity estimate confidence: 0-100 */ +  unsigned char lce_suspended;         /* LCE report going to be suspended? (e.g., radio +                                        * moves to inactive state or network type change) +                                        * 1 = suspended; +                                        * 0 = not suspended. +                                        */ +} RIL_LceDataInfo; + +/* See RIL_REQUEST_LAST_CALL_FAIL_CAUSE */ +typedef enum { +    CALL_FAIL_UNOBTAINABLE_NUMBER = 1, +    CALL_FAIL_NORMAL = 16, +    CALL_FAIL_BUSY = 17, +    CALL_FAIL_CONGESTION = 34, +    CALL_FAIL_ACM_LIMIT_EXCEEDED = 68, +    CALL_FAIL_CALL_BARRED = 240, +    CALL_FAIL_FDN_BLOCKED = 241, +    CALL_FAIL_IMSI_UNKNOWN_IN_VLR = 242, +    CALL_FAIL_IMEI_NOT_ACCEPTED = 243, +    CALL_FAIL_DIAL_MODIFIED_TO_USSD = 244, /* STK Call Control */ +    CALL_FAIL_DIAL_MODIFIED_TO_SS = 245, +    CALL_FAIL_DIAL_MODIFIED_TO_DIAL = 246, +    CALL_FAIL_CDMA_LOCKED_UNTIL_POWER_CYCLE = 1000, +    CALL_FAIL_CDMA_DROP = 1001, +    CALL_FAIL_CDMA_INTERCEPT = 1002, +    CALL_FAIL_CDMA_REORDER = 1003, +    CALL_FAIL_CDMA_SO_REJECT = 1004, +    CALL_FAIL_CDMA_RETRY_ORDER = 1005, +    CALL_FAIL_CDMA_ACCESS_FAILURE = 1006, +    CALL_FAIL_CDMA_PREEMPTED = 1007, +    CALL_FAIL_CDMA_NOT_EMERGENCY = 1008, /* For non-emergency number dialed +                                            during emergency callback mode */ +    CALL_FAIL_CDMA_ACCESS_BLOCKED = 1009, /* CDMA network access probes blocked */ +    CALL_FAIL_ERROR_UNSPECIFIED = 0xffff +} RIL_LastCallFailCause; + +typedef struct { +  RIL_LastCallFailCause cause_code; +  char *                vendor_cause; +} RIL_LastCallFailCauseInfo; + +/* See RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE */ +typedef enum { +    PDP_FAIL_NONE = 0, /* No error, connection ok */ + +    /* an integer cause code defined in TS 24.008 +       section 6.1.3.1.3 or TS 24.301 Release 8+ Annex B. +       If the implementation does not have access to the exact cause codes, +       then it should return one of the following values, +       as the UI layer needs to distinguish these +       cases for error notification and potential retries. */ +    PDP_FAIL_OPERATOR_BARRED = 0x08,               /* no retry */ +    PDP_FAIL_INSUFFICIENT_RESOURCES = 0x1A, +    PDP_FAIL_MISSING_UKNOWN_APN = 0x1B,            /* no retry */ +    PDP_FAIL_UNKNOWN_PDP_ADDRESS_TYPE = 0x1C,      /* no retry */ +    PDP_FAIL_USER_AUTHENTICATION = 0x1D,           /* no retry */ +    PDP_FAIL_ACTIVATION_REJECT_GGSN = 0x1E,        /* no retry */ +    PDP_FAIL_ACTIVATION_REJECT_UNSPECIFIED = 0x1F, +    PDP_FAIL_SERVICE_OPTION_NOT_SUPPORTED = 0x20,  /* no retry */ +    PDP_FAIL_SERVICE_OPTION_NOT_SUBSCRIBED = 0x21, /* no retry */ +    PDP_FAIL_SERVICE_OPTION_OUT_OF_ORDER = 0x22, +    PDP_FAIL_NSAPI_IN_USE = 0x23,                  /* no retry */ +    PDP_FAIL_REGULAR_DEACTIVATION = 0x24,          /* possibly restart radio, +                                                      based on framework config */ +    PDP_FAIL_ONLY_IPV4_ALLOWED = 0x32,             /* no retry */ +    PDP_FAIL_ONLY_IPV6_ALLOWED = 0x33,             /* no retry */ +    PDP_FAIL_ONLY_SINGLE_BEARER_ALLOWED = 0x34, +    PDP_FAIL_PROTOCOL_ERRORS   = 0x6F,             /* no retry */ + +    /* Not mentioned in the specification */ +    PDP_FAIL_VOICE_REGISTRATION_FAIL = -1, +    PDP_FAIL_DATA_REGISTRATION_FAIL = -2, + +   /* reasons for data call drop - network/modem disconnect */ +    PDP_FAIL_SIGNAL_LOST = -3, +    PDP_FAIL_PREF_RADIO_TECH_CHANGED = -4,/* preferred technology has changed, should retry +                                             with parameters appropriate for new technology */ +    PDP_FAIL_RADIO_POWER_OFF = -5,        /* data call was disconnected because radio was resetting, +                                             powered off - no retry */ +    PDP_FAIL_TETHERED_CALL_ACTIVE = -6,   /* data call was disconnected by modem because tethered +                                             mode was up on same APN/data profile - no retry until +                                             tethered call is off */ + +    PDP_FAIL_ERROR_UNSPECIFIED = 0xffff,  /* retry silently */ +} RIL_DataCallFailCause; + +/* See RIL_REQUEST_SETUP_DATA_CALL */ +typedef enum { +    RIL_DATA_PROFILE_DEFAULT    = 0, +    RIL_DATA_PROFILE_TETHERED   = 1, +    RIL_DATA_PROFILE_IMS        = 2, +    RIL_DATA_PROFILE_FOTA       = 3, +    RIL_DATA_PROFILE_CBS        = 4, +    RIL_DATA_PROFILE_OEM_BASE   = 1000,    /* Start of OEM-specific profiles */ +    RIL_DATA_PROFILE_INVALID    = 0xFFFFFFFF +} RIL_DataProfile; + +/* Used by RIL_UNSOL_SUPP_SVC_NOTIFICATION */ +typedef struct { +    int     notificationType;   /* +                                 * 0 = MO intermediate result code +                                 * 1 = MT unsolicited result code +                                 */ +    int     code;               /* See 27.007 7.17 +                                   "code1" for MO +                                   "code2" for MT. */ +    int     index;              /* CUG index. See 27.007 7.17. */ +    int     type;               /* "type" from 27.007 7.17 (MT only). */ +    char *  number;             /* "number" from 27.007 7.17 +                                   (MT only, may be NULL). */ +} RIL_SuppSvcNotification; + +#define RIL_CARD_MAX_APPS     8 + +typedef enum { +    RIL_CARDSTATE_ABSENT   = 0, +    RIL_CARDSTATE_PRESENT  = 1, +    RIL_CARDSTATE_ERROR    = 2 +} RIL_CardState; + +typedef enum { +    RIL_PERSOSUBSTATE_UNKNOWN                   = 0, /* initial state */ +    RIL_PERSOSUBSTATE_IN_PROGRESS               = 1, /* in between each lock transition */ +    RIL_PERSOSUBSTATE_READY                     = 2, /* when either SIM or RUIM Perso is finished +                                                        since each app can only have 1 active perso +                                                        involved */ +    RIL_PERSOSUBSTATE_SIM_NETWORK               = 3, +    RIL_PERSOSUBSTATE_SIM_NETWORK_SUBSET        = 4, +    RIL_PERSOSUBSTATE_SIM_CORPORATE             = 5, +    RIL_PERSOSUBSTATE_SIM_SERVICE_PROVIDER      = 6, +    RIL_PERSOSUBSTATE_SIM_SIM                   = 7, +    RIL_PERSOSUBSTATE_SIM_NETWORK_PUK           = 8, /* The corresponding perso lock is blocked */ +    RIL_PERSOSUBSTATE_SIM_NETWORK_SUBSET_PUK    = 9, +    RIL_PERSOSUBSTATE_SIM_CORPORATE_PUK         = 10, +    RIL_PERSOSUBSTATE_SIM_SERVICE_PROVIDER_PUK  = 11, +    RIL_PERSOSUBSTATE_SIM_SIM_PUK               = 12, +    RIL_PERSOSUBSTATE_RUIM_NETWORK1             = 13, +    RIL_PERSOSUBSTATE_RUIM_NETWORK2             = 14, +    RIL_PERSOSUBSTATE_RUIM_HRPD                 = 15, +    RIL_PERSOSUBSTATE_RUIM_CORPORATE            = 16, +    RIL_PERSOSUBSTATE_RUIM_SERVICE_PROVIDER     = 17, +    RIL_PERSOSUBSTATE_RUIM_RUIM                 = 18, +    RIL_PERSOSUBSTATE_RUIM_NETWORK1_PUK         = 19, /* The corresponding perso lock is blocked */ +    RIL_PERSOSUBSTATE_RUIM_NETWORK2_PUK         = 20, +    RIL_PERSOSUBSTATE_RUIM_HRPD_PUK             = 21, +    RIL_PERSOSUBSTATE_RUIM_CORPORATE_PUK        = 22, +    RIL_PERSOSUBSTATE_RUIM_SERVICE_PROVIDER_PUK = 23, +    RIL_PERSOSUBSTATE_RUIM_RUIM_PUK             = 24 +} RIL_PersoSubstate; + +typedef enum { +    RIL_APPSTATE_UNKNOWN               = 0, +    RIL_APPSTATE_DETECTED              = 1, +    RIL_APPSTATE_PIN                   = 2, /* If PIN1 or UPin is required */ +    RIL_APPSTATE_PUK                   = 3, /* If PUK1 or Puk for UPin is required */ +    RIL_APPSTATE_SUBSCRIPTION_PERSO    = 4, /* perso_substate should be look at +                                               when app_state is assigned to this value */ +    RIL_APPSTATE_READY                 = 5 +} RIL_AppState; + +typedef enum { +    RIL_PINSTATE_UNKNOWN              = 0, +    RIL_PINSTATE_ENABLED_NOT_VERIFIED = 1, +    RIL_PINSTATE_ENABLED_VERIFIED     = 2, +    RIL_PINSTATE_DISABLED             = 3, +    RIL_PINSTATE_ENABLED_BLOCKED      = 4, +    RIL_PINSTATE_ENABLED_PERM_BLOCKED = 5 +} RIL_PinState; + +typedef enum { +  RIL_APPTYPE_UNKNOWN = 0, +  RIL_APPTYPE_SIM     = 1, +  RIL_APPTYPE_USIM    = 2, +  RIL_APPTYPE_RUIM    = 3, +  RIL_APPTYPE_CSIM    = 4, +  RIL_APPTYPE_ISIM    = 5 +} RIL_AppType; + +typedef struct +{ +  RIL_AppType      app_type; +  RIL_AppState     app_state; +  RIL_PersoSubstate perso_substate; /* applicable only if app_state == +                                       RIL_APPSTATE_SUBSCRIPTION_PERSO */ +  char             *aid_ptr;        /* null terminated string, e.g., from 0xA0, 0x00 -> 0x41, +                                       0x30, 0x30, 0x30 */ +  char             *app_label_ptr;  /* null terminated string */ +  int              pin1_replaced;   /* applicable to USIM, CSIM & ISIM */ +  RIL_PinState     pin1; +  RIL_PinState     pin2; +  int              foo1;            /* Samsung */ +  int              foo2;            /* Samsung */ +  int              foo3;            /* Samsung */ +  int              foo4;            /* Samsung */ +  int              foo5;            /* Samsung */ +} RIL_AppStatus; + +/* Deprecated, use RIL_CardStatus_v6 */ +typedef struct +{ +  RIL_CardState card_state; +  RIL_PinState  universal_pin_state;             /* applicable to USIM and CSIM: RIL_PINSTATE_xxx */ +  int           gsm_umts_subscription_app_index; /* value < RIL_CARD_MAX_APPS, -1 if none */ +  int           cdma_subscription_app_index;     /* value < RIL_CARD_MAX_APPS, -1 if none */ +  int           num_applications;                /* value <= RIL_CARD_MAX_APPS */ +  RIL_AppStatus applications[RIL_CARD_MAX_APPS]; +} RIL_CardStatus_v5; + +typedef struct +{ +  RIL_CardState card_state; +  RIL_PinState  universal_pin_state;             /* applicable to USIM and CSIM: RIL_PINSTATE_xxx */ +  int           gsm_umts_subscription_app_index; /* value < RIL_CARD_MAX_APPS, -1 if none */ +  int           cdma_subscription_app_index;     /* value < RIL_CARD_MAX_APPS, -1 if none */ +  int           ims_subscription_app_index;      /* value < RIL_CARD_MAX_APPS, -1 if none */ +  int           num_applications;                /* value <= RIL_CARD_MAX_APPS */ +  RIL_AppStatus applications[RIL_CARD_MAX_APPS]; +} RIL_CardStatus_v6; + +/** The result of a SIM refresh, returned in data[0] of RIL_UNSOL_SIM_REFRESH + *      or as part of RIL_SimRefreshResponse_v7 + */ +typedef enum { +    /* A file on SIM has been updated.  data[1] contains the EFID. */ +    SIM_FILE_UPDATE = 0, +    /* SIM initialized.  All files should be re-read. */ +    SIM_INIT = 1, +    /* SIM reset.  SIM power required, SIM may be locked and all files should be re-read. */ +    SIM_RESET = 2 +} RIL_SimRefreshResult; + +typedef struct { +    RIL_SimRefreshResult result; +    int                  ef_id; /* is the EFID of the updated file if the result is */ +                                /* SIM_FILE_UPDATE or 0 for any other result. */ +    char *               aid;   /* is AID(application ID) of the card application */ +                                /* See ETSI 102.221 8.1 and 101.220 4 */ +                                /*     For SIM_FILE_UPDATE result it can be set to AID of */ +                                /*         application in which updated EF resides or it can be */ +                                /*         NULL if EF is outside of an application. */ +                                /*     For SIM_INIT result this field is set to AID of */ +                                /*         application that caused REFRESH */ +                                /*     For SIM_RESET result it is NULL. */ +} RIL_SimRefreshResponse_v7; + +/* Deprecated, use RIL_CDMA_CallWaiting_v6 */ +typedef struct { +    char *          number;             /* Remote party number */ +    int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown */ +    char *          name;               /* Remote party name */ +    RIL_CDMA_SignalInfoRecord signalInfoRecord; +} RIL_CDMA_CallWaiting_v5; + +typedef struct { +    char *          number;             /* Remote party number */ +    int             numberPresentation; /* 0=Allowed, 1=Restricted, 2=Not Specified/Unknown */ +    char *          name;               /* Remote party name */ +    RIL_CDMA_SignalInfoRecord signalInfoRecord; +    /* Number type/Number plan required to support International Call Waiting */ +    int             number_type;        /* 0=Unknown, 1=International, 2=National, +                                           3=Network specific, 4=subscriber */ +    int             number_plan;        /* 0=Unknown, 1=ISDN, 3=Data, 4=Telex, 8=Nat'l, 9=Private */ +} RIL_CDMA_CallWaiting_v6; + +/** + * Which types of Cell Broadcast Message (CBM) are to be received by the ME + * + * uFromServiceID - uToServiceID defines a range of CBM message identifiers + * whose value is 0x0000 - 0xFFFF as defined in TS 23.041 9.4.1.2.2 for GMS + * and 9.4.4.2.2 for UMTS. All other values can be treated as empty + * CBM message ID. + * + * uFromCodeScheme - uToCodeScheme defines a range of CBM data coding schemes + * whose value is 0x00 - 0xFF as defined in TS 23.041 9.4.1.2.3 for GMS + * and 9.4.4.2.3 for UMTS. + * All other values can be treated as empty CBM data coding scheme. + * + * selected 0 means message types specified in <fromServiceId, toServiceId> + * and <fromCodeScheme, toCodeScheme>are not accepted, while 1 means accepted. + * + * Used by RIL_REQUEST_GSM_GET_BROADCAST_CONFIG and + * RIL_REQUEST_GSM_SET_BROADCAST_CONFIG. + */ +typedef struct { +    int fromServiceId; +    int toServiceId; +    int fromCodeScheme; +    int toCodeScheme; +    unsigned char selected; +} RIL_GSM_BroadcastSmsConfigInfo; + +/* No restriction at all including voice/SMS/USSD/SS/AV64 and packet data. */ +#define RIL_RESTRICTED_STATE_NONE           0x00 +/* Block emergency call due to restriction. But allow all normal voice/SMS/USSD/SS/AV64. */ +#define RIL_RESTRICTED_STATE_CS_EMERGENCY   0x01 +/* Block all normal voice/SMS/USSD/SS/AV64 due to restriction. Only Emergency call allowed. */ +#define RIL_RESTRICTED_STATE_CS_NORMAL      0x02 +/* Block all voice/SMS/USSD/SS/AV64 including emergency call due to restriction.*/ +#define RIL_RESTRICTED_STATE_CS_ALL         0x04 +/* Block packet data access due to restriction. */ +#define RIL_RESTRICTED_STATE_PS_ALL         0x10 + +/* The status for an OTASP/OTAPA session */ +typedef enum { +    CDMA_OTA_PROVISION_STATUS_SPL_UNLOCKED, +    CDMA_OTA_PROVISION_STATUS_SPC_RETRIES_EXCEEDED, +    CDMA_OTA_PROVISION_STATUS_A_KEY_EXCHANGED, +    CDMA_OTA_PROVISION_STATUS_SSD_UPDATED, +    CDMA_OTA_PROVISION_STATUS_NAM_DOWNLOADED, +    CDMA_OTA_PROVISION_STATUS_MDN_DOWNLOADED, +    CDMA_OTA_PROVISION_STATUS_IMSI_DOWNLOADED, +    CDMA_OTA_PROVISION_STATUS_PRL_DOWNLOADED, +    CDMA_OTA_PROVISION_STATUS_COMMITTED, +    CDMA_OTA_PROVISION_STATUS_OTAPA_STARTED, +    CDMA_OTA_PROVISION_STATUS_OTAPA_STOPPED, +    CDMA_OTA_PROVISION_STATUS_OTAPA_ABORTED +} RIL_CDMA_OTA_ProvisionStatus; + +typedef struct { +    int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */ +    int bitErrorRate;    /* bit error rate (0-7, 99) as defined in TS 27.007 8.5 */ +} RIL_GW_SignalStrength; + +typedef struct { +    int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */ +    int bitErrorRate;    /* bit error rate (0-7, 99) as defined in TS 27.007 8.5 */ +} RIL_SignalStrengthWcdma; + +typedef struct { +    int dbm;  /* Valid values are positive integers.  This value is the actual RSSI value +               * multiplied by -1.  Example: If the actual RSSI is -75, then this response +               * value will be 75. +               */ +    int ecio; /* Valid values are positive integers.  This value is the actual Ec/Io multiplied +               * by -10.  Example: If the actual Ec/Io is -12.5 dB, then this response value +               * will be 125. +               */ +} RIL_CDMA_SignalStrength; + + +typedef struct { +    int dbm;  /* Valid values are positive integers.  This value is the actual RSSI value +               * multiplied by -1.  Example: If the actual RSSI is -75, then this response +               * value will be 75. +               */ +    int ecio; /* Valid values are positive integers.  This value is the actual Ec/Io multiplied +               * by -10.  Example: If the actual Ec/Io is -12.5 dB, then this response value +               * will be 125. +               */ +    int signalNoiseRatio; /* Valid values are 0-8.  8 is the highest signal to noise ratio. */ +} RIL_EVDO_SignalStrength; + +typedef struct { +    int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */ +    int rsrp;            /* The current Reference Signal Receive Power in dBm multipled by -1. +                          * Range: 44 to 140 dBm +                          * INT_MAX: 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.133 9.1.4 */ +    int rsrq;            /* The current Reference Signal Receive Quality in dB multiplied by -1. +                          * Range: 20 to 3 dB. +                          * INT_MAX: 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.133 9.1.7 */ +    int rssnr;           /* The current reference signal signal-to-noise ratio in 0.1 dB units. +                          * Range: -200 to +300 (-200 = -20.0 dB, +300 = 30dB). +                          * INT_MAX : 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.101 8.1.1 */ +    int cqi;             /* The current Channel Quality Indicator. +                          * Range: 0 to 15. +                          * INT_MAX : 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.101 9.2, 9.3, A.4 */ +} RIL_LTE_SignalStrength; + +typedef struct { +    int signalStrength;  /* Valid values are (0-31, 99) as defined in TS 27.007 8.5 */ +    int rsrp;            /* The current Reference Signal Receive Power in dBm multipled by -1. +                          * Range: 44 to 140 dBm +                          * INT_MAX: 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.133 9.1.4 */ +    int rsrq;            /* The current Reference Signal Receive Quality in dB multiplied by -1. +                          * Range: 20 to 3 dB. +                          * INT_MAX: 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.133 9.1.7 */ +    int rssnr;           /* The current reference signal signal-to-noise ratio in 0.1 dB units. +                          * Range: -200 to +300 (-200 = -20.0 dB, +300 = 30dB). +                          * INT_MAX : 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.101 8.1.1 */ +    int cqi;             /* The current Channel Quality Indicator. +                          * Range: 0 to 15. +                          * INT_MAX : 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP TS 36.101 9.2, 9.3, A.4 */ +    int timingAdvance;   /* timing advance in micro seconds for a one way trip from cell to device. +                          * Approximate distance can be calculated using 300m/us * timingAdvance. +                          * Range: 0 to 0x7FFFFFFE +                          * INT_MAX : 0x7FFFFFFF denotes invalid value. +                          * Reference: 3GPP 36.321 section 6.1.3.5 +                          * also: http://www.cellular-planningoptimization.com/2010/02/timing-advance-with-calculation.html */ +} RIL_LTE_SignalStrength_v8; + +typedef struct { +    int rscp;    /* The Received Signal Code Power in dBm multipled by -1. +                  * Range : 25 to 120 +                  * INT_MAX: 0x7FFFFFFF denotes invalid value. +                  * Reference: 3GPP TS 25.123, section 9.1.1.1 */ +} RIL_TD_SCDMA_SignalStrength; + +/* Deprecated, use RIL_SignalStrength_v6 */ +typedef struct { +    RIL_GW_SignalStrength   GW_SignalStrength; +    RIL_CDMA_SignalStrength CDMA_SignalStrength; +    RIL_EVDO_SignalStrength EVDO_SignalStrength; +} RIL_SignalStrength_v5; + +typedef struct { +    RIL_GW_SignalStrength   GW_SignalStrength; +    RIL_CDMA_SignalStrength CDMA_SignalStrength; +    RIL_EVDO_SignalStrength EVDO_SignalStrength; +    RIL_LTE_SignalStrength  LTE_SignalStrength; +} RIL_SignalStrength_v6; + +typedef struct { +    RIL_GW_SignalStrength       GW_SignalStrength; +    RIL_CDMA_SignalStrength     CDMA_SignalStrength; +    RIL_EVDO_SignalStrength     EVDO_SignalStrength; +    RIL_LTE_SignalStrength_v8   LTE_SignalStrength; +} RIL_SignalStrength_v8; + +typedef struct { +    RIL_GW_SignalStrength       GW_SignalStrength; +    RIL_CDMA_SignalStrength     CDMA_SignalStrength; +    RIL_EVDO_SignalStrength     EVDO_SignalStrength; +    RIL_LTE_SignalStrength_v8   LTE_SignalStrength; +    RIL_TD_SCDMA_SignalStrength TD_SCDMA_SignalStrength; +} RIL_SignalStrength_v10; + +/** RIL_CellIdentityGsm */ +typedef struct { +    int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown */ +    int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown */ +    int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */ +    int cid;    /* 16-bit GSM Cell Identity described in TS 27.007, 0..65535, INT_MAX if unknown  */ +} RIL_CellIdentityGsm; + +/** RIL_CellIdentityWcdma */ +typedef struct { +    int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */ +    int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */ +    int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */ +    int cid;    /* 28-bit UMTS Cell Identity described in TS 25.331, 0..268435455, INT_MAX if unknown  */ +    int psc;    /* 9-bit UMTS Primary Scrambling Code described in TS 25.331, 0..511, INT_MAX if unknown */ +} RIL_CellIdentityWcdma; + +/** RIL_CellIdentityCdma */ +typedef struct { +    int networkId;      /* Network Id 0..65535, INT_MAX if unknown */ +    int systemId;       /* CDMA System Id 0..32767, INT_MAX if unknown  */ +    int basestationId;  /* Base Station Id 0..65535, INT_MAX if unknown  */ +    int longitude;      /* Longitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. +                         * It is represented in units of 0.25 seconds and ranges from -2592000 +                         * to 2592000, both values inclusive (corresponding to a range of -180 +                         * to +180 degrees). INT_MAX if unknown */ + +    int latitude;       /* Latitude is a decimal number as specified in 3GPP2 C.S0005-A v6.0. +                         * It is represented in units of 0.25 seconds and ranges from -1296000 +                         * to 1296000, both values inclusive (corresponding to a range of -90 +                         * to +90 degrees). INT_MAX if unknown */ +} RIL_CellIdentityCdma; + +/** RIL_CellIdentityLte */ +typedef struct { +    int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */ +    int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */ +    int ci;     /* 28-bit Cell Identity described in TS ???, INT_MAX if unknown */ +    int pci;    /* physical cell id 0..503, INT_MAX if unknown  */ +    int tac;    /* 16-bit tracking area code, INT_MAX if unknown  */ +} RIL_CellIdentityLte; + +/** RIL_CellIdentityTdscdma */ +typedef struct { +    int mcc;    /* 3-digit Mobile Country Code, 0..999, INT_MAX if unknown  */ +    int mnc;    /* 2 or 3-digit Mobile Network Code, 0..999, INT_MAX if unknown  */ +    int lac;    /* 16-bit Location Area Code, 0..65535, INT_MAX if unknown  */ +    int cid;    /* 28-bit UMTS Cell Identity described in TS 25.331, 0..268435455, INT_MAX if unknown  */ +    int cpid;    /* 8-bit Cell Parameters ID described in TS 25.331, 0..127, INT_MAX if unknown */ +} RIL_CellIdentityTdscdma; + +/** RIL_CellInfoGsm */ +typedef struct { +  RIL_CellIdentityGsm   cellIdentityGsm; +  RIL_GW_SignalStrength signalStrengthGsm; +} RIL_CellInfoGsm; + +/** RIL_CellInfoWcdma */ +typedef struct { +  RIL_CellIdentityWcdma cellIdentityWcdma; +  RIL_SignalStrengthWcdma signalStrengthWcdma; +} RIL_CellInfoWcdma; + +/** RIL_CellInfoCdma */ +typedef struct { +  RIL_CellIdentityCdma      cellIdentityCdma; +  RIL_CDMA_SignalStrength   signalStrengthCdma; +  RIL_EVDO_SignalStrength   signalStrengthEvdo; +} RIL_CellInfoCdma; + +/** RIL_CellInfoLte */ +typedef struct { +  RIL_CellIdentityLte        cellIdentityLte; +  RIL_LTE_SignalStrength_v8  signalStrengthLte; +} RIL_CellInfoLte; + +/** RIL_CellInfoTdscdma */ +typedef struct { +  RIL_CellIdentityTdscdma cellIdentityTdscdma; +  RIL_TD_SCDMA_SignalStrength signalStrengthTdscdma; +} RIL_CellInfoTdscdma; + +// Must be the same as CellInfo.TYPE_XXX +typedef enum { +  RIL_CELL_INFO_TYPE_GSM    = 1, +  RIL_CELL_INFO_TYPE_CDMA   = 2, +  RIL_CELL_INFO_TYPE_LTE    = 3, +  RIL_CELL_INFO_TYPE_WCDMA  = 4, +  RIL_CELL_INFO_TYPE_TD_SCDMA  = 5 +} RIL_CellInfoType; + +// Must be the same as CellInfo.TIMESTAMP_TYPE_XXX +typedef enum { +    RIL_TIMESTAMP_TYPE_UNKNOWN = 0, +    RIL_TIMESTAMP_TYPE_ANTENNA = 1, +    RIL_TIMESTAMP_TYPE_MODEM = 2, +    RIL_TIMESTAMP_TYPE_OEM_RIL = 3, +    RIL_TIMESTAMP_TYPE_JAVA_RIL = 4, +} RIL_TimeStampType; + +typedef struct { +  RIL_CellInfoType  cellInfoType;   /* cell type for selecting from union CellInfo */ +  int               registered;     /* !0 if this cell is registered 0 if not registered */ +  RIL_TimeStampType timeStampType;  /* type of time stamp represented by timeStamp */ +  uint64_t          timeStamp;      /* Time in nanos as returned by ril_nano_time */ +  union { +    RIL_CellInfoGsm     gsm; +    RIL_CellInfoCdma    cdma; +    RIL_CellInfoLte     lte; +    RIL_CellInfoWcdma   wcdma; +    RIL_CellInfoTdscdma tdscdma; +  } CellInfo; +} RIL_CellInfo; + +/* Names of the CDMA info records (C.S0005 section 3.7.5) */ +typedef enum { +  RIL_CDMA_DISPLAY_INFO_REC, +  RIL_CDMA_CALLED_PARTY_NUMBER_INFO_REC, +  RIL_CDMA_CALLING_PARTY_NUMBER_INFO_REC, +  RIL_CDMA_CONNECTED_NUMBER_INFO_REC, +  RIL_CDMA_SIGNAL_INFO_REC, +  RIL_CDMA_REDIRECTING_NUMBER_INFO_REC, +  RIL_CDMA_LINE_CONTROL_INFO_REC, +  RIL_CDMA_EXTENDED_DISPLAY_INFO_REC, +  RIL_CDMA_T53_CLIR_INFO_REC, +  RIL_CDMA_T53_RELEASE_INFO_REC, +  RIL_CDMA_T53_AUDIO_CONTROL_INFO_REC +} RIL_CDMA_InfoRecName; + +/* Display Info Rec as defined in C.S0005 section 3.7.5.1 +   Extended Display Info Rec as defined in C.S0005 section 3.7.5.16 +   Note: the Extended Display info rec contains multiple records of the +   form: display_tag, display_len, and display_len occurrences of the +   chari field if the display_tag is not 10000000 or 10000001. +   To save space, the records are stored consecutively in a byte buffer. +   The display_tag, display_len and chari fields are all 1 byte. +*/ + +typedef struct { +  char alpha_len; +  char alpha_buf[CDMA_ALPHA_INFO_BUFFER_LENGTH]; +} RIL_CDMA_DisplayInfoRecord; + +/* Called Party Number Info Rec as defined in C.S0005 section 3.7.5.2 +   Calling Party Number Info Rec as defined in C.S0005 section 3.7.5.3 +   Connected Number Info Rec as defined in C.S0005 section 3.7.5.4 +*/ + +typedef struct { +  char len; +  char buf[CDMA_NUMBER_INFO_BUFFER_LENGTH]; +  char number_type; +  char number_plan; +  char pi; +  char si; +} RIL_CDMA_NumberInfoRecord; + +/* Redirecting Number Information Record as defined in C.S0005 section 3.7.5.11 */ +typedef enum { +  RIL_REDIRECTING_REASON_UNKNOWN = 0, +  RIL_REDIRECTING_REASON_CALL_FORWARDING_BUSY = 1, +  RIL_REDIRECTING_REASON_CALL_FORWARDING_NO_REPLY = 2, +  RIL_REDIRECTING_REASON_CALLED_DTE_OUT_OF_ORDER = 9, +  RIL_REDIRECTING_REASON_CALL_FORWARDING_BY_THE_CALLED_DTE = 10, +  RIL_REDIRECTING_REASON_CALL_FORWARDING_UNCONDITIONAL = 15, +  RIL_REDIRECTING_REASON_RESERVED +} RIL_CDMA_RedirectingReason; + +typedef struct { +  RIL_CDMA_NumberInfoRecord redirectingNumber; +  /* redirectingReason is set to RIL_REDIRECTING_REASON_UNKNOWN if not included */ +  RIL_CDMA_RedirectingReason redirectingReason; +} RIL_CDMA_RedirectingNumberInfoRecord; + +/* Line Control Information Record as defined in C.S0005 section 3.7.5.15 */ +typedef struct { +  char lineCtrlPolarityIncluded; +  char lineCtrlToggle; +  char lineCtrlReverse; +  char lineCtrlPowerDenial; +} RIL_CDMA_LineControlInfoRecord; + +/* T53 CLIR Information Record */ +typedef struct { +  char cause; +} RIL_CDMA_T53_CLIRInfoRecord; + +/* T53 Audio Control Information Record */ +typedef struct { +  char upLink; +  char downLink; +} RIL_CDMA_T53_AudioControlInfoRecord; + +typedef struct { + +  RIL_CDMA_InfoRecName name; + +  union { +    /* Display and Extended Display Info Rec */ +    RIL_CDMA_DisplayInfoRecord           display; + +    /* Called Party Number, Calling Party Number, Connected Number Info Rec */ +    RIL_CDMA_NumberInfoRecord            number; + +    /* Signal Info Rec */ +    RIL_CDMA_SignalInfoRecord            signal; + +    /* Redirecting Number Info Rec */ +    RIL_CDMA_RedirectingNumberInfoRecord redir; + +    /* Line Control Info Rec */ +    RIL_CDMA_LineControlInfoRecord       lineCtrl; + +    /* T53 CLIR Info Rec */ +    RIL_CDMA_T53_CLIRInfoRecord          clir; + +    /* T53 Audio Control Info Rec */ +    RIL_CDMA_T53_AudioControlInfoRecord  audioCtrl; +  } rec; +} RIL_CDMA_InformationRecord; + +#define RIL_CDMA_MAX_NUMBER_OF_INFO_RECS 10 + +typedef struct { +  char numberOfInfoRecs; +  RIL_CDMA_InformationRecord infoRec[RIL_CDMA_MAX_NUMBER_OF_INFO_RECS]; +} RIL_CDMA_InformationRecords; + +/* See RIL_REQUEST_NV_READ_ITEM */ +typedef struct { +  RIL_NV_Item itemID; +} RIL_NV_ReadItem; + +/* See RIL_REQUEST_NV_WRITE_ITEM */ +typedef struct { +  RIL_NV_Item   itemID; +  char *        value; +} RIL_NV_WriteItem; + +typedef enum { +    HANDOVER_STARTED = 0, +    HANDOVER_COMPLETED = 1, +    HANDOVER_FAILED = 2, +    HANDOVER_CANCELED = 3 +} RIL_SrvccState; + +/* hardware configuration reported to RILJ. */ +typedef enum { +   RIL_HARDWARE_CONFIG_MODEM = 0, +   RIL_HARDWARE_CONFIG_SIM = 1, +} RIL_HardwareConfig_Type; + +typedef enum { +   RIL_HARDWARE_CONFIG_STATE_ENABLED = 0, +   RIL_HARDWARE_CONFIG_STATE_STANDBY = 1, +   RIL_HARDWARE_CONFIG_STATE_DISABLED = 2, +} RIL_HardwareConfig_State; + +typedef struct { +   int rilModel; +   uint32_t rat; /* bitset - ref. RIL_RadioTechnology. */ +   int maxVoice; +   int maxData; +   int maxStandby; +} RIL_HardwareConfig_Modem; + +typedef struct { +   char modemUuid[MAX_UUID_LENGTH]; +} RIL_HardwareConfig_Sim; + +typedef struct { +  RIL_HardwareConfig_Type type; +  char uuid[MAX_UUID_LENGTH]; +  RIL_HardwareConfig_State state; +  union { +     RIL_HardwareConfig_Modem modem; +     RIL_HardwareConfig_Sim sim; +  } cfg; +} RIL_HardwareConfig; + +typedef enum { +  SS_CFU, +  SS_CF_BUSY, +  SS_CF_NO_REPLY, +  SS_CF_NOT_REACHABLE, +  SS_CF_ALL, +  SS_CF_ALL_CONDITIONAL, +  SS_CLIP, +  SS_CLIR, +  SS_COLP, +  SS_COLR, +  SS_WAIT, +  SS_BAOC, +  SS_BAOIC, +  SS_BAOIC_EXC_HOME, +  SS_BAIC, +  SS_BAIC_ROAMING, +  SS_ALL_BARRING, +  SS_OUTGOING_BARRING, +  SS_INCOMING_BARRING +} RIL_SsServiceType; + +typedef enum { +  SS_ACTIVATION, +  SS_DEACTIVATION, +  SS_INTERROGATION, +  SS_REGISTRATION, +  SS_ERASURE +} RIL_SsRequestType; + +typedef enum { +  SS_ALL_TELE_AND_BEARER_SERVICES, +  SS_ALL_TELESEVICES, +  SS_TELEPHONY, +  SS_ALL_DATA_TELESERVICES, +  SS_SMS_SERVICES, +  SS_ALL_TELESERVICES_EXCEPT_SMS +} RIL_SsTeleserviceType; + +#define SS_INFO_MAX 4 +#define NUM_SERVICE_CLASSES 7 + +typedef struct { +  int numValidIndexes; /* This gives the number of valid values in cfInfo. +                       For example if voice is forwarded to one number and data +                       is forwarded to a different one then numValidIndexes will be +                       2 indicating total number of valid values in cfInfo. +                       Similarly if all the services are forwarded to the same +                       number then the value of numValidIndexes will be 1. */ + +  RIL_CallForwardInfo cfInfo[NUM_SERVICE_CLASSES]; /* This is the response data +                                                      for SS request to query call +                                                      forward status. see +                                                      RIL_REQUEST_QUERY_CALL_FORWARD_STATUS */ +} RIL_CfData; + +typedef struct { +  RIL_SsServiceType serviceType; +  RIL_SsRequestType requestType; +  RIL_SsTeleserviceType teleserviceType; +  int serviceClass; +  RIL_Errno result; + +  union { +    int ssInfo[SS_INFO_MAX]; /* This is the response data for most of the SS GET/SET +                                RIL requests. E.g. RIL_REQUSET_GET_CLIR returns +                                two ints, so first two values of ssInfo[] will be +                                used for response if serviceType is SS_CLIR and +                                requestType is SS_INTERROGATION */ + +    RIL_CfData cfData; +  }; +} RIL_StkCcUnsolSsResponse; + +/** + * Data connection power state + */ +typedef enum { +    RIL_DC_POWER_STATE_LOW      = 1,        // Low power state +    RIL_DC_POWER_STATE_MEDIUM   = 2,        // Medium power state +    RIL_DC_POWER_STATE_HIGH     = 3,        // High power state +    RIL_DC_POWER_STATE_UNKNOWN  = INT32_MAX // Unknown state +} RIL_DcPowerStates; + +/** + * Data connection real time info + */ +typedef struct { +    uint64_t                    time;       // Time in nanos as returned by ril_nano_time +    RIL_DcPowerStates           powerState; // Current power state +} RIL_DcRtInfo; + +/** + * Data profile to modem + */ +typedef struct { +    /* id of the data profile */ +    int profileId; +    /* the APN to connect to */ +    char* apn; +    /** one of the PDP_type values in TS 27.007 section 10.1.1. +     * For example, "IP", "IPV6", "IPV4V6", or "PPP". +     */ +    char* protocol; +    /** authentication protocol used for this PDP context +     * (None: 0, PAP: 1, CHAP: 2, PAP&CHAP: 3) +     */ +    int authType; +    /* the username for APN, or NULL */ +    char* user; +    /* the password for APN, or NULL */ +    char* password; +    /* the profile type, TYPE_COMMON-0, TYPE_3GPP-1, TYPE_3GPP2-2 */ +    int type; +    /* the period in seconds to limit the maximum connections */ +    int maxConnsTime; +    /* the maximum connections during maxConnsTime */ +    int maxConns; +    /** the required wait time in seconds after a successful UE initiated +     * disconnect of a given PDN connection before the device can send +     * a new PDN connection request for that given PDN +     */ +    int waitTime; +    /* true to enable the profile, 0 to disable, 1 to enable */ +    int enabled; +} RIL_DataProfileInfo; + +/* Tx Power Levels */ +#define RIL_NUM_TX_POWER_LEVELS     5 + +typedef struct { + +  /* period (in ms) when modem is power collapsed */ +  uint32_t sleep_mode_time_ms; + +  /* period (in ms) when modem is awake and in idle mode*/ +  uint32_t idle_mode_time_ms; + +  /* period (in ms) for which Tx is active */ +  uint32_t tx_mode_time_ms[RIL_NUM_TX_POWER_LEVELS]; + +  /* period (in ms) for which Rx is active */ +  uint32_t rx_mode_time_ms; +} RIL_ActivityStatsInfo; + +/** + * RIL_REQUEST_GET_SIM_STATUS + * + * Requests status of the SIM interface and the SIM card + * + * "data" is NULL + * + * "response" is const RIL_CardStatus_v6 * + * + * Valid errors: + *  Must never fail + */ +#define RIL_REQUEST_GET_SIM_STATUS 1 + +/** + * RIL_REQUEST_ENTER_SIM_PIN + * + * Supplies SIM PIN. Only called if RIL_CardStatus has RIL_APPSTATE_PIN state + * + * "data" is const char ** + * ((const char **)data)[0] is PIN value + * ((const char **)data)[1] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + * SUCCESS + * RADIO_NOT_AVAILABLE (radio resetting) + * GENERIC_FAILURE + * PASSWORD_INCORRECT + */ + +#define RIL_REQUEST_ENTER_SIM_PIN 2 + +/** + * RIL_REQUEST_ENTER_SIM_PUK + * + * Supplies SIM PUK and new PIN. + * + * "data" is const char ** + * ((const char **)data)[0] is PUK value + * ((const char **)data)[1] is new PIN value + * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + *     (PUK is invalid) + */ + +#define RIL_REQUEST_ENTER_SIM_PUK 3 + +/** + * RIL_REQUEST_ENTER_SIM_PIN2 + * + * Supplies SIM PIN2. Only called following operation where SIM_PIN2 was + * returned as a a failure from a previous operation. + * + * "data" is const char ** + * ((const char **)data)[0] is PIN2 value + * ((const char **)data)[1] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + */ + +#define RIL_REQUEST_ENTER_SIM_PIN2 4 + +/** + * RIL_REQUEST_ENTER_SIM_PUK2 + * + * Supplies SIM PUK2 and new PIN2. + * + * "data" is const char ** + * ((const char **)data)[0] is PUK2 value + * ((const char **)data)[1] is new PIN2 value + * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + *     (PUK2 is invalid) + */ + +#define RIL_REQUEST_ENTER_SIM_PUK2 5 + +/** + * RIL_REQUEST_CHANGE_SIM_PIN + * + * Supplies old SIM PIN and new PIN. + * + * "data" is const char ** + * ((const char **)data)[0] is old PIN value + * ((const char **)data)[1] is new PIN value + * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + *     (old PIN is invalid) + * + */ + +#define RIL_REQUEST_CHANGE_SIM_PIN 6 + + +/** + * RIL_REQUEST_CHANGE_SIM_PIN2 + * + * Supplies old SIM PIN2 and new PIN2. + * + * "data" is const char ** + * ((const char **)data)[0] is old PIN2 value + * ((const char **)data)[1] is new PIN2 value + * ((const char **)data)[2] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + *     (old PIN2 is invalid) + * + */ + +#define RIL_REQUEST_CHANGE_SIM_PIN2 7 + +/** + * RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION + * + * Requests that network personlization be deactivated + * + * "data" is const char ** + * ((const char **)(data))[0]] is network depersonlization code + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  PASSWORD_INCORRECT + *     (code is invalid) + */ + +#define RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION 8 + +/** + * RIL_REQUEST_GET_CURRENT_CALLS + * + * Requests current call list + * + * "data" is NULL + * + * "response" must be a "const RIL_Call **" + * + * Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *      (request will be made again in a few hundred msec) + */ + +#define RIL_REQUEST_GET_CURRENT_CALLS 9 + + +/** + * RIL_REQUEST_DIAL + * + * Initiate voice call + * + * "data" is const RIL_Dial * + * "response" is NULL + * + * This method is never used for supplementary service codes + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  DIAL_MODIFIED_TO_USSD + *  DIAL_MODIFIED_TO_SS + *  DIAL_MODIFIED_TO_DIAL + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_DIAL 10 + +/** + * RIL_REQUEST_GET_IMSI + * + * Get the SIM IMSI + * + * Only valid when radio state is "RADIO_STATE_ON" + * + * "data" is const char ** + * ((const char **)data)[0] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + * "response" is a const char * containing the IMSI + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_GET_IMSI 11 + +/** + * RIL_REQUEST_HANGUP + * + * Hang up a specific line (like AT+CHLD=1x) + * + * After this HANGUP request returns, RIL should show the connection is NOT + * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query. + * + * "data" is an int * + * (int *)data)[0] contains Connection index (value of 'x' in CHLD above) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_HANGUP 12 + +/** + * RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND + * + * Hang up waiting or held (like AT+CHLD=0) + * + * After this HANGUP request returns, RIL should show the connection is NOT + * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query. + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND 13 + +/** + * RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND + * + * Hang up waiting or held (like AT+CHLD=1) + * + * After this HANGUP request returns, RIL should show the connection is NOT + * active anymore in next RIL_REQUEST_GET_CURRENT_CALLS query. + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND 14 + +/** + * RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE + * + * Switch waiting or holding call and active call (like AT+CHLD=2) + * + * State transitions should be is follows: + * + * If call 1 is waiting and call 2 is active, then if this re + * + *   BEFORE                               AFTER + * Call 1   Call 2                 Call 1       Call 2 + * ACTIVE   HOLDING                HOLDING     ACTIVE + * ACTIVE   WAITING                HOLDING     ACTIVE + * HOLDING  WAITING                HOLDING     ACTIVE + * ACTIVE   IDLE                   HOLDING     IDLE + * IDLE     IDLE                   IDLE        IDLE + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE 15 +#define RIL_REQUEST_SWITCH_HOLDING_AND_ACTIVE 15 + +/** + * RIL_REQUEST_CONFERENCE + * + * Conference holding and active (like AT+CHLD=3) + + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_CONFERENCE 16 + +/** + * RIL_REQUEST_UDUB + * + * Send UDUB (user determined used busy) to ringing or + * waiting call answer)(RIL_BasicRequest r); + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_UDUB 17 + +/** + * RIL_REQUEST_LAST_CALL_FAIL_CAUSE + * + * Requests the failure cause code for the most recently terminated call + * + * "data" is NULL + * "response" is a "int *" + * ((int *)response)[0] is RIL_LastCallFailCause.  GSM failure reasons are + * mapped to cause codes defined in TS 24.008 Annex H where possible. CDMA + * failure reasons are derived from the possible call failure scenarios + * described in the "CDMA IS-2000 Release A (C.S0005-A v6.0)" standard. + * + * The implementation should return CALL_FAIL_ERROR_UNSPECIFIED for blocked + * MO calls by restricted state (See RIL_UNSOL_RESTRICTED_STATE_CHANGED) + * + * If the implementation does not have access to the exact cause codes, + * then it should return one of the values listed in RIL_LastCallFailCause, + * as the UI layer needs to distinguish these cases for tone generation or + * error notification. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE + */ +#define RIL_REQUEST_LAST_CALL_FAIL_CAUSE 18 + +/** + * RIL_REQUEST_SIGNAL_STRENGTH + * + * Requests current signal strength and associated information + * + * Must succeed if radio is on. + * + * "data" is NULL + * + * "response" is a const RIL_SignalStrength * + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + */ +#define RIL_REQUEST_SIGNAL_STRENGTH 19 + +/** + * RIL_REQUEST_VOICE_REGISTRATION_STATE + * + * Request current registration state + * + * "data" is NULL + * "response" is a "char **" + * ((const char **)response)[0] is registration state 0-6, + *              0 - Not registered, MT is not currently searching + *                  a new operator to register + *              1 - Registered, home network + *              2 - Not registered, but MT is currently searching + *                  a new operator to register + *              3 - Registration denied + *              4 - Unknown + *              5 - Registered, roaming + *             10 - Same as 0, but indicates that emergency calls + *                  are enabled. + *             12 - Same as 2, but indicates that emergency calls + *                  are enabled. + *             13 - Same as 3, but indicates that emergency calls + *                  are enabled. + *             14 - Same as 4, but indicates that emergency calls + *                  are enabled. + * + * ((const char **)response)[1] is LAC if registered on a GSM/WCDMA system or + *                              NULL if not.Valid LAC are 0x0000 - 0xffff + * ((const char **)response)[2] is CID if registered on a * GSM/WCDMA or + *                              NULL if not. + *                                 Valid CID are 0x00000000 - 0xffffffff + *                                    In GSM, CID is Cell ID (see TS 27.007) + *                                            in 16 bits + *                                    In UMTS, CID is UMTS Cell Identity + *                                             (see TS 25.331) in 28 bits + * ((const char **)response)[3] indicates the available voice radio technology, + *                              valid values as defined by RIL_RadioTechnology. + * ((const char **)response)[4] is Base Station ID if registered on a CDMA + *                              system or NULL if not.  Base Station ID in + *                              decimal format + * ((const char **)response)[5] is Base Station latitude if registered on a + *                              CDMA system or NULL if not. Base Station + *                              latitude is a decimal number as specified in + *                              3GPP2 C.S0005-A v6.0. It is represented in + *                              units of 0.25 seconds and ranges from -1296000 + *                              to 1296000, both values inclusive (corresponding + *                              to a range of -90 to +90 degrees). + * ((const char **)response)[6] is Base Station longitude if registered on a + *                              CDMA system or NULL if not. Base Station + *                              longitude is a decimal number as specified in + *                              3GPP2 C.S0005-A v6.0. It is represented in + *                              units of 0.25 seconds and ranges from -2592000 + *                              to 2592000, both values inclusive (corresponding + *                              to a range of -180 to +180 degrees). + * ((const char **)response)[7] is concurrent services support indicator if + *                              registered on a CDMA system 0-1. + *                                   0 - Concurrent services not supported, + *                                   1 - Concurrent services supported + * ((const char **)response)[8] is System ID if registered on a CDMA system or + *                              NULL if not. Valid System ID are 0 - 32767 + * ((const char **)response)[9] is Network ID if registered on a CDMA system or + *                              NULL if not. Valid System ID are 0 - 65535 + * ((const char **)response)[10] is the TSB-58 Roaming Indicator if registered + *                               on a CDMA or EVDO system or NULL if not. Valid values + *                               are 0-255. + * ((const char **)response)[11] indicates whether the current system is in the + *                               PRL if registered on a CDMA or EVDO system or NULL if + *                               not. 0=not in the PRL, 1=in the PRL + * ((const char **)response)[12] is the default Roaming Indicator from the PRL, + *                               if registered on a CDMA or EVDO system or NULL if not. + *                               Valid values are 0-255. + * ((const char **)response)[13] if registration state is 3 (Registration + *                               denied) this is an enumerated reason why + *                               registration was denied.  See 3GPP TS 24.008, + *                               10.5.3.6 and Annex G. + *                                 0 - General + *                                 1 - Authentication Failure + *                                 2 - IMSI unknown in HLR + *                                 3 - Illegal MS + *                                 4 - Illegal ME + *                                 5 - PLMN not allowed + *                                 6 - Location area not allowed + *                                 7 - Roaming not allowed + *                                 8 - No Suitable Cells in this Location Area + *                                 9 - Network failure + *                                10 - Persistent location update reject + *                                11 - PLMN not allowed + *                                12 - Location area not allowed + *                                13 - Roaming not allowed in this Location Area + *                                15 - No Suitable Cells in this Location Area + *                                17 - Network Failure + *                                20 - MAC Failure + *                                21 - Sync Failure + *                                22 - Congestion + *                                23 - GSM Authentication unacceptable + *                                25 - Not Authorized for this CSG + *                                32 - Service option not supported + *                                33 - Requested service option not subscribed + *                                34 - Service option temporarily out of order + *                                38 - Call cannot be identified + *                                48-63 - Retry upon entry into a new cell + *                                95 - Semantically incorrect message + *                                96 - Invalid mandatory information + *                                97 - Message type non-existent or not implemented + *                                98 - Message not compatible with protocol state + *                                99 - Information element non-existent or not implemented + *                               100 - Conditional IE error + *                               101 - Message not compatible with protocol state + *                               111 - Protocol error, unspecified + * ((const char **)response)[14] is the Primary Scrambling Code of the current + *                               cell as described in TS 25.331, in hexadecimal + *                               format, or NULL if unknown or not registered + *                               to a UMTS network. + * + * Please note that registration state 4 ("unknown") is treated + * as "out of service" in the Android telephony system + * + * Registration state 3 can be returned if Location Update Reject + * (with cause 17 - Network Failure) is received repeatedly from the network, + * to facilitate "managed roaming" + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_VOICE_REGISTRATION_STATE 20 + +/** + * RIL_REQUEST_DATA_REGISTRATION_STATE + * + * Request current DATA registration state + * + * "data" is NULL + * "response" is a "char **" + * ((const char **)response)[0] is registration state 0-5 from TS 27.007 10.1.20 AT+CGREG + * ((const char **)response)[1] is LAC if registered or NULL if not + * ((const char **)response)[2] is CID if registered or NULL if not + * ((const char **)response)[3] indicates the available data radio technology, + *                              valid values as defined by RIL_RadioTechnology. + * ((const char **)response)[4] if registration state is 3 (Registration + *                               denied) this is an enumerated reason why + *                               registration was denied.  See 3GPP TS 24.008, + *                               Annex G.6 "Additonal cause codes for GMM". + *      7 == GPRS services not allowed + *      8 == GPRS services and non-GPRS services not allowed + *      9 == MS identity cannot be derived by the network + *      10 == Implicitly detached + *      14 == GPRS services not allowed in this PLMN + *      16 == MSC temporarily not reachable + *      40 == No PDP context activated + * ((const char **)response)[5] The maximum number of simultaneous Data Calls that can be + *                              established using RIL_REQUEST_SETUP_DATA_CALL. + * + * The values at offsets 6..10 are optional LTE location information in decimal. + * If a value is unknown that value may be NULL. If all values are NULL, + * none need to be present. + *  ((const char **)response)[6] is TAC, a 16-bit Tracking Area Code. + *  ((const char **)response)[7] is CID, a 0-503 Physical Cell Identifier. + *  ((const char **)response)[8] is ECI, a 28-bit E-UTRAN Cell Identifier. + *  ((const char **)response)[9] is CSGID, a 27-bit Closed Subscriber Group Identity. + *  ((const char **)response)[10] is TADV, a 6-bit timing advance value. + * + * LAC and CID are in hexadecimal format. + * valid LAC are 0x0000 - 0xffff + * valid CID are 0x00000000 - 0x0fffffff + * + * Please note that registration state 4 ("unknown") is treated + * as "out of service" in the Android telephony system + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_DATA_REGISTRATION_STATE 21 + +/** + * RIL_REQUEST_OPERATOR + * + * Request current operator ONS or EONS + * + * "data" is NULL + * "response" is a "const char **" + * ((const char **)response)[0] is long alpha ONS or EONS + *                                  or NULL if unregistered + * + * ((const char **)response)[1] is short alpha ONS or EONS + *                                  or NULL if unregistered + * ((const char **)response)[2] is 5 or 6 digit numeric code (MCC + MNC) + *                                  or NULL if unregistered + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_OPERATOR 22 + +/** + * RIL_REQUEST_RADIO_POWER + * + * Toggle radio on and off (for "airplane" mode) + * If the radio is is turned off/on the radio modem subsystem + * is expected return to an initialized state. For instance, + * any voice and data calls will be terminated and all associated + * lists emptied. + * + * "data" is int * + * ((int *)data)[0] is > 0 for "Radio On" + * ((int *)data)[0] is == 0 for "Radio Off" + * + * "response" is NULL + * + * Turn radio on if "on" > 0 + * Turn radio off if "on" == 0 + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_RADIO_POWER 23 + +/** + * RIL_REQUEST_DTMF + * + * Send a DTMF tone + * + * If the implementation is currently playing a tone requested via + * RIL_REQUEST_DTMF_START, that tone should be cancelled and the new tone + * should be played instead + * + * "data" is a char * containing a single character with one of 12 values: 0-9,*,# + * "response" is NULL + * + * FIXME should this block/mute microphone? + * How does this interact with local DTMF feedback? + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_DTMF_STOP, RIL_REQUEST_DTMF_START + * + */ +#define RIL_REQUEST_DTMF 24 + +/** + * RIL_REQUEST_SEND_SMS + * + * Send an SMS message + * + * "data" is const char ** + * ((const char **)data)[0] is SMSC address in GSM BCD format prefixed + *      by a length byte (as expected by TS 27.005) or NULL for default SMSC + * ((const char **)data)[1] is SMS in PDU format as an ASCII hex string + *      less the SMSC address + *      TP-Layer-Length is be "strlen(((const char **)data)[1])/2" + * + * "response" is a const RIL_SMS_Response * + * + * Based on the return error, caller decides to resend if sending sms + * fails. SMS_SEND_FAIL_RETRY means retry (i.e. error cause is 332) + * and GENERIC_FAILURE means no retry (i.e. error cause is 500) + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SMS_SEND_FAIL_RETRY + *  FDN_CHECK_FAILURE + *  GENERIC_FAILURE + * + * FIXME how do we specify TP-Message-Reference if we need to resend? + */ +#define RIL_REQUEST_SEND_SMS 25 + + +/** + * RIL_REQUEST_SEND_SMS_EXPECT_MORE + * + * Send an SMS message. Identical to RIL_REQUEST_SEND_SMS, + * except that more messages are expected to be sent soon. If possible, + * keep SMS relay protocol link open (eg TS 27.005 AT+CMMS command) + * + * "data" is const char ** + * ((const char **)data)[0] is SMSC address in GSM BCD format prefixed + *      by a length byte (as expected by TS 27.005) or NULL for default SMSC + * ((const char **)data)[1] is SMS in PDU format as an ASCII hex string + *      less the SMSC address + *      TP-Layer-Length is be "strlen(((const char **)data)[1])/2" + * + * "response" is a const RIL_SMS_Response * + * + * Based on the return error, caller decides to resend if sending sms + * fails. SMS_SEND_FAIL_RETRY means retry (i.e. error cause is 332) + * and GENERIC_FAILURE means no retry (i.e. error cause is 500) + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SMS_SEND_FAIL_RETRY + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_SEND_SMS_EXPECT_MORE 26 + + +/** + * RIL_REQUEST_SETUP_DATA_CALL + * + * Setup a packet data connection. If RIL_Data_Call_Response_v6.status + * return success it is added to the list of data calls and a + * RIL_UNSOL_DATA_CALL_LIST_CHANGED is sent. The call remains in the + * list until RIL_REQUEST_DEACTIVATE_DATA_CALL is issued or the + * radio is powered off/on. This list is returned by RIL_REQUEST_DATA_CALL_LIST + * and RIL_UNSOL_DATA_CALL_LIST_CHANGED. + * + * The RIL is expected to: + *  - Create one data call context. + *  - Create and configure a dedicated interface for the context + *  - The interface must be point to point. + *  - The interface is configured with one or more addresses and + *    is capable of sending and receiving packets. The prefix length + *    of the addresses must be /32 for IPv4 and /128 for IPv6. + *  - Must NOT change the linux routing table. + *  - Support up to RIL_REQUEST_DATA_REGISTRATION_STATE response[5] + *    number of simultaneous data call contexts. + * + * "data" is a const char ** + * ((const char **)data)[0] Radio technology to use: 0-CDMA, 1-GSM/UMTS, 2... + *                          for values above 2 this is RIL_RadioTechnology + 2. + * ((const char **)data)[1] is a RIL_DataProfile (support is optional) + * ((const char **)data)[2] is the APN to connect to if radio technology is GSM/UMTS. This APN will + *                          override the one in the profile. NULL indicates no APN overrride. + * ((const char **)data)[3] is the username for APN, or NULL + * ((const char **)data)[4] is the password for APN, or NULL + * ((const char **)data)[5] is the PAP / CHAP auth type. Values: + *                          0 => PAP and CHAP is never performed. + *                          1 => PAP may be performed; CHAP is never performed. + *                          2 => CHAP may be performed; PAP is never performed. + *                          3 => PAP / CHAP may be performed - baseband dependent. + * ((const char **)data)[6] is the connection type to request must be one of the + *                          PDP_type values in TS 27.007 section 10.1.1. + *                          For example, "IP", "IPV6", "IPV4V6", or "PPP". + * ((const char **)data)[7] Optional connection property parameters, format to be defined. + * + * "response" is a RIL_Data_Call_Response_v11 + * + * FIXME may need way to configure QoS settings + * + * Valid errors: + *  SUCCESS should be returned on both success and failure of setup with + *  the RIL_Data_Call_Response_v6.status containing the actual status. + *  For all other errors the RIL_Data_Call_Resonse_v6 is ignored. + * + *  Other errors could include: + *    RADIO_NOT_AVAILABLE, GENERIC_FAILURE, OP_NOT_ALLOWED_BEFORE_REG_TO_NW, + *    OP_NOT_ALLOWED_DURING_VOICE_CALL and REQUEST_NOT_SUPPORTED. + * + * See also: RIL_REQUEST_DEACTIVATE_DATA_CALL + */ +#define RIL_REQUEST_SETUP_DATA_CALL 27 + + +/** + * RIL_REQUEST_SIM_IO + * + * Request SIM I/O operation. + * This is similar to the TS 27.007 "restricted SIM" operation + * where it assumes all of the EF selection will be done by the + * callee. + * + * "data" is a const RIL_SIM_IO_v6 * + * Please note that RIL_SIM_IO has a "PIN2" field which may be NULL, + * or may specify a PIN2 for operations that require a PIN2 (eg + * updating FDN records) + * + * "response" is a const RIL_SIM_IO_Response * + * + * Arguments and responses that are unused for certain + * values of "command" should be ignored or set to NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + *  SIM_PIN2 + *  SIM_PUK2 + */ +#define RIL_REQUEST_SIM_IO 28 + +/** + * RIL_REQUEST_SEND_USSD + * + * Send a USSD message + * + * If a USSD session already exists, the message should be sent in the + * context of that session. Otherwise, a new session should be created. + * + * The network reply should be reported via RIL_UNSOL_ON_USSD + * + * Only one USSD session may exist at a time, and the session is assumed + * to exist until: + *   a) The android system invokes RIL_REQUEST_CANCEL_USSD + *   b) The implementation sends a RIL_UNSOL_ON_USSD with a type code + *      of "0" (USSD-Notify/no further action) or "2" (session terminated) + * + * "data" is a const char * containing the USSD request in UTF-8 format + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  FDN_CHECK_FAILURE + *  USSD_MODIFIED_TO_DIAL + *  USSD_MODIFIED_TO_SS + *  USSD_MODIFIED_TO_USSD + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_CANCEL_USSD, RIL_UNSOL_ON_USSD + */ + +#define RIL_REQUEST_SEND_USSD 29 + +/** + * RIL_REQUEST_CANCEL_USSD + * + * Cancel the current USSD session if one exists + * + * "data" is null + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_CANCEL_USSD 30 + +/** + * RIL_REQUEST_GET_CLIR + * + * Gets current CLIR status + * "data" is NULL + * "response" is int * + * ((int *)data)[0] is "n" parameter from TS 27.007 7.7 + * ((int *)data)[1] is "m" parameter from TS 27.007 7.7 + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_GET_CLIR 31 + +/** + * RIL_REQUEST_SET_CLIR + * + * "data" is int * + * ((int *)data)[0] is "n" parameter from TS 27.007 7.7 + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_CLIR 32 + +/** + * RIL_REQUEST_QUERY_CALL_FORWARD_STATUS + * + * "data" is const RIL_CallForwardInfo * + * + * "response" is const RIL_CallForwardInfo ** + * "response" points to an array of RIL_CallForwardInfo *'s, one for + * each distinct registered phone number. + * + * For example, if data is forwarded to +18005551212 and voice is forwarded + * to +18005559999, then two separate RIL_CallForwardInfo's should be returned + * + * If, however, both data and voice are forwarded to +18005551212, then + * a single RIL_CallForwardInfo can be returned with the service class + * set to "data + voice = 3") + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_QUERY_CALL_FORWARD_STATUS 33 + + +/** + * RIL_REQUEST_SET_CALL_FORWARD + * + * Configure call forward rule + * + * "data" is const RIL_CallForwardInfo * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_CALL_FORWARD 34 + + +/** + * RIL_REQUEST_QUERY_CALL_WAITING + * + * Query current call waiting state + * + * "data" is const int * + * ((const int *)data)[0] is the TS 27.007 service class to query. + * "response" is a const int * + * ((const int *)response)[0] is 0 for "disabled" and 1 for "enabled" + * + * If ((const int *)response)[0] is = 1, then ((const int *)response)[1] + * must follow, with the TS 27.007 service class bit vector of services + * for which call waiting is enabled. + * + * For example, if ((const int *)response)[0]  is 1 and + * ((const int *)response)[1] is 3, then call waiting is enabled for data + * and voice and disabled for everything else + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_QUERY_CALL_WAITING 35 + + +/** + * RIL_REQUEST_SET_CALL_WAITING + * + * Configure current call waiting state + * + * "data" is const int * + * ((const int *)data)[0] is 0 for "disabled" and 1 for "enabled" + * ((const int *)data)[1] is the TS 27.007 service class bit vector of + *                           services to modify + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_CALL_WAITING 36 + +/** + * RIL_REQUEST_SMS_ACKNOWLEDGE + * + * Acknowledge successful or failed receipt of SMS previously indicated + * via RIL_UNSOL_RESPONSE_NEW_SMS + * + * "data" is int * + * ((int *)data)[0] is 1 on successful receipt + *                  (basically, AT+CNMA=1 from TS 27.005 + *                  is 0 on failed receipt + *                  (basically, AT+CNMA=2 from TS 27.005) + * ((int *)data)[1] if data[0] is 0, this contains the failure cause as defined + *                  in TS 23.040, 9.2.3.22. Currently only 0xD3 (memory + *                  capacity exceeded) and 0xFF (unspecified error) are + *                  reported. + * + * "response" is NULL + * + * FIXME would like request that specified RP-ACK/RP-ERROR PDU + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SMS_ACKNOWLEDGE  37 + +/** + * RIL_REQUEST_GET_IMEI - DEPRECATED + * + * Get the device IMEI, including check digit + * + * The request is DEPRECATED, use RIL_REQUEST_DEVICE_IDENTITY + * Valid when RadioState is not RADIO_STATE_UNAVAILABLE + * + * "data" is NULL + * "response" is a const char * containing the IMEI + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_GET_IMEI 38 + +/** + * RIL_REQUEST_GET_IMEISV - DEPRECATED + * + * Get the device IMEISV, which should be two decimal digits + * + * The request is DEPRECATED, use RIL_REQUEST_DEVICE_IDENTITY + * Valid when RadioState is not RADIO_STATE_UNAVAILABLE + * + * "data" is NULL + * "response" is a const char * containing the IMEISV + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_GET_IMEISV 39 + + +/** + * RIL_REQUEST_ANSWER + * + * Answer incoming call + * + * Will not be called for WAITING calls. + * RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE will be used in this case + * instead + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_ANSWER 40 + +/** + * RIL_REQUEST_DEACTIVATE_DATA_CALL + * + * Deactivate packet data connection and remove from the + * data call list if SUCCESS is returned. Any other return + * values should also try to remove the call from the list, + * but that may not be possible. In any event a + * RIL_REQUEST_RADIO_POWER off/on must clear the list. An + * RIL_UNSOL_DATA_CALL_LIST_CHANGED is not expected to be + * issued because of an RIL_REQUEST_DEACTIVATE_DATA_CALL. + * + * "data" is const char ** + * ((char**)data)[0] indicating CID + * ((char**)data)[1] indicating Disconnect Reason + *                   0 => No specific reason specified + *                   1 => Radio shutdown requested + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_SETUP_DATA_CALL + */ +#define RIL_REQUEST_DEACTIVATE_DATA_CALL 41 + +/** + * RIL_REQUEST_QUERY_FACILITY_LOCK + * + * Query the status of a facility lock state + * + * "data" is const char ** + * ((const char **)data)[0] is the facility string code from TS 27.007 7.4 + *                      (eg "AO" for BAOC, "SC" for SIM lock) + * ((const char **)data)[1] is the password, or "" if not required + * ((const char **)data)[2] is the TS 27.007 service class bit vector of + *                           services to query + * ((const char **)data)[3] is AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + *                            This is only applicable in the case of Fixed Dialing Numbers + *                            (FDN) requests. + * + * "response" is an int * + * ((const int *)response) 0 is the TS 27.007 service class bit vector of + *                           services for which the specified barring facility + *                           is active. "0" means "disabled for all" + * + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_QUERY_FACILITY_LOCK 42 + +/** + * RIL_REQUEST_SET_FACILITY_LOCK + * + * Enable/disable one facility lock + * + * "data" is const char ** + * + * ((const char **)data)[0] = facility string code from TS 27.007 7.4 + * (eg "AO" for BAOC) + * ((const char **)data)[1] = "0" for "unlock" and "1" for "lock" + * ((const char **)data)[2] = password + * ((const char **)data)[3] = string representation of decimal TS 27.007 + *                            service class bit vector. Eg, the string + *                            "1" means "set this facility for voice services" + * ((const char **)data)[4] = AID value, See ETSI 102.221 8.1 and 101.220 4, NULL if no value. + *                            This is only applicable in the case of Fixed Dialing Numbers + *                            (FDN) requests. + * + * "response" is int * + * ((int *)response)[0] is the number of retries remaining, or -1 if unknown + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_SET_FACILITY_LOCK 43 + +/** + * RIL_REQUEST_CHANGE_BARRING_PASSWORD + * + * Change call barring facility password + * + * "data" is const char ** + * + * ((const char **)data)[0] = facility string code from TS 27.007 7.4 + * (eg "AO" for BAOC) + * ((const char **)data)[1] = old password + * ((const char **)data)[2] = new password + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CHANGE_BARRING_PASSWORD 44 + +/** + * RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE + * + * Query current network selectin mode + * + * "data" is NULL + * + * "response" is int * + * ((const int *)response)[0] is + *     0 for automatic selection + *     1 for manual selection + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE 45 + +/** + * RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC + * + * Specify that the network should be selected automatically + * + * "data" is NULL + * "response" is NULL + * + * This request must not respond until the new operator is selected + * and registered + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  ILLEGAL_SIM_OR_ME + *  GENERIC_FAILURE + * + * Note: Returns ILLEGAL_SIM_OR_ME when the failure is permanent and + *       no retries needed, such as illegal SIM or ME. + *       Returns GENERIC_FAILURE for all other causes that might be + *       fixed by retries. + * + */ +#define RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC 46 + +/** + * RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL + * + * Manually select a specified network. + * + * "data" is const char * specifying MCCMNC of network to select (eg "310170") + * "response" is NULL + * + * This request must not respond until the new operator is selected + * and registered + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  ILLEGAL_SIM_OR_ME + *  GENERIC_FAILURE + * + * Note: Returns ILLEGAL_SIM_OR_ME when the failure is permanent and + *       no retries needed, such as illegal SIM or ME. + *       Returns GENERIC_FAILURE for all other causes that might be + *       fixed by retries. + * + */ +#define RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL 47 + +/** + * RIL_REQUEST_QUERY_AVAILABLE_NETWORKS + * + * Scans for available networks + * + * "data" is NULL + * "response" is const char ** that should be an array of n*4 strings, where + *    n is the number of available networks + * For each available network: + * + * ((const char **)response)[n+0] is long alpha ONS or EONS + * ((const char **)response)[n+1] is short alpha ONS or EONS + * ((const char **)response)[n+2] is 5 or 6 digit numeric code (MCC + MNC) + * ((const char **)response)[n+3] is a string value of the status: + *           "unknown" + *           "available" + *           "current" + *           "forbidden" + * + * This request must not respond until the new operator is selected + * and registered + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_QUERY_AVAILABLE_NETWORKS 48 + +/** + * RIL_REQUEST_DTMF_START + * + * Start playing a DTMF tone. Continue playing DTMF tone until + * RIL_REQUEST_DTMF_STOP is received + * + * If a RIL_REQUEST_DTMF_START is received while a tone is currently playing, + * it should cancel the previous tone and play the new one. + * + * "data" is a char * + * ((char *)data)[0] is a single character with one of 12 values: 0-9,*,# + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_DTMF, RIL_REQUEST_DTMF_STOP + */ +#define RIL_REQUEST_DTMF_START 49 + +/** + * RIL_REQUEST_DTMF_STOP + * + * Stop playing a currently playing DTMF tone. + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_DTMF, RIL_REQUEST_DTMF_START + */ +#define RIL_REQUEST_DTMF_STOP 50 + +/** + * RIL_REQUEST_BASEBAND_VERSION + * + * Return string value indicating baseband version, eg + * response from AT+CGMR + * + * "data" is NULL + * "response" is const char * containing version string for log reporting + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_BASEBAND_VERSION 51 + +/** + * RIL_REQUEST_SEPARATE_CONNECTION + * + * Separate a party from a multiparty call placing the multiparty call + * (less the specified party) on hold and leaving the specified party + * as the only other member of the current (active) call + * + * Like AT+CHLD=2x + * + * See TS 22.084 1.3.8.2 (iii) + * TS 22.030 6.5.5 "Entering "2X followed by send" + * TS 27.007 "AT+CHLD=2x" + * + * "data" is an int * + * (int *)data)[0] contains Connection index (value of 'x' in CHLD above) "response" is NULL + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SEPARATE_CONNECTION 52 + + +/** + * RIL_REQUEST_SET_MUTE + * + * Turn on or off uplink (microphone) mute. + * + * Will only be sent while voice call is active. + * Will always be reset to "disable mute" when a new voice call is initiated + * + * "data" is an int * + * (int *)data)[0] is 1 for "enable mute" and 0 for "disable mute" + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_SET_MUTE 53 + +/** + * RIL_REQUEST_GET_MUTE + * + * Queries the current state of the uplink mute setting + * + * "data" is NULL + * "response" is an int * + * (int *)response)[0] is 1 for "mute enabled" and 0 for "mute disabled" + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  SS_MODIFIED_TO_DIAL + *  SS_MODIFIED_TO_USSD + *  SS_MODIFIED_TO_SS + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_GET_MUTE 54 + +/** + * RIL_REQUEST_QUERY_CLIP + * + * Queries the status of the CLIP supplementary service + * + * (for MMI code "*#30#") + * + * "data" is NULL + * "response" is an int * + * (int *)response)[0] is 1 for "CLIP provisioned" + *                           and 0 for "CLIP not provisioned" + *                           and 2 for "unknown, e.g. no network etc" + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ + +#define RIL_REQUEST_QUERY_CLIP 55 + +/** + * RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE - Deprecated use the status + * field in RIL_Data_Call_Response_v6. + * + * Requests the failure cause code for the most recently failed PDP + * context or CDMA data connection active + * replaces RIL_REQUEST_LAST_PDP_FAIL_CAUSE + * + * "data" is NULL + * + * "response" is a "int *" + * ((int *)response)[0] is an integer cause code defined in TS 24.008 + *   section 6.1.3.1.3 or close approximation + * + * If the implementation does not have access to the exact cause codes, + * then it should return one of the values listed in + * RIL_DataCallFailCause, as the UI layer needs to distinguish these + * cases for error notification + * and potential retries. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_LAST_CALL_FAIL_CAUSE + * + * Deprecated use the status field in RIL_Data_Call_Response_v6. + */ + +#define RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE 56 + +/** + * RIL_REQUEST_DATA_CALL_LIST + * + * Returns the data call list. An entry is added when a + * RIL_REQUEST_SETUP_DATA_CALL is issued and removed on a + * RIL_REQUEST_DEACTIVATE_DATA_CALL. The list is emptied + * when RIL_REQUEST_RADIO_POWER off/on is issued. + * + * "data" is NULL + * "response" is an array of RIL_Data_Call_Response_v6 + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + * + * See also: RIL_UNSOL_DATA_CALL_LIST_CHANGED + */ + +#define RIL_REQUEST_DATA_CALL_LIST 57 + +/** + * RIL_REQUEST_RESET_RADIO - DEPRECATED + * + * Request a radio reset. The RIL implementation may postpone + * the reset until after this request is responded to if the baseband + * is presently busy. + * + * The request is DEPRECATED, use RIL_REQUEST_RADIO_POWER + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  REQUEST_NOT_SUPPORTED + */ + +#define RIL_REQUEST_RESET_RADIO 58 + +/** + * RIL_REQUEST_OEM_HOOK_RAW + * + * This request reserved for OEM-specific uses. It passes raw byte arrays + * back and forth. + * + * It can be invoked on the Java side from + * com.android.internal.telephony.Phone.invokeOemRilRequestRaw() + * + * "data" is a char * of bytes copied from the byte[] data argument in java + * "response" is a char * of bytes that will returned via the + * caller's "response" Message here: + * (byte[])(((AsyncResult)response.obj).result) + * + * An error response here will result in + * (((AsyncResult)response.obj).result) == null and + * (((AsyncResult)response.obj).exception) being an instance of + * com.android.internal.telephony.gsm.CommandException + * + * Valid errors: + *  All + */ + +#define RIL_REQUEST_OEM_HOOK_RAW 59 + +/** + * RIL_REQUEST_OEM_HOOK_STRINGS + * + * This request reserved for OEM-specific uses. It passes strings + * back and forth. + * + * It can be invoked on the Java side from + * com.android.internal.telephony.Phone.invokeOemRilRequestStrings() + * + * "data" is a const char **, representing an array of null-terminated UTF-8 + * strings copied from the "String[] strings" argument to + * invokeOemRilRequestStrings() + * + * "response" is a const char **, representing an array of null-terminated UTF-8 + * stings that will be returned via the caller's response message here: + * + * (String[])(((AsyncResult)response.obj).result) + * + * An error response here will result in + * (((AsyncResult)response.obj).result) == null and + * (((AsyncResult)response.obj).exception) being an instance of + * com.android.internal.telephony.gsm.CommandException + * + * Valid errors: + *  All + */ + +#define RIL_REQUEST_OEM_HOOK_STRINGS 60 + +/** + * RIL_REQUEST_SCREEN_STATE + * + * Indicates the current state of the screen.  When the screen is off, the + * RIL should notify the baseband to suppress certain notifications (eg, + * signal strength and changes in LAC/CID or BID/SID/NID/latitude/longitude) + * in an effort to conserve power.  These notifications should resume when the + * screen is on. + * + * "data" is int * + * ((int *)data)[0] is == 1 for "Screen On" + * ((int *)data)[0] is == 0 for "Screen Off" + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SCREEN_STATE 61 + + +/** + * RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION + * + * Enables/disables supplementary service related notifications + * from the network. + * + * Notifications are reported via RIL_UNSOL_SUPP_SVC_NOTIFICATION. + * + * "data" is int * + * ((int *)data)[0] is == 1 for notifications enabled + * ((int *)data)[0] is == 0 for notifications disabled + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_UNSOL_SUPP_SVC_NOTIFICATION. + */ +#define RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION 62 + +/** + * RIL_REQUEST_WRITE_SMS_TO_SIM + * + * Stores a SMS message to SIM memory. + * + * "data" is RIL_SMS_WriteArgs * + * + * "response" is int * + * ((const int *)response)[0] is the record index where the message is stored. + * + * Valid errors: + *  SUCCESS + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_WRITE_SMS_TO_SIM 63 + +/** + * RIL_REQUEST_DELETE_SMS_ON_SIM + * + * Deletes a SMS message from SIM memory. + * + * "data" is int  * + * ((int *)data)[0] is the record index of the message to delete. + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_DELETE_SMS_ON_SIM 64 + +/** + * RIL_REQUEST_SET_BAND_MODE + * + * Assign a specified band for RF configuration. + * + * "data" is int * + * ((int *)data)[0] is == 0 for "unspecified" (selected by baseband automatically) + * ((int *)data)[0] is == 1 for "EURO band" (GSM-900 / DCS-1800 / WCDMA-IMT-2000) + * ((int *)data)[0] is == 2 for "US band" (GSM-850 / PCS-1900 / WCDMA-850 / WCDMA-PCS-1900) + * ((int *)data)[0] is == 3 for "JPN band" (WCDMA-800 / WCDMA-IMT-2000) + * ((int *)data)[0] is == 4 for "AUS band" (GSM-900 / DCS-1800 / WCDMA-850 / WCDMA-IMT-2000) + * ((int *)data)[0] is == 5 for "AUS band 2" (GSM-900 / DCS-1800 / WCDMA-850) + * ((int *)data)[0] is == 6 for "Cellular (800-MHz Band)" + * ((int *)data)[0] is == 7 for "PCS (1900-MHz Band)" + * ((int *)data)[0] is == 8 for "Band Class 3 (JTACS Band)" + * ((int *)data)[0] is == 9 for "Band Class 4 (Korean PCS Band)" + * ((int *)data)[0] is == 10 for "Band Class 5 (450-MHz Band)" + * ((int *)data)[0] is == 11 for "Band Class 6 (2-GMHz IMT2000 Band)" + * ((int *)data)[0] is == 12 for "Band Class 7 (Upper 700-MHz Band)" + * ((int *)data)[0] is == 13 for "Band Class 8 (1800-MHz Band)" + * ((int *)data)[0] is == 14 for "Band Class 9 (900-MHz Band)" + * ((int *)data)[0] is == 15 for "Band Class 10 (Secondary 800-MHz Band)" + * ((int *)data)[0] is == 16 for "Band Class 11 (400-MHz European PAMR Band)" + * ((int *)data)[0] is == 17 for "Band Class 15 (AWS Band)" + * ((int *)data)[0] is == 18 for "Band Class 16 (US 2.5-GHz Band)" + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_BAND_MODE 65 + +/** + * RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE + * + * Query the list of band mode supported by RF. + * + * "data" is NULL + * + * "response" is int * + * "response" points to an array of int's, the int[0] is the size of array, reset is one for + * each available band mode. + * + *  0 for "unspecified" (selected by baseband automatically) + *  1 for "EURO band" (GSM-900 / DCS-1800 / WCDMA-IMT-2000) + *  2 for "US band" (GSM-850 / PCS-1900 / WCDMA-850 / WCDMA-PCS-1900) + *  3 for "JPN band" (WCDMA-800 / WCDMA-IMT-2000) + *  4 for "AUS band" (GSM-900 / DCS-1800 / WCDMA-850 / WCDMA-IMT-2000) + *  5 for "AUS band 2" (GSM-900 / DCS-1800 / WCDMA-850) + *  6 for "Cellular (800-MHz Band)" + *  7 for "PCS (1900-MHz Band)" + *  8 for "Band Class 3 (JTACS Band)" + *  9 for "Band Class 4 (Korean PCS Band)" + *  10 for "Band Class 5 (450-MHz Band)" + *  11 for "Band Class 6 (2-GMHz IMT2000 Band)" + *  12 for "Band Class 7 (Upper 700-MHz Band)" + *  13 for "Band Class 8 (1800-MHz Band)" + *  14 for "Band Class 9 (900-MHz Band)" + *  15 for "Band Class 10 (Secondary 800-MHz Band)" + *  16 for "Band Class 11 (400-MHz European PAMR Band)" + *  17 for "Band Class 15 (AWS Band)" + *  18 for "Band Class 16 (US 2.5-GHz Band)" + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_SET_BAND_MODE + */ +#define RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE 66 + +/** + * RIL_REQUEST_STK_GET_PROFILE + * + * Requests the profile of SIM tool kit. + * The profile indicates the SAT/USAT features supported by ME. + * The SAT/USAT features refer to 3GPP TS 11.14 and 3GPP TS 31.111 + * + * "data" is NULL + * + * "response" is a const char * containing SAT/USAT profile + * in hexadecimal format string starting with first byte of terminal profile + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_GET_PROFILE 67 + +/** + * RIL_REQUEST_STK_SET_PROFILE + * + * Download the STK terminal profile as part of SIM initialization + * procedure + * + * "data" is a const char * containing SAT/USAT profile + * in hexadecimal format string starting with first byte of terminal profile + * + * "response" is NULL + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_SET_PROFILE 68 + +/** + * RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND + * + * Requests to send a SAT/USAT envelope command to SIM. + * The SAT/USAT envelope command refers to 3GPP TS 11.14 and 3GPP TS 31.111 + * + * "data" is a const char * containing SAT/USAT command + * in hexadecimal format string starting with command tag + * + * "response" is a const char * containing SAT/USAT response + * in hexadecimal format string starting with first byte of response + * (May be NULL) + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND 69 + +/** + * RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE + * + * Requests to send a terminal response to SIM for a received + * proactive command + * + * "data" is a const char * containing SAT/USAT response + * in hexadecimal format string starting with first byte of response data + * + * "response" is NULL + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE 70 + +/** + * RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM + * + * When STK application gets RIL_UNSOL_STK_CALL_SETUP, the call actually has + * been initialized by ME already. (We could see the call has been in the 'call + * list') So, STK application needs to accept/reject the call according as user + * operations. + * + * "data" is int * + * ((int *)data)[0] is > 0 for "accept" the call setup + * ((int *)data)[0] is == 0 for "reject" the call setup + * + * "response" is NULL + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM 71 + +/** + * RIL_REQUEST_EXPLICIT_CALL_TRANSFER + * + * Connects the two calls and disconnects the subscriber from both calls. + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_EXPLICIT_CALL_TRANSFER 72 + +/** + * RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE + * + * Requests to set the preferred network type for searching and registering + * (CS/PS domain, RAT, and operation mode) + * + * "data" is int * which is RIL_PreferredNetworkType + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  MODE_NOT_SUPPORTED + */ +#define RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE 73 + +/** + * RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE + * + * Query the preferred network type (CS/PS domain, RAT, and operation mode) + * for searching and registering + * + * "data" is NULL + * + * "response" is int * + * ((int *)reponse)[0] is == RIL_PreferredNetworkType + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE + */ +#define RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE 74 + +/** + * RIL_REQUEST_NEIGHBORING_CELL_IDS + * + * Request neighboring cell id in GSM network + * + * "data" is NULL + * "response" must be a " const RIL_NeighboringCell** " + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_GET_NEIGHBORING_CELL_IDS 75 + +/** + * RIL_REQUEST_SET_LOCATION_UPDATES + * + * Enables/disables network state change notifications due to changes in + * LAC and/or CID (for GSM) or BID/SID/NID/latitude/longitude (for CDMA). + * Basically +CREG=2 vs. +CREG=1 (TS 27.007). + * + * Note:  The RIL implementation should default to "updates enabled" + * when the screen is on and "updates disabled" when the screen is off. + * + * "data" is int * + * ((int *)data)[0] is == 1 for updates enabled (+CREG=2) + * ((int *)data)[0] is == 0 for updates disabled (+CREG=1) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_REQUEST_SCREEN_STATE, RIL_UNSOL_RESPONSE_NETWORK_STATE_CHANGED + */ +#define RIL_REQUEST_SET_LOCATION_UPDATES 76 + +/** + * RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE + * + * Request to set the location where the CDMA subscription shall + * be retrieved + * + * "data" is int * + * ((int *)data)[0] is == RIL_CdmaSubscriptionSource + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + *  SIM_ABSENT + *  SUBSCRIPTION_NOT_AVAILABLE + * + * See also: RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE + */ +#define RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE 77 + +/** + * RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE + * + * Request to set the roaming preferences in CDMA + * + * "data" is int * + * ((int *)data)[0] is == 0 for Home Networks only, as defined in PRL + * ((int *)data)[0] is == 1 for Roaming on Affiliated networks, as defined in PRL + * ((int *)data)[0] is == 2 for Roaming on Any Network, as defined in the PRL + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE 78 + +/** + * RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE + * + * Request the actual setting of the roaming preferences in CDMA in the modem + * + * "data" is NULL + * + * "response" is int * + * ((int *)response)[0] is == 0 for Home Networks only, as defined in PRL + * ((int *)response)[0] is == 1 for Roaming on Affiliated networks, as defined in PRL + * ((int *)response)[0] is == 2 for Roaming on Any Network, as defined in the PRL + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE 79 + +/** + * RIL_REQUEST_SET_TTY_MODE + * + * Request to set the TTY mode + * + * "data" is int * + * ((int *)data)[0] is == 0 for TTY off + * ((int *)data)[0] is == 1 for TTY Full + * ((int *)data)[0] is == 2 for TTY HCO (hearing carryover) + * ((int *)data)[0] is == 3 for TTY VCO (voice carryover) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_TTY_MODE 80 + +/** + * RIL_REQUEST_QUERY_TTY_MODE + * + * Request the setting of TTY mode + * + * "data" is NULL + * + * "response" is int * + * ((int *)response)[0] is == 0 for TTY off + * ((int *)response)[0] is == 1 for TTY Full + * ((int *)response)[0] is == 2 for TTY HCO (hearing carryover) + * ((int *)response)[0] is == 3 for TTY VCO (voice carryover) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_QUERY_TTY_MODE 81 + +/** + * RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE + * + * Request to set the preferred voice privacy mode used in voice + * scrambling + * + * "data" is int * + * ((int *)data)[0] is == 0 for Standard Privacy Mode (Public Long Code Mask) + * ((int *)data)[0] is == 1 for Enhanced Privacy Mode (Private Long Code Mask) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE 82 + +/** + * RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE + * + * Request the setting of preferred voice privacy mode + * + * "data" is NULL + * + * "response" is int * + * ((int *)response)[0] is == 0 for Standard Privacy Mode (Public Long Code Mask) + * ((int *)response)[0] is == 1 for Enhanced Privacy Mode (Private Long Code Mask) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE 83 + +/** + * RIL_REQUEST_CDMA_FLASH + * + * Send FLASH + * + * "data" is const char * + * ((const char *)data)[0] is a FLASH string + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_FLASH 84 + +/** + * RIL_REQUEST_CDMA_BURST_DTMF + * + * Send DTMF string + * + * "data" is const char ** + * ((const char **)data)[0] is a DTMF string + * ((const char **)data)[1] is the DTMF ON length in milliseconds, or 0 to use + *                          default + * ((const char **)data)[2] is the DTMF OFF length in milliseconds, or 0 to use + *                          default + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_BURST_DTMF 85 + +/** + * RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY + * + * Takes a 26 digit string (20 digit AKEY + 6 digit checksum). + * If the checksum is valid the 20 digit AKEY is written to NV, + * replacing the existing AKEY no matter what it was before. + * + * "data" is const char * + * ((const char *)data)[0] is a 26 digit string (ASCII digits '0'-'9') + *                         where the last 6 digits are a checksum of the + *                         first 20, as specified in TR45.AHAG + *                         "Common Cryptographic Algorithms, Revision D.1 + *                         Section 2.2" + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY 86 + +/** + * RIL_REQUEST_CDMA_SEND_SMS + * + * Send a CDMA SMS message + * + * "data" is const RIL_CDMA_SMS_Message * + * + * "response" is a const RIL_SMS_Response * + * + * Based on the return error, caller decides to resend if sending sms + * fails. The CDMA error class is derived as follows, + * SUCCESS is error class 0 (no error) + * SMS_SEND_FAIL_RETRY is error class 2 (temporary failure) + * and GENERIC_FAILURE is error class 3 (permanent and no retry) + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SMS_SEND_FAIL_RETRY + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_SEND_SMS 87 + +/** + * RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE + * + * Acknowledge the success or failure in the receipt of SMS + * previously indicated via RIL_UNSOL_RESPONSE_CDMA_NEW_SMS + * + * "data" is const RIL_CDMA_SMS_Ack * + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE 88 + +/** + * RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG + * + * Request the setting of GSM/WCDMA Cell Broadcast SMS config. + * + * "data" is NULL + * + * "response" is a const RIL_GSM_BroadcastSmsConfigInfo ** + * "responselen" is count * sizeof (RIL_GSM_BroadcastSmsConfigInfo *) + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG 89 + +/** + * RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG + * + * Set GSM/WCDMA Cell Broadcast SMS config + * + * "data" is a const RIL_GSM_BroadcastSmsConfigInfo ** + * "datalen" is count * sizeof(RIL_GSM_BroadcastSmsConfigInfo *) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG 90 + +/** + * RIL_REQUEST_GSM_SMS_BROADCAST_ACTIVATION + * +* Enable or disable the reception of GSM/WCDMA Cell Broadcast SMS + * + * "data" is const int * + * (const int *)data[0] indicates to activate or turn off the + * reception of GSM/WCDMA Cell Broadcast SMS, 0-1, + *                       0 - Activate, 1 - Turn off + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_GSM_SMS_BROADCAST_ACTIVATION 91 + +/** + * RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG + * + * Request the setting of CDMA Broadcast SMS config + * + * "data" is NULL + * + * "response" is a const RIL_CDMA_BroadcastSmsConfigInfo ** + * "responselen" is count * sizeof (RIL_CDMA_BroadcastSmsConfigInfo *) + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG 92 + +/** + * RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG + * + * Set CDMA Broadcast SMS config + * + * "data" is an const RIL_CDMA_BroadcastSmsConfigInfo ** + * "datalen" is count * sizeof(const RIL_CDMA_BroadcastSmsConfigInfo *) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG 93 + +/** + * RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION + * + * Enable or disable the reception of CDMA Broadcast SMS + * + * "data" is const int * + * (const int *)data[0] indicates to activate or turn off the + * reception of CDMA Broadcast SMS, 0-1, + *                       0 - Activate, 1 - Turn off + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION 94 + +/** + * RIL_REQUEST_CDMA_SUBSCRIPTION + * + * Request the device MDN / H_SID / H_NID. + * + * The request is only allowed when CDMA subscription is available.  When CDMA + * subscription is changed, application layer should re-issue the request to + * update the subscription information. + * + * If a NULL value is returned for any of the device id, it means that error + * accessing the device. + * + * "response" is const char ** + * ((const char **)response)[0] is MDN if CDMA subscription is available + * ((const char **)response)[1] is a comma separated list of H_SID (Home SID) if + *                              CDMA subscription is available, in decimal format + * ((const char **)response)[2] is a comma separated list of H_NID (Home NID) if + *                              CDMA subscription is available, in decimal format + * ((const char **)response)[3] is MIN (10 digits, MIN2+MIN1) if CDMA subscription is available + * ((const char **)response)[4] is PRL version if CDMA subscription is available + * + * Valid errors: + *  SUCCESS + *  RIL_E_SUBSCRIPTION_NOT_AVAILABLE + */ + +#define RIL_REQUEST_CDMA_SUBSCRIPTION 95 + +/** + * RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM + * + * Stores a CDMA SMS message to RUIM memory. + * + * "data" is RIL_CDMA_SMS_WriteArgs * + * + * "response" is int * + * ((const int *)response)[0] is the record index where the message is stored. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM 96 + +/** + * RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM + * + * Deletes a CDMA SMS message from RUIM memory. + * + * "data" is int  * + * ((int *)data)[0] is the record index of the message to delete. + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM 97 + +/** + * RIL_REQUEST_DEVICE_IDENTITY + * + * Request the device ESN / MEID / IMEI / IMEISV. + * + * The request is always allowed and contains GSM and CDMA device identity; + * it substitutes the deprecated requests RIL_REQUEST_GET_IMEI and + * RIL_REQUEST_GET_IMEISV. + * + * If a NULL value is returned for any of the device id, it means that error + * accessing the device. + * + * When CDMA subscription is changed the ESN/MEID may change.  The application + * layer should re-issue the request to update the device identity in this case. + * + * "response" is const char ** + * ((const char **)response)[0] is IMEI if GSM subscription is available + * ((const char **)response)[1] is IMEISV if GSM subscription is available + * ((const char **)response)[2] is ESN if CDMA subscription is available + * ((const char **)response)[3] is MEID if CDMA subscription is available + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_DEVICE_IDENTITY 98 + +/** + * RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE + * + * Request the radio's system selection module to exit emergency + * callback mode.  RIL will not respond with SUCCESS until the modem has + * completely exited from Emergency Callback Mode. + * + * "data" is NULL + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE 99 + +/** + * RIL_REQUEST_GET_SMSC_ADDRESS + * + * Queries the default Short Message Service Center address on the device. + * + * "data" is NULL + * + * "response" is const char * containing the SMSC address. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_GET_SMSC_ADDRESS 100 + +/** + * RIL_REQUEST_SET_SMSC_ADDRESS + * + * Sets the default Short Message Service Center address on the device. + * + * "data" is const char * containing the SMSC address. + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_SET_SMSC_ADDRESS 101 + +/** + * RIL_REQUEST_REPORT_SMS_MEMORY_STATUS + * + * Indicates whether there is storage available for new SMS messages. + * + * "data" is int * + * ((int *)data)[0] is 1 if memory is available for storing new messages + *                  is 0 if memory capacity is exceeded + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_REPORT_SMS_MEMORY_STATUS 102 + +/** + * RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING + * + * Indicates that the StkSerivce is running and is + * ready to receive RIL_UNSOL_STK_XXXXX commands. + * + * "data" is NULL + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING 103 + +/** + * RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE + * + * Request to query the location where the CDMA subscription shall + * be retrieved + * + * "data" is NULL + * + * "response" is int * + * ((int *)data)[0] is == RIL_CdmaSubscriptionSource + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + *  SUBSCRIPTION_NOT_AVAILABLE + * + * See also: RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE + */ +#define RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE 104 + +/** + * RIL_REQUEST_ISIM_AUTHENTICATION + * + * Request the ISIM application on the UICC to perform AKA + * challenge/response algorithm for IMS authentication + * + * "data" is a const char * containing the challenge string in Base64 format + * "response" is a const char * containing the response in Base64 format + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_ISIM_AUTHENTICATION 105 + +/** + * RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU + * + * Acknowledge successful or failed receipt of SMS previously indicated + * via RIL_UNSOL_RESPONSE_NEW_SMS, including acknowledgement TPDU to send + * as the RP-User-Data element of the RP-ACK or RP-ERROR PDU. + * + * "data" is const char ** + * ((const char **)data)[0] is "1" on successful receipt (send RP-ACK) + *                          is "0" on failed receipt (send RP-ERROR) + * ((const char **)data)[1] is the acknowledgement TPDU in hexadecimal format + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU 106 + +/** + * RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS + * + * Requests to send a SAT/USAT envelope command to SIM. + * The SAT/USAT envelope command refers to 3GPP TS 11.14 and 3GPP TS 31.111. + * + * This request has one difference from RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND: + * the SW1 and SW2 status bytes from the UICC response are returned along with + * the response data, using the same structure as RIL_REQUEST_SIM_IO. + * + * The RIL implementation shall perform the normal processing of a '91XX' + * response in SW1/SW2 to retrieve the pending proactive command and send it + * as an unsolicited response, as RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND does. + * + * "data" is a const char * containing the SAT/USAT command + * in hexadecimal format starting with command tag + * + * "response" is a const RIL_SIM_IO_Response * + * + * Valid errors: + *  RIL_E_SUCCESS + *  RIL_E_RADIO_NOT_AVAILABLE (radio resetting) + *  RIL_E_GENERIC_FAILURE + */ +#define RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS 107 + +/** + * RIL_REQUEST_VOICE_RADIO_TECH + * + * Query the radio technology type (3GPP/3GPP2) used for voice. Query is valid only + * when radio state is RADIO_STATE_ON + * + * "data" is NULL + * "response" is int * + * ((int *) response)[0] is of type const RIL_RadioTechnology + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_VOICE_RADIO_TECH 108 + +/** + * RIL_REQUEST_GET_CELL_INFO_LIST + * + * Request all of the current cell information known to the radio. The radio + * must a list of all current cells, including the neighboring cells. If for a particular + * cell information isn't known then the appropriate unknown value will be returned. + * This does not cause or change the rate of RIL_UNSOL_CELL_INFO_LIST. + * + * "data" is NULL + * + * "response" is an array of  RIL_CellInfo. + */ +#define RIL_REQUEST_GET_CELL_INFO_LIST 109 + +/** + * RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE + * + * Sets the minimum time between when RIL_UNSOL_CELL_INFO_LIST should be invoked. + * A value of 0, means invoke RIL_UNSOL_CELL_INFO_LIST when any of the reported + * information changes. Setting the value to INT_MAX(0x7fffffff) means never issue + * a RIL_UNSOL_CELL_INFO_LIST. + * + * "data" is int * + * ((int *)data)[0] is minimum time in milliseconds + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE 110 + +/** + * RIL_REQUEST_SET_INITIAL_ATTACH_APN + * + * Set an apn to initial attach network + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  SUBSCRIPTION_NOT_AVAILABLE + */ +#define RIL_REQUEST_SET_INITIAL_ATTACH_APN 111 + +/** + * RIL_REQUEST_IMS_REGISTRATION_STATE + * + * Request current IMS registration state + * + * "data" is NULL + * + * "response" is int * + * ((int *)response)[0] is registration state: + *              0 - Not registered + *              1 - Registered + * + * If ((int*)response)[0] is = 1, then ((int *) response)[1] + * must follow with IMS SMS format: + * + * ((int *) response)[1] is of type RIL_RadioTechnologyFamily + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_IMS_REGISTRATION_STATE 112 + +/** + * RIL_REQUEST_IMS_SEND_SMS + * + * Send a SMS message over IMS + * + * "data" is const RIL_IMS_SMS_Message * + * + * "response" is a const RIL_SMS_Response * + * + * Based on the return error, caller decides to resend if sending sms + * fails. SMS_SEND_FAIL_RETRY means retry, and other errors means no retry. + * In case of retry, data is encoded based on Voice Technology available. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  SMS_SEND_FAIL_RETRY + *  FDN_CHECK_FAILURE + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_IMS_SEND_SMS 113 + +/** + * RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC + * + * Request APDU exchange on the basic channel. This command reflects TS 27.007 + * "generic SIM access" operation (+CSIM). The modem must ensure proper function + * of GSM/CDMA, and filter commands appropriately. It should filter + * channel management and SELECT by DF name commands. + * + * "data" is a const RIL_SIM_APDU * + * "sessionid" field should be ignored. + * + * "response" is a const RIL_SIM_IO_Response * + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC 114 + +/** + * RIL_REQUEST_SIM_OPEN_CHANNEL + * + * Open a new logical channel and select the given application. This command + * reflects TS 27.007 "open logical channel" operation (+CCHO). + * + * "data" is const char * and set to AID value, See ETSI 102.221 and 101.220. + * + * "response" is int * + * ((int *)data)[0] contains the session id of the logical channel. + * ((int *)data)[1] onwards may optionally contain the select response for the + *     open channel command with one byte per integer. + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + *  MISSING_RESOURCE + *  NO_SUCH_ELEMENT + */ +#define RIL_REQUEST_SIM_OPEN_CHANNEL 115 + +/** + * RIL_REQUEST_SIM_CLOSE_CHANNEL + * + * Close a previously opened logical channel. This command reflects TS 27.007 + * "close logical channel" operation (+CCHC). + * + * "data" is int * + * ((int *)data)[0] is the session id of logical the channel to close. + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SIM_CLOSE_CHANNEL 116 + +/** + * RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL + * + * Exchange APDUs with a UICC over a previously opened logical channel. This + * command reflects TS 27.007 "generic logical channel access" operation + * (+CGLA). The modem should filter channel management and SELECT by DF name + * commands. + * + * "data" is a const RIL_SIM_APDU* + * + * "response" is a const RIL_SIM_IO_Response * + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL 117 + +/** + * RIL_REQUEST_NV_READ_ITEM + * + * Read one of the radio NV items defined in RadioNVItems.java / ril_nv_items.h. + * This is used for device configuration by some CDMA operators. + * + * "data" is a const RIL_NV_ReadItem * + * + * "response" is const char * containing the contents of the NV item + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_NV_READ_ITEM 118 + +/** + * RIL_REQUEST_NV_WRITE_ITEM + * + * Write one of the radio NV items defined in RadioNVItems.java / ril_nv_items.h. + * This is used for device configuration by some CDMA operators. + * + * "data" is a const RIL_NV_WriteItem * + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_NV_WRITE_ITEM 119 + +/** + * RIL_REQUEST_NV_WRITE_CDMA_PRL + * + * Update the CDMA Preferred Roaming List (PRL) in the radio NV storage. + * This is used for device configuration by some CDMA operators. + * + * "data" is a const char * containing the PRL as a byte array + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_NV_WRITE_CDMA_PRL 120 + +/** + * RIL_REQUEST_NV_RESET_CONFIG + * + * Reset the radio NV configuration to the factory state. + * This is used for device configuration by some CDMA operators. + * + * "data" is int * + * ((int *)data)[0] is 1 to reload all NV items + * ((int *)data)[0] is 2 for erase NV reset (SCRTN) + * ((int *)data)[0] is 3 for factory reset (RTN) + * + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_NV_RESET_CONFIG 121 + + /** RIL_REQUEST_SET_UICC_SUBSCRIPTION + * FIXME This API needs to have more documentation. + * + * Selection/de-selection of a subscription from a SIM card + * "data" is const  RIL_SelectUiccSub* + + * + * "response" is NULL + * + *  Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  SUBSCRIPTION_NOT_SUPPORTED + * + */ +#define RIL_REQUEST_SET_UICC_SUBSCRIPTION  122 + +/** + *  RIL_REQUEST_ALLOW_DATA + * + *  Tells the modem whether data calls are allowed or not + * + * "data" is int * + * FIXME slotId and aid will be added. + * ((int *)data)[0] is == 0 to allow data calls + * ((int *)data)[0] is == 1 to disallow data calls + * + * "response" is NULL + * + *  Valid errors: + * + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + * + */ +#define RIL_REQUEST_ALLOW_DATA  123 + +/** + * RIL_REQUEST_GET_HARDWARE_CONFIG + * + * Request all of the current hardware (modem and sim) associated + * with the RIL. + * + * "data" is NULL + * + * "response" is an array of  RIL_HardwareConfig. + */ +#define RIL_REQUEST_GET_HARDWARE_CONFIG 124 + +/** + * RIL_REQUEST_SIM_AUTHENTICATION + * + * Returns the response of SIM Authentication through RIL to a + * challenge request. + * + * "data" Base64 encoded string containing challenge: + *      int   authContext;          P2 value of authentication command, see P2 parameter in + *                                  3GPP TS 31.102 7.1.2 + *      char *authData;             the challenge string in Base64 format, see 3GPP + *                                  TS 31.102 7.1.2 + *      char *aid;                  AID value, See ETSI 102.221 8.1 and 101.220 4, + *                                  NULL if no value + * + * "response" Base64 encoded strings containing response: + *      int   sw1;                  Status bytes per 3GPP TS 31.102 section 7.3 + *      int   sw2; + *      char *simResponse;          Response in Base64 format, see 3GPP TS 31.102 7.1.2 + */ +#define RIL_REQUEST_SIM_AUTHENTICATION 125 + +/** + * RIL_REQUEST_GET_DC_RT_INFO + * + * The request is DEPRECATED, use RIL_REQUEST_GET_ACTIVITY_INFO + * Requests the Data Connection Real Time Info + * + * "data" is NULL + * + * "response" is the most recent RIL_DcRtInfo + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + * + * See also: RIL_UNSOL_DC_RT_INFO_CHANGED + */ +#define RIL_REQUEST_GET_DC_RT_INFO 126 + +/** + * RIL_REQUEST_SET_DC_RT_INFO_RATE + * + * The request is DEPRECATED + * This is the minimum number of milliseconds between successive + * RIL_UNSOL_DC_RT_INFO_CHANGED messages and defines the highest rate + * at which RIL_UNSOL_DC_RT_INFO_CHANGED's will be sent. A value of + * 0 means send as fast as possible. + * + * "data" The number of milliseconds as an int + * + * "response" is null + * + * Valid errors: + *  SUCCESS must not fail + */ +#define RIL_REQUEST_SET_DC_RT_INFO_RATE 127 + +/** + * RIL_REQUEST_SET_DATA_PROFILE + * + * Set data profile in modem + * Modem should erase existed profiles from framework, and apply new profiles + * "data" is an const RIL_DataProfileInfo ** + * "datalen" is count * sizeof(const RIL_DataProfileInfo *) + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE (radio resetting) + *  GENERIC_FAILURE + *  SUBSCRIPTION_NOT_AVAILABLE + */ +#define RIL_REQUEST_SET_DATA_PROFILE 128 + +/** + * RIL_REQUEST_SHUTDOWN + * + * Device is shutting down. All further commands are ignored + * and RADIO_NOT_AVAILABLE must be returned. + * + * "data" is null + * "response" is NULL + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SHUTDOWN 129 + +/** + * RIL_REQUEST_GET_RADIO_CAPABILITY + * + * Used to get phone radio capablility. + * + * "data" is the RIL_RadioCapability structure + * + * Valid errors: + *  SUCCESS + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_GET_RADIO_CAPABILITY 130 + +/** + * RIL_REQUEST_SET_RADIO_CAPABILITY + * + * Used to set the phones radio capability. Be VERY careful + * using this request as it may cause some vendor modems to reset. Because + * of the possible modem reset any RIL commands after this one may not be + * processed. + * + * "data" is the RIL_RadioCapability structure + * + * "response" is the RIL_RadioCapability structure, used to feedback return status + * + * Valid errors: + *  SUCCESS means a RIL_UNSOL_RADIO_CAPABILITY will be sent within 30 seconds. + *  RADIO_NOT_AVAILABLE + *  GENERIC_FAILURE + */ +#define RIL_REQUEST_SET_RADIO_CAPABILITY 131 + + /** + * RIL_REQUEST_START_LCE + * + * Start Link Capacity Estimate (LCE) service if supported by the radio. + * + * "data" is const int * + * ((const int*)data)[0] specifies the desired reporting interval (ms). + * ((const int*)data)[1] specifies the LCE service mode. 1: PULL; 0: PUSH. + * + * "response" is the RIL_LceStatusInfo. + * + * Valid errors: + * SUCCESS + * RADIO_NOT_AVAILABLE + * LCE_NOT_SUPPORTED + */ +#define RIL_REQUEST_START_LCE 132 + +/** + * RIL_REQUEST_STOP_LCE + * + * Stop Link Capacity Estimate (LCE) service, the STOP operation should be + * idempotent for the radio modem. + * + * "response" is the RIL_LceStatusInfo. + * + * Valid errors: + * SUCCESS + * RADIO_NOT_AVAILABLE + * LCE_NOT_SUPPORTED + */ +#define RIL_REQUEST_STOP_LCE 133 + +/** + * RIL_REQUEST_PULL_LCEDATA + * + * Pull LCE service for capacity information. + * + * "response" is the RIL_LceDataInfo. + * + * Valid errors: + * SUCCESS + * RADIO_NOT_AVAILABLE + * LCE_NOT_SUPPORTED + */ +#define RIL_REQUEST_PULL_LCEDATA 134 + /** + * RIL_REQUEST_GET_ACTIVITY_INFO + * + * Get modem activity statisitics info. + * + * There can be multiple RIL_REQUEST_GET_ACTIVITY_INFO calls to modem. + * Once the response for the request is sent modem will clear + * current statistics information. + * + * "data" is null + * "response" is const RIL_ActivityStatsInfo * + * + * Valid errors: + * + * SUCCESS + * RADIO_NOT_AVAILABLE (radio resetting) + * GENERIC_FAILURE + */ +#define RIL_REQUEST_GET_ACTIVITY_INFO 135 + + +/* SAMSUNG REQUESTS */ +#undef RIL_REQUEST_SIM_OPEN_CHANNEL +#undef RIL_REQUEST_SIM_CLOSE_CHANNEL + +#define RIL_REQUEST_GET_CELL_BROADCAST_CONFIG 10002 + +#define RIL_REQUEST_SEND_ENCODED_USSD 10005 +#define RIL_REQUEST_SET_PDA_MEMORY_STATUS 10006 +#define RIL_REQUEST_GET_PHONEBOOK_STORAGE_INFO 10007 +#define RIL_REQUEST_GET_PHONEBOOK_ENTRY 10008 +#define RIL_REQUEST_ACCESS_PHONEBOOK_ENTRY 10009 +#define RIL_REQUEST_DIAL_VIDEO_CALL 10010 +#define RIL_REQUEST_CALL_DEFLECTION 10011 +#define RIL_REQUEST_READ_SMS_FROM_SIM 10012 +#define RIL_REQUEST_USIM_PB_CAPA 10013 +#define RIL_REQUEST_LOCK_INFO 10014 + +#define RIL_REQUEST_DIAL_EMERGENCY 10016 +#define RIL_REQUEST_GET_STOREAD_MSG_COUNT 10017 +#define RIL_REQUEST_STK_SIM_INIT_EVENT 10018 +#define RIL_REQUEST_GET_LINE_ID 10019 +#define RIL_REQUEST_SET_LINE_ID 10020 +#define RIL_REQUEST_GET_SERIAL_NUMBER 10021 +#define RIL_REQUEST_GET_MANUFACTURE_DATE_NUMBER 10022 +#define RIL_REQUEST_GET_BARCODE_NUMBER 10023 +#define RIL_REQUEST_UICC_GBA_AUTHENTICATE_BOOTSTRAP 10024 +#define RIL_REQUEST_UICC_GBA_AUTHENTICATE_NAF 10025 +#define RIL_REQUEST_SIM_TRANSMIT_BASIC 10026 +#define RIL_REQUEST_SIM_OPEN_CHANNEL 10027 +#define RIL_REQUEST_SIM_CLOSE_CHANNEL 10028 +#define RIL_REQUEST_SIM_TRANSMIT_CHANNEL 10029 +#define RIL_REQUEST_SIM_AUTH 10030 +#define RIL_REQUEST_PS_ATTACH 10031 +#define RIL_REQUEST_PS_DETACH 10032 +#define RIL_REQUEST_ACTIVATE_DATA_CALL 10033 +#define RIL_REQUEST_CHANGE_SIM_PERSO 10034 +#define RIL_REQUEST_ENTER_SIM_PERSO 10035 +#define RIL_REQUEST_GET_TIME_INFO 10036 +#define RIL_REQUEST_OMADM_SETUP_SESSION 10037 +#define RIL_REQUEST_OMADM_SERVER_START_SESSION 10038 +#define RIL_REQUEST_OMADM_CLIENT_START_SESSION 10039 +#define RIL_REQUEST_OMADM_SEND_DATA 10040 +#define RIL_REQUEST_CDMA_GET_DATAPROFILE 10041 +#define RIL_REQUEST_CDMA_SET_DATAPROFILE 10042 +#define RIL_REQUEST_CDMA_GET_SYSTEMPROPERTIES 10043 +#define RIL_REQUEST_CDMA_SET_SYSTEMPROPERTIES 10044 +#define RIL_REQUEST_SEND_SMS_COUNT 10045 +#define RIL_REQUEST_SEND_SMS_MSG 10046 +#define RIL_REQUEST_SEND_SMS_MSG_READ_STATUS 10047 +#define RIL_REQUEST_MODEM_HANGUP 10048 +#define RIL_REQUEST_SET_SIM_POWER 10049 +#define RIL_REQUEST_SET_PREFERRED_NETWORK_LIST 10050 +#define RIL_REQUEST_GET_PREFERRED_NETWORK_LIST 10051 +#define RIL_REQUEST_HANGUP_VT 10052 + + +/***********************************************************************/ + + +#define RIL_UNSOL_RESPONSE_BASE 1000 + +/** + * RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED + * + * Indicate when value of RIL_RadioState has changed. + * + * Callee will invoke RIL_RadioStateRequest method on main thread + * + * "data" is NULL + */ + +#define RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED 1000 + + +/** + * RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED + * + * Indicate when call state has changed + * + * Callee will invoke RIL_REQUEST_GET_CURRENT_CALLS on main thread + * + * "data" is NULL + * + * Response should be invoked on, for example, + * "RING", "BUSY", "NO CARRIER", and also call state + * transitions (DIALING->ALERTING ALERTING->ACTIVE) + * + * Redundent or extraneous invocations are tolerated + */ +#define RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED 1001 + + +/** + * RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED + * + * Called when the voice network state changed + * + * Callee will invoke the following requests on main thread: + * + * RIL_REQUEST_VOICE_REGISTRATION_STATE + * RIL_REQUEST_OPERATOR + * + * "data" is NULL + * + * FIXME should this happen when SIM records are loaded? (eg, for + * EONS) + */ +#define RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED 1002 + +/** + * RIL_UNSOL_RESPONSE_NEW_SMS + * + * Called when new SMS is received. + * + * "data" is const char * + * This is a pointer to a string containing the PDU of an SMS-DELIVER + * as an ascii string of hex digits. The PDU starts with the SMSC address + * per TS 27.005 (+CMT:) + * + * Callee will subsequently confirm the receipt of thei SMS with a + * RIL_REQUEST_SMS_ACKNOWLEDGE + * + * No new RIL_UNSOL_RESPONSE_NEW_SMS + * or RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT messages should be sent until a + * RIL_REQUEST_SMS_ACKNOWLEDGE has been received + */ + +#define RIL_UNSOL_RESPONSE_NEW_SMS 1003 + +/** + * RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT + * + * Called when new SMS Status Report is received. + * + * "data" is const char * + * This is a pointer to a string containing the PDU of an SMS-STATUS-REPORT + * as an ascii string of hex digits. The PDU starts with the SMSC address + * per TS 27.005 (+CDS:). + * + * Callee will subsequently confirm the receipt of the SMS with a + * RIL_REQUEST_SMS_ACKNOWLEDGE + * + * No new RIL_UNSOL_RESPONSE_NEW_SMS + * or RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT messages should be sent until a + * RIL_REQUEST_SMS_ACKNOWLEDGE has been received + */ + +#define RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT 1004 + +/** + * RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM + * + * Called when new SMS has been stored on SIM card + * + * "data" is const int * + * ((const int *)data)[0] contains the slot index on the SIM that contains + * the new message + */ + +#define RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM 1005 + +/** + * RIL_UNSOL_ON_USSD + * + * Called when a new USSD message is received. + * + * "data" is const char ** + * ((const char **)data)[0] points to a type code, which is + *  one of these string values: + *      "0"   USSD-Notify -- text in ((const char **)data)[1] + *      "1"   USSD-Request -- text in ((const char **)data)[1] + *      "2"   Session terminated by network + *      "3"   other local client (eg, SIM Toolkit) has responded + *      "4"   Operation not supported + *      "5"   Network timeout + * + * The USSD session is assumed to persist if the type code is "1", otherwise + * the current session (if any) is assumed to have terminated. + * + * ((const char **)data)[1] points to a message string if applicable, which + * should always be in UTF-8. + */ +#define RIL_UNSOL_ON_USSD 1006 +/* Previously #define RIL_UNSOL_ON_USSD_NOTIFY 1006   */ + +/** + * RIL_UNSOL_ON_USSD_REQUEST + * + * Obsolete. Send via RIL_UNSOL_ON_USSD + */ +#define RIL_UNSOL_ON_USSD_REQUEST 1007 + +/** + * RIL_UNSOL_NITZ_TIME_RECEIVED + * + * Called when radio has received a NITZ time message + * + * "data" is const char * pointing to NITZ time string + * in the form "yy/mm/dd,hh:mm:ss(+/-)tz,dt" + */ +#define RIL_UNSOL_NITZ_TIME_RECEIVED  1008 + +/** + * RIL_UNSOL_SIGNAL_STRENGTH + * + * Radio may report signal strength rather han have it polled. + * + * "data" is a const RIL_SignalStrength * + */ +#define RIL_UNSOL_SIGNAL_STRENGTH  1009 + + +/** + * RIL_UNSOL_DATA_CALL_LIST_CHANGED + * + * "data" is an array of RIL_Data_Call_Response_v6 identical to that + * returned by RIL_REQUEST_DATA_CALL_LIST. It is the complete list + * of current data contexts including new contexts that have been + * activated. A data call is only removed from this list when the + * framework sends a RIL_REQUEST_DEACTIVATE_DATA_CALL or the radio + * is powered off/on. + * + * See also: RIL_REQUEST_DATA_CALL_LIST + */ + +#define RIL_UNSOL_DATA_CALL_LIST_CHANGED 1010 + +/** + * RIL_UNSOL_SUPP_SVC_NOTIFICATION + * + * Reports supplementary service related notification from the network. + * + * "data" is a const RIL_SuppSvcNotification * + * + */ + +#define RIL_UNSOL_SUPP_SVC_NOTIFICATION 1011 + +/** + * RIL_UNSOL_STK_SESSION_END + * + * Indicate when STK session is terminated by SIM. + * + * "data" is NULL + */ +#define RIL_UNSOL_STK_SESSION_END 1012 + +/** + * RIL_UNSOL_STK_PROACTIVE_COMMAND + * + * Indicate when SIM issue a STK proactive command to applications + * + * "data" is a const char * containing SAT/USAT proactive command + * in hexadecimal format string starting with command tag + * + */ +#define RIL_UNSOL_STK_PROACTIVE_COMMAND 1013 + +/** + * RIL_UNSOL_STK_EVENT_NOTIFY + * + * Indicate when SIM notifies applcations some event happens. + * Generally, application does not need to have any feedback to + * SIM but shall be able to indicate appropriate messages to users. + * + * "data" is a const char * containing SAT/USAT commands or responses + * sent by ME to SIM or commands handled by ME, in hexadecimal format string + * starting with first byte of response data or command tag + * + */ +#define RIL_UNSOL_STK_EVENT_NOTIFY 1014 + +/** + * RIL_UNSOL_STK_CALL_SETUP + * + * Indicate when SIM wants application to setup a voice call. + * + * "data" is const int * + * ((const int *)data)[0] contains timeout value (in milliseconds) + */ +#define RIL_UNSOL_STK_CALL_SETUP 1015 + +/** + * RIL_UNSOL_SIM_SMS_STORAGE_FULL + * + * Indicates that SMS storage on the SIM is full.  Sent when the network + * attempts to deliver a new SMS message.  Messages cannot be saved on the + * SIM until space is freed.  In particular, incoming Class 2 messages + * cannot be stored. + * + * "data" is null + * + */ +#define RIL_UNSOL_SIM_SMS_STORAGE_FULL 1016 + +/** + * RIL_UNSOL_SIM_REFRESH + * + * Indicates that file(s) on the SIM have been updated, or the SIM + * has been reinitialized. + * + * In the case where RIL is version 6 or older: + * "data" is an int * + * ((int *)data)[0] is a RIL_SimRefreshResult. + * ((int *)data)[1] is the EFID of the updated file if the result is + * SIM_FILE_UPDATE or NULL for any other result. + * + * In the case where RIL is version 7: + * "data" is a RIL_SimRefreshResponse_v7 * + * + * Note: If the SIM state changes as a result of the SIM refresh (eg, + * SIM_READY -> SIM_LOCKED_OR_ABSENT), RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED + * should be sent. + */ +#define RIL_UNSOL_SIM_REFRESH 1017 + +/** + * RIL_UNSOL_CALL_RING + * + * Ring indication for an incoming call (eg, RING or CRING event). + * There must be at least one RIL_UNSOL_CALL_RING at the beginning + * of a call and sending multiple is optional. If the system property + * ro.telephony.call_ring.multiple is false then the upper layers + * will generate the multiple events internally. Otherwise the vendor + * ril must generate multiple RIL_UNSOL_CALL_RING if + * ro.telephony.call_ring.multiple is true or if it is absent. + * + * The rate of these events is controlled by ro.telephony.call_ring.delay + * and has a default value of 3000 (3 seconds) if absent. + * + * "data" is null for GSM + * "data" is const RIL_CDMA_SignalInfoRecord * if CDMA + */ +#define RIL_UNSOL_CALL_RING 1018 + +/** + * RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED + * + * Indicates that SIM state changes. + * + * Callee will invoke RIL_REQUEST_GET_SIM_STATUS on main thread + + * "data" is null + */ +#define RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED 1019 + +/** + * RIL_UNSOL_RESPONSE_CDMA_NEW_SMS + * + * Called when new CDMA SMS is received + * + * "data" is const RIL_CDMA_SMS_Message * + * + * Callee will subsequently confirm the receipt of the SMS with + * a RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE + * + * No new RIL_UNSOL_RESPONSE_CDMA_NEW_SMS should be sent until + * RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE has been received + * + */ +#define RIL_UNSOL_RESPONSE_CDMA_NEW_SMS 1020 + +/** + * RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS + * + * Called when new Broadcast SMS is received + * + * "data" can be one of the following: + * If received from GSM network, "data" is const char of 88 bytes + * which indicates each page of a CBS Message sent to the MS by the + * BTS as coded in 3GPP 23.041 Section 9.4.1.2. + * If received from UMTS network, "data" is const char of 90 up to 1252 + * bytes which contain between 1 and 15 CBS Message pages sent as one + * packet to the MS by the BTS as coded in 3GPP 23.041 Section 9.4.2.2. + * + */ +#define RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS 1021 + +/** + * RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL + * + * Indicates that SMS storage on the RUIM is full.  Messages + * cannot be saved on the RUIM until space is freed. + * + * "data" is null + * + */ +#define RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL 1022 + +/** + * RIL_UNSOL_RESTRICTED_STATE_CHANGED + * + * Indicates a restricted state change (eg, for Domain Specific Access Control). + * + * Radio need send this msg after radio off/on cycle no matter it is changed or not. + * + * "data" is an int * + * ((int *)data)[0] contains a bitmask of RIL_RESTRICTED_STATE_* values. + */ +#define RIL_UNSOL_RESTRICTED_STATE_CHANGED 1023 + +/** + * RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE + * + * Indicates that the radio system selection module has + * autonomously entered emergency callback mode. + * + * "data" is null + * + */ +#define RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE 1024 + +/** + * RIL_UNSOL_CDMA_CALL_WAITING + * + * Called when CDMA radio receives a call waiting indication. + * + * "data" is const RIL_CDMA_CallWaiting * + * + */ +#define RIL_UNSOL_CDMA_CALL_WAITING 1025 + +/** + * RIL_UNSOL_CDMA_OTA_PROVISION_STATUS + * + * Called when CDMA radio receives an update of the progress of an + * OTASP/OTAPA call. + * + * "data" is const int * + *  For CDMA this is an integer OTASP/OTAPA status listed in + *  RIL_CDMA_OTA_ProvisionStatus. + * + */ +#define RIL_UNSOL_CDMA_OTA_PROVISION_STATUS 1026 + +/** + * RIL_UNSOL_CDMA_INFO_REC + * + * Called when CDMA radio receives one or more info recs. + * + * "data" is const RIL_CDMA_InformationRecords * + * + */ +#define RIL_UNSOL_CDMA_INFO_REC 1027 + +/** + * RIL_UNSOL_OEM_HOOK_RAW + * + * This is for OEM specific use. + * + * "data" is a byte[] + */ +#define RIL_UNSOL_OEM_HOOK_RAW 1028 + +/** + * RIL_UNSOL_RINGBACK_TONE + * + * Indicates that nework doesn't have in-band information,  need to + * play out-band tone. + * + * "data" is an int * + * ((int *)data)[0] == 0 for stop play ringback tone. + * ((int *)data)[0] == 1 for start play ringback tone. + */ +#define RIL_UNSOL_RINGBACK_TONE 1029 + +/** + * RIL_UNSOL_RESEND_INCALL_MUTE + * + * Indicates that framework/application need reset the uplink mute state. + * + * There may be situations where the mute state becomes out of sync + * between the application and device in some GSM infrastructures. + * + * "data" is null + */ +#define RIL_UNSOL_RESEND_INCALL_MUTE 1030 + +/** + * RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED + * + * Called when CDMA subscription source changed. + * + * "data" is int * + * ((int *)data)[0] is == RIL_CdmaSubscriptionSource + */ +#define RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED 1031 + +/** + * RIL_UNSOL_CDMA_PRL_CHANGED + * + * Called when PRL (preferred roaming list) changes. + * + * "data" is int * + * ((int *)data)[0] is PRL_VERSION as would be returned by RIL_REQUEST_CDMA_SUBSCRIPTION + */ +#define RIL_UNSOL_CDMA_PRL_CHANGED 1032 + +/** + * RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE + * + * Called when Emergency Callback Mode Ends + * + * Indicates that the radio system selection module has + * proactively exited emergency callback mode. + * + * "data" is NULL + * + */ +#define RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE 1033 + +/** + * RIL_UNSOL_RIL_CONNECTED + * + * Called the ril connects and returns the version + * + * "data" is int * + * ((int *)data)[0] is RIL_VERSION + */ +#define RIL_UNSOL_RIL_CONNECTED 1034 + +/** + * RIL_UNSOL_VOICE_RADIO_TECH_CHANGED + * + * Indicates that voice technology has changed. Contains new radio technology + * as a data in the message. + * + * "data" is int * + * ((int *)data)[0] is of type const RIL_RadioTechnology + * + */ +#define RIL_UNSOL_VOICE_RADIO_TECH_CHANGED 1035 + +/** + * RIL_UNSOL_CELL_INFO_LIST + * + * Same information as returned by RIL_REQUEST_GET_CELL_INFO_LIST, but returned + * at the rate no greater than specified by RIL_REQUEST_SET_UNSOL_CELL_INFO_RATE. + * + * "data" is NULL + * + * "response" is an array of RIL_CellInfo. + */ +#define RIL_UNSOL_CELL_INFO_LIST 1036 + +/** + * RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED + * + * Called when IMS registration state has changed + * + * To get IMS registration state and IMS SMS format, callee needs to invoke the + * following request on main thread: + * + * RIL_REQUEST_IMS_REGISTRATION_STATE + * + * "data" is NULL + * + */ +#define RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED 1037 + +/** + * RIL_UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED + * + * Indicated when there is a change in subscription status. + * This event will be sent in the following scenarios + *  - subscription readiness at modem, which was selected by telephony layer + *  - when subscription is deactivated by modem due to UICC card removal + *  - When network invalidates the subscription i.e. attach reject due to authentication reject + * + * "data" is const int * + * ((const int *)data)[0] == 0 for Subscription Deactivated + * ((const int *)data)[0] == 1 for Subscription Activated + * + */ +#define RIL_UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED 1038 + +/** + * RIL_UNSOL_SRVCC_STATE_NOTIFY + * + * Called when Single Radio Voice Call Continuity(SRVCC) + * progress state has changed + * + * "data" is int * + * ((int *)data)[0] is of type const RIL_SrvccState + * + */ + +#define RIL_UNSOL_SRVCC_STATE_NOTIFY 1039 + +/** + * RIL_UNSOL_HARDWARE_CONFIG_CHANGED + * + * Called when the hardware configuration associated with the RILd changes + * + * "data" is an array of RIL_HardwareConfig + * + */ +#define RIL_UNSOL_HARDWARE_CONFIG_CHANGED 1040 + +/** + * RIL_UNSOL_DC_RT_INFO_CHANGED + * + * The message is DEPRECATED, use RIL_REQUEST_GET_ACTIVITY_INFO + * Sent when the DC_RT_STATE changes but the time + * between these messages must not be less than the + * value set by RIL_REQUEST_SET_DC_RT_RATE. + * + * "data" is the most recent RIL_DcRtInfo + * + */ +#define RIL_UNSOL_DC_RT_INFO_CHANGED 1041 + +/** + * RIL_UNSOL_RADIO_CAPABILITY + * + * Sent when RIL_REQUEST_SET_RADIO_CAPABILITY completes. + * Returns the phone radio capability exactly as + * RIL_REQUEST_GET_RADIO_CAPABILITY and should be the + * same set as sent by RIL_REQUEST_SET_RADIO_CAPABILITY. + * + * "data" is the RIL_RadioCapability structure + */ +#define RIL_UNSOL_RADIO_CAPABILITY 1042 + +/* + * RIL_UNSOL_ON_SS + * + * Called when SS response is received when DIAL/USSD/SS is changed to SS by + * call control. + * + * "data" is const RIL_StkCcUnsolSsResponse * + * + */ +#define RIL_UNSOL_ON_SS 1043 + +/** + * RIL_UNSOL_STK_CC_ALPHA_NOTIFY + * + * Called when there is an ALPHA from UICC during Call Control. + * + * "data" is const char * containing ALPHA string from UICC in UTF-8 format. + * + */ +#define RIL_UNSOL_STK_CC_ALPHA_NOTIFY 1044 + + /** + * RIL_UNSOL_LCEDATA_RECV + * + * Called when there is an incoming Link Capacity Estimate (LCE) info report. + * + * "data" is the RIL_LceDataInfo structure. + * + */ +#define RIL_UNSOL_LCEDATA_RECV 1045 + +/* SAMSUNG RESPONSE */ +#define SAMSUNG_UNSOL_RESPONSE_BASE 11000 + +#define RIL_UNSOL_RELEASE_COMPLETE_MESSAGE 11001 +#define RIL_UNSOL_STK_SEND_SMS_RESULT 11002 +#define RIL_UNSOL_STK_CALL_CONTROL_RESULT 11003 +#define RIL_UNSOL_DUN_CALL_STATUS 11004 + +#define RIL_UNSOL_O2_HOME_ZONE_INFO 11007 +#define RIL_UNSOL_DEVICE_READY_NOTI 11008 +#define RIL_UNSOL_GPS_NOTI 11009 +#define RIL_UNSOL_AM 11010 +#define RIL_UNSOL_DUN_PIN_CONTROL_SIGNAL 11011 +#define RIL_UNSOL_DATA_SUSPEND_RESUME 11012 +#define RIL_UNSOL_SAP 11013 + +#define RIL_UNSOL_SIM_SMS_STORAGE_AVAILALE 11015 +#define RIL_UNSOL_HSDPA_STATE_CHANGED 11016 +#define RIL_UNSOL_WB_AMR_STATE 11017 +#define RIL_UNSOL_TWO_MIC_STATE 11018 +#define RIL_UNSOL_DHA_STATE 11019 +#define RIL_UNSOL_UART 11020 +#define RIL_UNSOL_RESPONSE_HANDOVER 11021 +#define RIL_UNSOL_IPV6_ADDR 11022 +#define RIL_UNSOL_NWK_INIT_DISC_REQUEST 11023 +#define RIL_UNSOL_RTS_INDICATION 11024 +#define RIL_UNSOL_OMADM_SEND_DATA 11025 +#define RIL_UNSOL_DUN 11026 +#define RIL_UNSOL_SYSTEM_REBOOT 11027 +#define RIL_UNSOL_VOICE_PRIVACY_CHANGED 11028 +#define RIL_UNSOL_UTS_GETSMSCOUNT 11029 +#define RIL_UNSOL_UTS_GETSMSMSG 11030 +#define RIL_UNSOL_UTS_GET_UNREAD_SMS_STATUS 11031 +#define RIL_UNSOL_MIP_CONNECT_STATUS 11032 + +/***********************************************************************/ + + +#if defined(ANDROID_MULTI_SIM) +/** + * RIL_Request Function pointer + * + * @param request is one of RIL_REQUEST_* + * @param data is pointer to data defined for that RIL_REQUEST_* + *        data is owned by caller, and should not be modified or freed by callee + * @param t should be used in subsequent call to RIL_onResponse + * @param datalen the length of data + * + */ +typedef void (*RIL_RequestFunc) (int request, void *data, +                                    size_t datalen, RIL_Token t, RIL_SOCKET_ID socket_id); + +/** + * This function should return the current radio state synchronously + */ +typedef RIL_RadioState (*RIL_RadioStateRequest)(RIL_SOCKET_ID socket_id); + +#else +/* Backward compatible */ + +/** + * RIL_Request Function pointer + * + * @param request is one of RIL_REQUEST_* + * @param data is pointer to data defined for that RIL_REQUEST_* + *        data is owned by caller, and should not be modified or freed by callee + * @param t should be used in subsequent call to RIL_onResponse + * @param datalen the length of data + * + */ +typedef void (*RIL_RequestFunc) (int request, void *data, +                                    size_t datalen, RIL_Token t); + +/** + * This function should return the current radio state synchronously + */ +typedef RIL_RadioState (*RIL_RadioStateRequest)(); + +#endif + + +/** + * This function returns "1" if the specified RIL_REQUEST code is + * supported and 0 if it is not + * + * @param requestCode is one of RIL_REQUEST codes + */ + +typedef int (*RIL_Supports)(int requestCode); + +/** + * This function is called from a separate thread--not the + * thread that calls RIL_RequestFunc--and indicates that a pending + * request should be cancelled. + * + * On cancel, the callee should do its best to abandon the request and + * call RIL_onRequestComplete with RIL_Errno CANCELLED at some later point. + * + * Subsequent calls to  RIL_onRequestComplete for this request with + * other results will be tolerated but ignored. (That is, it is valid + * to ignore the cancellation request) + * + * RIL_Cancel calls should return immediately, and not wait for cancellation + * + * Please see ITU v.250 5.6.1 for how one might implement this on a TS 27.007 + * interface + * + * @param t token wants to be canceled + */ + +typedef void (*RIL_Cancel)(RIL_Token t); + +typedef void (*RIL_TimedCallback) (void *param); + +/** + * Return a version string for your RIL implementation + */ +typedef const char * (*RIL_GetVersion) (void); + +typedef struct { +    int version;        /* set to RIL_VERSION */ +    RIL_RequestFunc onRequest; +    RIL_RadioStateRequest onStateRequest; +    RIL_Supports supports; +    RIL_Cancel onCancel; +    RIL_GetVersion getVersion; +} RIL_RadioFunctions; + +typedef struct { +    char *apn; +    char *protocol; +    int authtype; +    char *username; +    char *password; +} RIL_InitialAttachApn; + +typedef struct { +    int authContext;            /* P2 value of authentication command, see P2 parameter in +                                   3GPP TS 31.102 7.1.2 */ +    char *authData;             /* the challenge string in Base64 format, see 3GPP +                                   TS 31.102 7.1.2 */ +    char *aid;                  /* AID value, See ETSI 102.221 8.1 and 101.220 4, +                                   NULL if no value. */ +} RIL_SimAuthentication; + +#ifdef RIL_SHLIB +struct RIL_Env { +    /** +     * "t" is parameter passed in on previous call to RIL_Notification +     * routine. +     * +     * If "e" != SUCCESS, then response can be null/is ignored +     * +     * "response" is owned by caller, and should not be modified or +     * freed by callee +     * +     * RIL_onRequestComplete will return as soon as possible +     */ +    void (*OnRequestComplete)(RIL_Token t, RIL_Errno e, +                           void *response, size_t responselen); + +#if defined(ANDROID_MULTI_SIM) +    /** +     * "unsolResponse" is one of RIL_UNSOL_RESPONSE_* +     * "data" is pointer to data defined for that RIL_UNSOL_RESPONSE_* +     * +     * "data" is owned by caller, and should not be modified or freed by callee +     */ +    void (*OnUnsolicitedResponse)(int unsolResponse, const void *data, size_t datalen, RIL_SOCKET_ID socket_id); +#else +    /** +     * "unsolResponse" is one of RIL_UNSOL_RESPONSE_* +     * "data" is pointer to data defined for that RIL_UNSOL_RESPONSE_* +     * +     * "data" is owned by caller, and should not be modified or freed by callee +     */ +    void (*OnUnsolicitedResponse)(int unsolResponse, const void *data, size_t datalen); +#endif +    /** +     * Call user-specifed "callback" function on on the same thread that +     * RIL_RequestFunc is called. If "relativeTime" is specified, then it specifies +     * a relative time value at which the callback is invoked. If relativeTime is +     * NULL or points to a 0-filled structure, the callback will be invoked as +     * soon as possible +     */ + +    void (*RequestTimedCallback) (RIL_TimedCallback callback, +                                   void *param, const struct timeval *relativeTime); +}; + + +/** + *  RIL implementations must defined RIL_Init + *  argc and argv will be command line arguments intended for the RIL implementation + *  Return NULL on error + * + * @param env is environment point defined as RIL_Env + * @param argc number of arguments + * @param argv list fo arguments + * + */ +const RIL_RadioFunctions *RIL_Init(const struct RIL_Env *env, int argc, char **argv); + +#else /* RIL_SHLIB */ + +/** + * Call this once at startup to register notification routine + * + * @param callbacks user-specifed callback function + */ +void RIL_register (const RIL_RadioFunctions *callbacks); + + +/** + * + * RIL_onRequestComplete will return as soon as possible + * + * @param t is parameter passed in on previous call to RIL_Notification + *          routine. + * @param e error code + *          if "e" != SUCCESS, then response can be null/is ignored + * @param response is owned by caller, and should not be modified or + *                 freed by callee + * @param responselen the length of response in byte + */ +void RIL_onRequestComplete(RIL_Token t, RIL_Errno e, +                           void *response, size_t responselen); + +#if defined(ANDROID_MULTI_SIM) +/** + * @param unsolResponse is one of RIL_UNSOL_RESPONSE_* + * @param data is pointer to data defined for that RIL_UNSOL_RESPONSE_* + *     "data" is owned by caller, and should not be modified or freed by callee + * @param datalen the length of data in byte + */ + +void RIL_onUnsolicitedResponse(int unsolResponse, const void *data, +                                size_t datalen, RIL_SOCKET_ID socket_id); +#else +/** + * @param unsolResponse is one of RIL_UNSOL_RESPONSE_* + * @param data is pointer to data defined for that RIL_UNSOL_RESPONSE_* + *     "data" is owned by caller, and should not be modified or freed by callee + * @param datalen the length of data in byte + */ + +void RIL_onUnsolicitedResponse(int unsolResponse, const void *data, +                                size_t datalen); +#endif + +/** + * Call user-specifed "callback" function on on the same thread that + * RIL_RequestFunc is called. If "relativeTime" is specified, then it specifies + * a relative time value at which the callback is invoked. If relativeTime is + * NULL or points to a 0-filled structure, the callback will be invoked as + * soon as possible + * + * @param callback user-specifed callback function + * @param param parameter list + * @param relativeTime a relative time value at which the callback is invoked + */ + +void RIL_requestTimedCallback (RIL_TimedCallback callback, +                               void *param, const struct timeval *relativeTime); + + +#endif /* RIL_SHLIB */ + +#ifdef __cplusplus +} +#endif + +#endif /*ANDROID_RIL_H*/ diff --git a/selinux/device.te b/selinux/device.te deleted file mode 100644 index c95050b..0000000 --- a/selinux/device.te +++ /dev/null @@ -1,4 +0,0 @@ -type mali_device, dev_type, mlstrustedobject; -type rfkill_device, dev_type; -type diagnostic_device, dev_type; -type efs_block_device, dev_type; diff --git a/selinux/dhcp.te b/selinux/dhcp.te deleted file mode 100755 index c403b9b..0000000 --- a/selinux/dhcp.te +++ /dev/null @@ -1 +0,0 @@ -allow dhcp self:rawip_socket { create write setopt }; diff --git a/selinux/domain.te b/selinux/domain.te deleted file mode 100644 index 1be0633..0000000 --- a/selinux/domain.te +++ /dev/null @@ -1,4 +0,0 @@ -## /dev/mali, /dev/ump -allow domain mali_device:chr_file rw_file_perms; - - diff --git a/selinux/file.te b/selinux/file.te deleted file mode 100644 index 185b1c2..0000000 --- a/selinux/file.te +++ /dev/null @@ -1,9 +0,0 @@ -type radio_efs_file, fs_type; - -type firmware_mfc, file_type; -type firmware_camera, file_type; - -type qmuxd_socket, file_type; -type kickstart_data_file, file_type, data_file_type; -type sensors_data_file, file_type, data_file_type; -type volume_data_file, file_type, data_file_type; diff --git a/selinux/file_contexts b/selinux/file_contexts deleted file mode 100644 index 36dc14c..0000000 --- a/selinux/file_contexts +++ /dev/null @@ -1,70 +0,0 @@ -# GFX -/dev/mali                               u:object_r:mali_device:s0 -/dev/ump                                u:object_r:mali_device:s0 -/dev/fimg2d                             u:object_r:mali_device:s0 - -# RIL -/dev/mdm                                u:object_r:radio_device:s0 -/dev/hsicctl[0-3]*                      u:object_r:radio_device:s0 -/dev/ttyUSB0                            u:object_r:radio_device:s0 -/dev/diag                               u:object_r:diagnostic_device:s0 - -# GPS -/dev/ttySAC1                            u:object_r:gps_device:s0 - -# Bluetooth -/dev/ttySAC0                            u:object_r:hci_attach_dev:s0 -/efs/bluetooth(/.*)?                    u:object_r:bluetooth_data_file:s0 - -# Sensors -/dev/akm8975                            u:object_r:sensors_device:s0 -/efs/gyro_cal_data                      u:object_r:sensors_data_file:s0 - -# Camera -/data/ISP_CV                            u:object_r:camera_data_file:s0 -/dev/exynos-mem                         u:object_r:video_device:s0 - -# for wpa_supp -/dev/rfkill                             u:object_r:rfkill_device:s0 - -# Firmwares -/system/vendor/firmware(/.*)?           u:object_r:firmware_camera:s0 -/system/vendor/firmware/mfc_fw.bin      u:object_r:firmware_mfc:s0 -/system/vendor/firmware/fimc_is_fw.bin  u:object_r:firmware_camera:s0 -/data/cfw(/.*)?                         u:object_r:firmware_camera:s0 -/tombstones                             u:object_r:system_data_file:s0 -/tombstones(/.*)?                       u:object_r:tombstone_data_file:s0 -/tombstones/qcks(/.*)?                  u:object_r:kickstart_data_file:s0 - -# Vibrator -/dev/tspdrv                             u:object_r:input_device:s0 - -# Wifi -/efs/wifi/.mac.info                     u:object_r:wifi_data_file:s0 - -# Sec-ril -/efs/FactoryApp/keystr                  u:object_r:efs_file:s0 -/efs/FactoryApp/factorymode             u:object_r:efs_file:s0 -/efs/FactoryApp/serial_no               u:object_r:efs_file:s0 -/data/misc/radio/ramdumpmode.txt        u:object_r:radio_data_file:s0 -/data/misc/radio/dlnk                   u:object_r:radio_data_file:s0 - -# Binaries -/system/bin/qmuxd                u:object_r:qmux_exec:s0 -/system/bin/efsks                u:object_r:kickstart_exec:s0 -/system/bin/ks                   u:object_r:kickstart_exec:s0 -/system/bin/qcks                 u:object_r:kickstart_exec:s0 - -# Sockets -/dev/socket/qmux_audio(/.*)?     u:object_r:qmuxd_socket:s0 -/dev/socket/qmux_bluetooth(/.*)? u:object_r:qmuxd_socket:s0 -/dev/socket/qmux_gps(/.*)?       u:object_r:qmuxd_socket:s0 -/dev/socket/qmux_radio(/.*)?     u:object_r:qmuxd_socket:s0 - -# Block devices -/dev/block/mmcblk0p[3-6]*       u:object_r:efs_block_device:s0 -/dev/block/mmcblk0p10           u:object_r:efs_block_device:s0 -/dev/block/mmcblk0p11           u:object_r:efs_block_device:s0 - -# Audio related -/data/local/audio(/.*)?         u:object_r:volume_data_file:s0 diff --git a/selinux/init.te b/selinux/init.te deleted file mode 100644 index 2f29889..0000000 --- a/selinux/init.te +++ /dev/null @@ -1,3 +0,0 @@ -allow init wpa_socket:unix_dgram_socket { bind create }; - - diff --git a/selinux/kickstart.te b/selinux/kickstart.te deleted file mode 100755 index 14e1ad5..0000000 --- a/selinux/kickstart.te +++ /dev/null @@ -1,44 +0,0 @@ -# kickstart processes and scripts -type kickstart, domain; -type kickstart_exec, exec_type, file_type; - -# kickstart_checker.sh talks to init over the property socket -unix_socket_connect(kickstart, property, init) - -# Start /system/bin/qcks from init -init_daemon_domain(kickstart) - -# Spawn /system/bin/efsks and /system/bin/ks -allow kickstart kickstart_exec:file { open execute_no_trans getattr }; - -# Run dd on m9kefs[123] block devices; write to /data/qcks/ -# Run cat on firmware and m9kefs[123] data; write to /data/qcks/ -allow kickstart efs_block_device:blk_file rw_file_perms; -allow kickstart kickstart_data_file:file create_file_perms; -allow kickstart kickstart_data_file:dir rw_dir_perms; -allow kickstart radio_efs_file:file r_file_perms; -allow kickstart radio_efs_file:dir search; - -# Let qcks access /dev/mdm node (modem driver) -allow kickstart radio_device:chr_file rw_file_perms; - -# Allow /dev/ttyUSB0 access -allow kickstart radio_device:chr_file { write ioctl getattr }; - -# Allow to run toolbox commands -allow kickstart shell_exec:file rx_file_perms; -# Toolbox commands for firmware dd -allow kickstart system_file:file execute_no_trans; - -# Access to /dev/block/platform/msm_sdcc.1/by-name/m9kefs2 -allow kickstart block_device:dir { getattr write search }; - -# Set system property key -allow kickstart radio_prop:property_service set; - -allow kickstart shell_exec:file entrypoint; -# ls on /data/qcks/ -allow kickstart self:capability { dac_override setuid }; - -# XXX Label sysfs files with a specific type? -allow kickstart sysfs:file rw_file_perms;
\ No newline at end of file diff --git a/selinux/mediaserver.te b/selinux/mediaserver.te deleted file mode 100644 index 35dce7b..0000000 --- a/selinux/mediaserver.te +++ /dev/null @@ -1,8 +0,0 @@ -qmux_socket(mediaserver) -allow mediaserver self:socket create_socket_perms; -allow mediaserver { firmware_camera }:file r_file_perms; -allow mediaserver firmware_camera:dir r_dir_perms; -allow mediaserver camera_data_file:file rw_file_perms; - -# Bluetooth audio -allow mediaserver bluetooth:unix_stream_socket { connectto }; diff --git a/selinux/netmgrd.te b/selinux/netmgrd.te deleted file mode 100755 index 11159a4..0000000 --- a/selinux/netmgrd.te +++ /dev/null @@ -1,29 +0,0 @@ -# Network utilities (radio process) -type netmgrd, domain; -type netmgrd_exec, exec_type, file_type; - -# Started by init -init_daemon_domain(netmgrd) - -allow netmgrd self:udp_socket { create ioctl }; -# fsetid, dac_override unlink on /dev/socket/qmux_radio/qmux_client_socket -allow netmgrd self:capability { sys_module fsetid setuid setgid net_admin net_raw dac_override }; -allow netmgrd self:packet_socket { write bind read create }; -allow netmgrd self:netlink_socket { write read create bind setopt }; -allow netmgrd self:netlink_route_socket { create bind read write nlmsg_read nlmsg_write setopt getattr }; -allow netmgrd kernel:system module_request; - -# Talk to qmuxd -qmux_socket(netmgrd) - -# Allow logging diagnostic items -allow netmgrd diagnostic_device:chr_file rw_file_perms; - -# /data/data_test/ access with shell -allow netmgrd shell_exec:file { execute read open execute_no_trans }; -allow netmgrd system_file:file { execute_no_trans }; - -# Talk to init over the property socket -unix_socket_connect(netmgrd, property, init) -# Set net.rmnet_usb0. values -allow netmgrd radio_prop:property_service set; diff --git a/selinux/qmux.te b/selinux/qmux.te deleted file mode 100755 index e2a5bbf..0000000 --- a/selinux/qmux.te +++ /dev/null @@ -1,21 +0,0 @@ -# Qualcomm Management Interface Multiplexer -type qmux, domain; -type qmux_exec, exec_type, file_type; - -# Started by init -init_daemon_domain(qmux) - -# Create local qmux_connect_socket -allow qmux qmuxd_socket:dir w_dir_perms; -allow qmux qmuxd_socket:sock_file { create setattr getattr unlink }; - -# /dev/hsicctl* node access -allow qmux radio_device:chr_file rw_file_perms; - -# Allow logging diagnostic items -allow qmux diagnostic_device:chr_file rw_file_perms; - -allow qmux self:capability { dac_override setuid }; - -# XXX Should we label with own type -allow qmux sysfs:file { open write append read getattr }; diff --git a/selinux/rild.te b/selinux/rild.te deleted file mode 100755 index 04209b0..0000000 --- a/selinux/rild.te +++ /dev/null @@ -1,14 +0,0 @@ -## RIL -allow rild radio_device:chr_file rw_file_perms; -allow rild { efs_file }:file rw_file_perms; -allow rild self:netlink_socket { create bind read write }; -allow rild self:netlink_route_socket { write }; - -# Talk to qmuxd -qmux_socket(rild) - -# Allow logging diagnostic items -allow rild diagnostic_device:chr_file rw_file_perms; - -# XXX label with own type? -allow rild sysfs:file { read open write getattr }; diff --git a/selinux/secril.te b/selinux/secril.te deleted file mode 100644 index 7761d80..0000000 --- a/selinux/secril.te +++ /dev/null @@ -1,25 +0,0 @@ -# sec-ril -type secril-daemon, domain; -type secril-daemon_exec, exec_type, file_type; - -# Start /system/bin/sec-ril from init -init_daemon_domain(secril-daemon) - -allow secril-daemon secril-daemon_exec:file { open execute_no_trans getattr }; -allow secril-daemon self:udp_socket { create ioctl }; -unix_socket_connect(secril-daemon, property, init) -unix_socket_connect(secril-daemon, rild, rild) - -allow secril-daemon { efs_file }:file rw_file_perms; -allow secril-daemon system_data_file:dir create_dir_perms; -allow secril-daemon system_data_file:file unlink; -allow secril-daemon radio_data_file:file { create_file_perms }; -allow secril-daemon kernel:system module_request; -allow secril-daemon self:capability { sys_module fsetid setuid setgid net_admin net_raw dac_override }; -allow secril-daemon system_file:file x_file_perms; -allow secril-daemon sysfs:file rw_file_perms; -allow secril-daemon shell_exec:file rx_file_perms; -allow secril-daemon app_data_file:file rw_file_perms; -allow secril-daemon app_data_file:dir search; -allow secril-daemon zygote_exec:file rx_file_perms; -allow secril-daemon ashmem_device:chr_file x_file_perms;
\ No newline at end of file diff --git a/selinux/system.te b/selinux/system.te deleted file mode 100755 index bc8212b..0000000 --- a/selinux/system.te +++ /dev/null @@ -1,12 +0,0 @@ -# Talk to qmuxd -qmux_socket(system) - -allow system diagnostic_device:chr_file rw_file_perms; -allow system sensors_device:chr_file { read open }; -allow system sensors_data_file:file r_file_perms; -allow system wpa_socket:unix_dgram_socket sendto; -allow system_app volume_data_file:file { read write open getattr }; - -allow system sysfs:file { read open write }; -allow system self:capability { sys_module }; - diff --git a/selinux/te_macros b/selinux/te_macros deleted file mode 100755 index 274fd55..0000000 --- a/selinux/te_macros +++ /dev/null @@ -1,12 +0,0 @@ -##################################### -# qmux_socket(clientdomain) -# Allow client to send via a local -# socket to the qmux domain. -define(`qmux_socket', ` -type $1_qmuxd_socket, file_type; -file_type_auto_trans($1, qmuxd_socket, $1_qmuxd_socket) -unix_socket_connect($1, qmuxd, qmux) -allow qmux $1_qmuxd_socket:sock_file { getattr unlink }; -') - - diff --git a/selinux/ueventd.te b/selinux/ueventd.te deleted file mode 100644 index fd1852b..0000000 --- a/selinux/ueventd.te +++ /dev/null @@ -1,11 +0,0 @@ -# Drivers read firmware files /firmware/image -allow ueventd { radio_efs_file }:file r_file_perms; -allow ueventd { radio_efs_file }:dir search; - -# MFC firmware -allow ueventd { firmware_mfc }:file r_file_perms; - -# Camera related firmwares -allow ueventd { firmware_camera }:dir search; -allow ueventd { firmware_camera }:file r_file_perms; - diff --git a/selinux/wpa_supplicant.te b/selinux/wpa_supplicant.te deleted file mode 100755 index ab5fb24..0000000 --- a/selinux/wpa_supplicant.te +++ /dev/null @@ -1,10 +0,0 @@ -allow wpa init:unix_dgram_socket { read write }; - -# logwrapper used with wpa_supplicant -allow wpa devpts:chr_file { read write }; - -allow wpa wpa_socket:unix_dgram_socket { read write }; -allow wpa_socket system:unix_dgram_socket sendto; - -allow wpa_socket wifi_data_file:sock_file unlink; -allow wpa rfkill_device:chr_file rw_file_perms;
\ No newline at end of file  | 
