ril.cpp revision 6e7c1966c6a41b6e7c0431dcc6bf65678438c79e
100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* //device/libs/telephony/ril.cpp
200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project**
300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project** Copyright 2006, The Android Open Source Project
400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project**
57f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** Licensed under the Apache License, Version 2.0 (the "License");
67f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** you may not use this file except in compliance with the License.
77f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** You may obtain a copy of the License at
800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project**
97f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville**     http://www.apache.org/licenses/LICENSE-2.0
1000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project**
117f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** Unless required by applicable law or agreed to in writing, software
127f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** distributed under the License is distributed on an "AS IS" BASIS,
137f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
147f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville** See the License for the specific language governing permissions and
1500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project** limitations under the License.
1600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project*/
1700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define LOG_TAG "RILC"
1900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <hardware_legacy/power.h>
2100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <telephony/ril.h>
23f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#include <telephony/ril_cdma_sms.h>
2400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/sockets.h>
2500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/jstring.h>
26622bf2bf79849127cbedd1f56631615bf58aaf78Dima Zavin#include <telephony/record_stream.h>
2700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <utils/Log.h>
2800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <utils/SystemClock.h>
2900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <pthread.h>
308a3c48c4eac62f9c25ab3f0dbfd8f829a1e32778Mathias Agopian#include <binder/Parcel.h>
3100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/jstring.h>
3200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <sys/types.h>
3418e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville#include <sys/limits.h>
3500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <pwd.h>
3600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdio.h>
3800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdlib.h>
3900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdarg.h>
4000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <string.h>
4100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <unistd.h>
4200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <fcntl.h>
4300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <time.h>
4400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <errno.h>
4500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <assert.h>
4600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <ctype.h>
4700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <alloca.h>
4800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <sys/un.h>
4900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <assert.h>
5000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <netinet/in.h>
5100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/properties.h>
5200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <ril_event.h>
5400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectnamespace android {
5600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PHONE_PROCESS "radio"
5800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define SOCKET_NAME_RIL "rild"
6000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define SOCKET_NAME_RIL_DEBUG "rild-debug"
6100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define ANDROID_WAKE_LOCK_NAME "radio-interface"
6300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PROPERTY_RIL_IMPL "gsm.version.ril-impl"
6600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// match with constant in RIL.java
6800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define MAX_COMMAND_BYTES (8 * 1024)
6900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
7000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Basically: memset buffers that the client library
7100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// shouldn't be using anymore in an attempt to find
7200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// memory usage issues sooner.
7300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define MEMSET_FREED 1
7400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
7500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define NUM_ELEMS(a)     (sizeof (a) / sizeof (a)[0])
7600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
77f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#define MIN(a,b) ((a)<(b) ? (a) : (b))
78f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
7900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* Constants for response types */
8000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RESPONSE_SOLICITED 0
8100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RESPONSE_UNSOLICITED 1
8200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
8300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* Negative values for private RIL errno's */
8400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RIL_ERRNO_INVALID_RESPONSE -1
8500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
8600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// request, response, and unsolicited msg print macro
8700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PRINTBUF_SIZE 8096
8800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
8900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Enable RILC log
9000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RILC_LOG 0
9100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
9200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if RILC_LOG
9300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define startRequest           sprintf(printBuf, "(")
9400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define closeRequest           sprintf(printBuf, "%s)", printBuf)
9500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define printRequest(token, req)           \
968eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGD("[%04d]> %s %s", token, requestToString(req), printBuf)
9700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
9800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define startResponse           sprintf(printBuf, "%s {", printBuf)
9900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define closeResponse           sprintf(printBuf, "%s}", printBuf)
1008eb2a12cb7b525e74736300962a5f3848427275aWink Saville    #define printResponse           RLOGD("%s", printBuf)
10100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
10200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define clearPrintBuf           printBuf[0] = 0
10300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define removeLastChar          printBuf[strlen(printBuf)-1] = 0
10400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define appendPrintBuf(x...)    sprintf(printBuf, x)
10500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#else
10600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define startRequest
10700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define closeRequest
10800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define printRequest(token, req)
10900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define startResponse
11000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define closeResponse
11100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define printResponse
11200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define clearPrintBuf
11300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define removeLastChar
11400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    #define appendPrintBuf(x...)
11500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
11600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
11700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectenum WakeType {DONT_WAKE, WAKE_PARTIAL};
11800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
11900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct {
12000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int requestNumber;
12100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    void (*dispatchFunction) (Parcel &p, struct RequestInfo *pRI);
12200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int(*responseFunction) (Parcel &p, void *response, size_t responselen);
12300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} CommandInfo;
12400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
12500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct {
12600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int requestNumber;
12700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int (*responseFunction) (Parcel &p, void *response, size_t responselen);
12800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    WakeType wakeType;
12900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} UnsolResponseInfo;
13000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
13100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct RequestInfo {
1327f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    int32_t token;      //this is not RIL_Token
13300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    CommandInfo *pCI;
13400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct RequestInfo *p_next;
13500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char cancelled;
13600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char local;         // responses to local commands do not go back to command process
13700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} RequestInfo;
13800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1393d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savilletypedef struct UserCallbackInfo {
14000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_TimedCallback p_callback;
14100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    void *userParam;
14200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct ril_event event;
14300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct UserCallbackInfo *p_next;
14400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} UserCallbackInfo;
14500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1460d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn
14700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*******************************************************************/
14800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
14900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source ProjectRIL_RadioFunctions s_callbacks = {0, NULL, NULL, NULL, NULL, NULL};
15000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_registerCalled = 0;
15100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
15200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_t s_tid_dispatch;
15300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_t s_tid_reader;
15400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_started = 0;
15500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
15600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdListen = -1;
15700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdCommand = -1;
15800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdDebug = -1;
15900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
16000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdWakeupRead;
16100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdWakeupWrite;
16200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
16300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_commands_event;
16400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_wakeupfd_event;
16500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_listen_event;
16600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_wake_timeout_event;
16700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_debug_event;
16800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
16900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
17000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic const struct timeval TIMEVAL_WAKE_TIMEOUT = {1,0};
17100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
17200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_pendingRequestsMutex = PTHREAD_MUTEX_INITIALIZER;
17300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_writeMutex = PTHREAD_MUTEX_INITIALIZER;
17400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_startupMutex = PTHREAD_MUTEX_INITIALIZER;
17500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_cond_t s_startupCond = PTHREAD_COND_INITIALIZER;
17600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
17700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_dispatchMutex = PTHREAD_MUTEX_INITIALIZER;
17800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_cond_t s_dispatchCond = PTHREAD_COND_INITIALIZER;
17900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
18000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_pendingRequests = NULL;
18100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
18200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_toDispatchHead = NULL;
18300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_toDispatchTail = NULL;
18400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
18500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UserCallbackInfo *s_last_wake_timeout_info = NULL;
18600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
18700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void *s_lastNITZTimeData = NULL;
18800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic size_t s_lastNITZTimeDataSize;
18900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
19000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if RILC_LOG
19100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    static char printBuf[PRINTBUF_SIZE];
19200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
19300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
19400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*******************************************************************/
19500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
19600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchVoid (Parcel& p, RequestInfo *pRI);
19700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchString (Parcel& p, RequestInfo *pRI);
19800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchStrings (Parcel& p, RequestInfo *pRI);
19900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchInts (Parcel& p, RequestInfo *pRI);
20000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchDial (Parcel& p, RequestInfo *pRI);
20100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchSIM_IO (Parcel& p, RequestInfo *pRI);
2022458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawalstatic void dispatchSIM_APDU (Parcel& p, RequestInfo *pRI);
20300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchCallForward(Parcel& p, RequestInfo *pRI);
20400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchRaw(Parcel& p, RequestInfo *pRI);
20500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchSmsWrite (Parcel &p, RequestInfo *pRI);
2064f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colittistatic void dispatchDataCall (Parcel& p, RequestInfo *pRI);
2072bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic void dispatchVoiceRadioTech (Parcel& p, RequestInfo *pRI);
20875697538e485ea2981960dcd4878bfdd032731acSungmin Choistatic void dispatchSetInitialAttachApn (Parcel& p, RequestInfo *pRI);
2092bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic void dispatchCdmaSubscriptionSource (Parcel& p, RequestInfo *pRI);
21000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
211f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaSms(Parcel &p, RequestInfo *pRI);
212a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void dispatchImsSms(Parcel &p, RequestInfo *pRI);
213a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void dispatchImsCdmaSms(Parcel &p, RequestInfo *pRI, uint8_t retry, int32_t messageRef);
214a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void dispatchImsGsmSms(Parcel &p, RequestInfo *pRI, uint8_t retry, int32_t messageRef);
215f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaSmsAck(Parcel &p, RequestInfo *pRI);
216a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void dispatchGsmBrSmsCnf(Parcel &p, RequestInfo *pRI);
217f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaBrSmsCnf(Parcel &p, RequestInfo *pRI);
218f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchRilCdmaSmsWriteArgs(Parcel &p, RequestInfo *pRI);
21900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseInts(Parcel &p, void *response, size_t responselen);
22000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseStrings(Parcel &p, void *response, size_t responselen);
22100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseString(Parcel &p, void *response, size_t responselen);
22200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseVoid(Parcel &p, void *response, size_t responselen);
22300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCallList(Parcel &p, void *response, size_t responselen);
22400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSMS(Parcel &p, void *response, size_t responselen);
22500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSIM_IO(Parcel &p, void *response, size_t responselen);
22600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCallForwards(Parcel &p, void *response, size_t responselen);
227f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseDataCallList(Parcel &p, void *response, size_t responselen);
2284380897c6cdc99486a061b819943e3b290ebcf09Wink Savillestatic int responseSetupDataCall(Parcel &p, void *response, size_t responselen);
22900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseRaw(Parcel &p, void *response, size_t responselen);
23000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSsn(Parcel &p, void *response, size_t responselen);
231f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSimStatus(Parcel &p, void *response, size_t responselen);
232a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseGsmBrSmsCnf(Parcel &p, void *response, size_t responselen);
233a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaBrSmsCnf(Parcel &p, void *response, size_t responselen);
234f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCdmaSms(Parcel &p, void *response, size_t responselen);
23500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCellList(Parcel &p, void *response, size_t responselen);
2363d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaInformationRecords(Parcel &p,void *response, size_t responselen);
2373d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseRilSignalStrength(Parcel &p,void *response, size_t responselen);
2383d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCallRing(Parcel &p, void *response, size_t responselen);
2393d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaSignalInfoRecord(Parcel &p,void *response, size_t responselen);
2403d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaCallWaiting(Parcel &p,void *response, size_t responselen);
24145e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenkastatic int responseSimRefresh(Parcel &p, void *response, size_t responselen);
2428a9e02161271505de274db0c3a88087056dd5dfcWink Savillestatic int responseCellInfoList(Parcel &p, void *response, size_t responselen);
24300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2442bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic int decodeVoiceRadioTechnology (RIL_RadioState radioState);
2452bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic int decodeCdmaSubscriptionSource (RIL_RadioState radioState);
2462bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic RIL_RadioState processRadioState(RIL_RadioState newRadioState);
2472bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
24800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * requestToString(int request);
24900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * failCauseToString(RIL_Errno);
25000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * callStateToString(RIL_CallState);
25100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * radioStateToString(RIL_RadioState);
25200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
25300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef RIL_SHLIB
2547f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void RIL_onUnsolicitedResponse(int unsolResponse, void *data,
25500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                size_t datalen);
25600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
25700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2587f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic UserCallbackInfo * internalRequestTimedCallback
2590d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn    (RIL_TimedCallback callback, void *param,
2600d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn        const struct timeval *relativeTime);
26100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
26200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Index == requestNumber */
26300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic CommandInfo s_commands[] = {
26400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include "ril_commands.h"
26500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project};
26600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
26700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UnsolResponseInfo s_unsolResponses[] = {
26800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include "ril_unsol_commands.h"
26900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project};
27000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2712bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla/* For older RILs that do not support new commands RIL_REQUEST_VOICE_RADIO_TECH and
2722bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   RIL_UNSOL_VOICE_RADIO_TECH_CHANGED messages, decode the voice radio tech from
2732bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   radio state message and store it. Every time there is a change in Radio State
2742bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   check to see if voice radio tech changes and notify telephony
2752bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla */
2762bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallaint voiceRadioTech = -1;
2772bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
2782bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla/* For older RILs that do not support new commands RIL_REQUEST_GET_CDMA_SUBSCRIPTION_SOURCE
2792bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   and RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED messages, decode the subscription
2802bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   source from radio state and store it. Every time there is a change in Radio State
2812bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   check to see if subscription source changed and notify telephony
2822bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla */
2832bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallaint cdmaSubscriptionSource = -1;
2842bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
2852bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla/* For older RILs that do not send RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED, decode the
2862bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   SIM/RUIM state from radio state and store it. Every time there is a change in Radio State,
2872bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   check to see if SIM/RUIM status changed and notify telephony
2882bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla */
2892bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallaint simRuimStatus = -1;
29000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
29100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic char *
292f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillestrdupReadString(Parcel &p) {
29300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t stringlen;
29400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    const char16_t *s16;
2957f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
29600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s16 = p.readString16Inplace(&stringlen);
2977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
29800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return strndup16to8(s16, stringlen);
29900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
30000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
301f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void writeStringToParcel(Parcel &p, const char *s) {
30200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char16_t *s16;
30300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t s16_len;
30400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s16 = strdup8to16(s, &s16_len);
30500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeString16(s16, s16_len);
30600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free(s16);
30700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
30800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
30900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
31000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
311f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillememsetString (char *s) {
31200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s != NULL) {
31300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        memset (s, 0, strlen(s));
31400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
31500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
31600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
31700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectvoid   nullParcelReleaseFunction (const uint8_t* data, size_t dataSize,
31800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                    const size_t* objects, size_t objectsSize,
319f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville                                        void* cookie) {
32000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // do nothing -- the data reference lives longer than the Parcel object
32100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
32200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3237f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/**
32400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * To be called from dispatch thread
32500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Issue a single local request, ensuring that the response
3267f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * is not sent back up to the command process
32700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
32800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
329f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleissueLocalRequest(int request, void *data, int len) {
33000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RequestInfo *pRI;
33100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
33200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
33300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI = (RequestInfo *)calloc(1, sizeof(RequestInfo));
33400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
33500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->local = 1;
33600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->token = 0xffffffff;        // token is not used in this context
33700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->pCI = &(s_commands[request]);
33800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
33900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_lock(&s_pendingRequestsMutex);
34000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
34100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
34200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->p_next = s_pendingRequests;
34300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_pendingRequests = pRI;
34400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
34500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_unlock(&s_pendingRequestsMutex);
34600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
34700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3488eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGD("C[locl]> %s", requestToString(request));
34900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
35000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(request, data, len, pRI);
35100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
35200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
35300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
35400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
35500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int
356f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleprocessCommandBuffer(void *buffer, size_t buflen) {
35700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    Parcel p;
35800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
35900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t request;
36000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t token;
36100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RequestInfo *pRI;
36200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
36300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
36400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.setData((uint8_t *) buffer, buflen);
36500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
36600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // status checked at end
36700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&request);
36800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32 (&token);
36900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
37000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR) {
3718eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid request block");
37200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return 0;
37300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
37400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
37500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (request < 1 || request >= (int32_t)NUM_ELEMS(s_commands)) {
3768eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("unsupported request code %d token %d", request, token);
37700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // FIXME this should perhaps return a response
37800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return 0;
37900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
38000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
38100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
38200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI = (RequestInfo *)calloc(1, sizeof(RequestInfo));
38300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
38400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->token = token;
38500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->pCI = &(s_commands[request]);
38600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
38700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_lock(&s_pendingRequestsMutex);
38800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
38900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
39000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI->p_next = s_pendingRequests;
39100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_pendingRequests = pRI;
39200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
39300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_unlock(&s_pendingRequestsMutex);
39400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
39500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
39600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*    sLastDispatchedToken = token; */
39700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3987f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    pRI->pCI->dispatchFunction(p, pRI);
39900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
40000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
40100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
40200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
40300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
404f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleinvalidCommandBlock (RequestInfo *pRI) {
4058eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGE("invalid command block for token %d request %s",
40600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                pRI->token, requestToString(pRI->pCI->requestNumber));
40700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
40800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
40900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects NULL */
4107f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void
411f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchVoid (Parcel& p, RequestInfo *pRI) {
41200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    clearPrintBuf;
41300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
41400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, NULL, 0, pRI);
41500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
41600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
41700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const char * */
41800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
419f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchString (Parcel& p, RequestInfo *pRI) {
42000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
42100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t datalen;
42200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t stringlen;
42300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char *string8 = NULL;
42400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
42500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    string8 = strdupReadString(p);
42600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
42700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
42800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%s%s", printBuf, string8);
42900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
43000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
43100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
43200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, string8,
43300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                       sizeof(char *), pRI);
43400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
43500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
43600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memsetString(string8);
43700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
43800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
43900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free(string8);
44000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
44100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
44200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
44300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
44400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
44500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
44600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const char ** */
44700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
448f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchStrings (Parcel &p, RequestInfo *pRI) {
44900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t countStrings;
45000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
45100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t datalen;
45200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char **pStrings;
45300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
45400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32 (&countStrings);
45500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
45600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR) {
45700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
45800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
45900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
46000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
46100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (countStrings == 0) {
46200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // just some non-null pointer
46300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pStrings = (char **)alloca(sizeof(char *));
46400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        datalen = 0;
46500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else if (((int)countStrings) == -1) {
46600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pStrings = NULL;
46700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        datalen = 0;
46800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
46900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        datalen = sizeof(char *) * countStrings;
4707f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
47100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pStrings = (char **)alloca(datalen);
47200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
47300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        for (int i = 0 ; i < countStrings ; i++) {
47400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            pStrings[i] = strdupReadString(p);
47500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            appendPrintBuf("%s%s,", printBuf, pStrings[i]);
47600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
47700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
47800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
47900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
48000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
48100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
48200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, pStrings, datalen, pRI);
48300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
48400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (pStrings != NULL) {
48500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        for (int i = 0 ; i < countStrings ; i++) {
48600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
48700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            memsetString (pStrings[i]);
48800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
48900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            free(pStrings[i]);
49000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
49100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
49200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
49300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        memset(pStrings, 0, datalen);
49400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
49500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
4967f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
49700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
49800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
49900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
50000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
50100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
50200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
50300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const int * */
50400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
505f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchInts (Parcel &p, RequestInfo *pRI) {
50600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t count;
50700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
50800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t datalen;
50900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int *pInts;
51000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
51100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32 (&count);
51200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
51300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR || count == 0) {
51400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
51500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
51600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
51700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    datalen = sizeof(int) * count;
51800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pInts = (int *)alloca(datalen);
51900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
52000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
52100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0 ; i < count ; i++) {
52200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        int32_t t;
52300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
52400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        status = p.readInt32(&t);
52500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pInts[i] = (int)t;
52600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        appendPrintBuf("%s%d,", printBuf, t);
52700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
52800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (status != NO_ERROR) {
52900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            goto invalid;
53000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
53100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project   }
53200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project   removeLastChar;
53300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project   closeRequest;
53400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project   printRequest(pRI->token, pRI->pCI->requestNumber);
53500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5367f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville   s_callbacks.onRequest(pRI->pCI->requestNumber, const_cast<int *>(pInts),
53700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                       datalen, pRI);
53800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
53900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
54000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset(pInts, 0, datalen);
54100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
54200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
54300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
54400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
54500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
54600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
54700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
54800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
54900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5507f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/**
5517f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_SMS_WriteArgs *
55200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is:
55300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   int32_t status
55400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   String pdu
55500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
55600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
557f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchSmsWrite (Parcel &p, RequestInfo *pRI) {
55800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_SMS_WriteArgs args;
55900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t t;
56000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
56100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
56200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset (&args, 0, sizeof(args));
56300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
56400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
56500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    args.status = (int)t;
56600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
56700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    args.pdu = strdupReadString(p);
56800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
56900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR || args.pdu == NULL) {
57000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
57100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
57200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
57300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    args.smsc = strdupReadString(p);
57400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
57500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
57600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%s%d,%s,smsc=%s", printBuf, args.status,
57700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        (char*)args.pdu,  (char*)args.smsc);
57800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
57900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
5807f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
58100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, &args, sizeof(args), pRI);
58200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
58300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
58400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memsetString (args.pdu);
58500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
58600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
58700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free (args.pdu);
5887f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
58900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
59000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset(&args, 0, sizeof(args));
59100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
59200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
59300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
59400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
59500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
59600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
59700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
59800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
5997f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/**
6007f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_Dial *
60100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is:
60200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   String address
60300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   int32_t clir
60400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
60500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
606f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchDial (Parcel &p, RequestInfo *pRI) {
60700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_Dial dial;
60874fa38884320698c1623764850e3131b9769dff0Wink Saville    RIL_UUS_Info uusInfo;
6097bce082edcee07339ebb06a35970b4b218ab8288Wink Saville    int32_t sizeOfDial;
61000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t t;
61174fa38884320698c1623764850e3131b9769dff0Wink Saville    int32_t uusPresent;
61200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
61300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
61400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset (&dial, 0, sizeof(dial));
61500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
61600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    dial.address = strdupReadString(p);
61700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
61800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
61900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    dial.clir = (int)t;
62000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
62100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR || dial.address == NULL) {
62200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
62300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
62400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6253a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville    if (s_callbacks.version < 3) { // Remove when partners upgrade to version 3
62674fa38884320698c1623764850e3131b9769dff0Wink Saville        uusPresent = 0;
6277bce082edcee07339ebb06a35970b4b218ab8288Wink Saville        sizeOfDial = sizeof(dial) - sizeof(RIL_UUS_Info *);
62874fa38884320698c1623764850e3131b9769dff0Wink Saville    } else {
62974fa38884320698c1623764850e3131b9769dff0Wink Saville        status = p.readInt32(&uusPresent);
63074fa38884320698c1623764850e3131b9769dff0Wink Saville
63174fa38884320698c1623764850e3131b9769dff0Wink Saville        if (status != NO_ERROR) {
63274fa38884320698c1623764850e3131b9769dff0Wink Saville            goto invalid;
63374fa38884320698c1623764850e3131b9769dff0Wink Saville        }
63474fa38884320698c1623764850e3131b9769dff0Wink Saville
63574fa38884320698c1623764850e3131b9769dff0Wink Saville        if (uusPresent == 0) {
63674fa38884320698c1623764850e3131b9769dff0Wink Saville            dial.uusInfo = NULL;
63774fa38884320698c1623764850e3131b9769dff0Wink Saville        } else {
63874fa38884320698c1623764850e3131b9769dff0Wink Saville            int32_t len;
63974fa38884320698c1623764850e3131b9769dff0Wink Saville
64074fa38884320698c1623764850e3131b9769dff0Wink Saville            memset(&uusInfo, 0, sizeof(RIL_UUS_Info));
64174fa38884320698c1623764850e3131b9769dff0Wink Saville
64274fa38884320698c1623764850e3131b9769dff0Wink Saville            status = p.readInt32(&t);
64374fa38884320698c1623764850e3131b9769dff0Wink Saville            uusInfo.uusType = (RIL_UUS_Type) t;
64474fa38884320698c1623764850e3131b9769dff0Wink Saville
64574fa38884320698c1623764850e3131b9769dff0Wink Saville            status = p.readInt32(&t);
64674fa38884320698c1623764850e3131b9769dff0Wink Saville            uusInfo.uusDcs = (RIL_UUS_DCS) t;
64774fa38884320698c1623764850e3131b9769dff0Wink Saville
64874fa38884320698c1623764850e3131b9769dff0Wink Saville            status = p.readInt32(&len);
64974fa38884320698c1623764850e3131b9769dff0Wink Saville            if (status != NO_ERROR) {
65074fa38884320698c1623764850e3131b9769dff0Wink Saville                goto invalid;
65174fa38884320698c1623764850e3131b9769dff0Wink Saville            }
65274fa38884320698c1623764850e3131b9769dff0Wink Saville
65374fa38884320698c1623764850e3131b9769dff0Wink Saville            // The java code writes -1 for null arrays
65474fa38884320698c1623764850e3131b9769dff0Wink Saville            if (((int) len) == -1) {
65574fa38884320698c1623764850e3131b9769dff0Wink Saville                uusInfo.uusData = NULL;
65674fa38884320698c1623764850e3131b9769dff0Wink Saville                len = 0;
65774fa38884320698c1623764850e3131b9769dff0Wink Saville            } else {
65874fa38884320698c1623764850e3131b9769dff0Wink Saville                uusInfo.uusData = (char*) p.readInplace(len);
65974fa38884320698c1623764850e3131b9769dff0Wink Saville            }
66074fa38884320698c1623764850e3131b9769dff0Wink Saville
66174fa38884320698c1623764850e3131b9769dff0Wink Saville            uusInfo.uusLength = len;
66274fa38884320698c1623764850e3131b9769dff0Wink Saville            dial.uusInfo = &uusInfo;
66374fa38884320698c1623764850e3131b9769dff0Wink Saville        }
6647bce082edcee07339ebb06a35970b4b218ab8288Wink Saville        sizeOfDial = sizeof(dial);
66574fa38884320698c1623764850e3131b9769dff0Wink Saville    }
66674fa38884320698c1623764850e3131b9769dff0Wink Saville
66700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
66800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%snum=%s,clir=%d", printBuf, dial.address, dial.clir);
66974fa38884320698c1623764850e3131b9769dff0Wink Saville    if (uusPresent) {
67074fa38884320698c1623764850e3131b9769dff0Wink Saville        appendPrintBuf("%s,uusType=%d,uusDcs=%d,uusLen=%d", printBuf,
67174fa38884320698c1623764850e3131b9769dff0Wink Saville                dial.uusInfo->uusType, dial.uusInfo->uusDcs,
67274fa38884320698c1623764850e3131b9769dff0Wink Saville                dial.uusInfo->uusLength);
67374fa38884320698c1623764850e3131b9769dff0Wink Saville    }
67400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
67500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
67600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6777bce082edcee07339ebb06a35970b4b218ab8288Wink Saville    s_callbacks.onRequest(pRI->pCI->requestNumber, &dial, sizeOfDial, pRI);
67800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
67900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
68000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memsetString (dial.address);
68100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
68200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
68300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free (dial.address);
6847f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
68500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
68674fa38884320698c1623764850e3131b9769dff0Wink Saville    memset(&uusInfo, 0, sizeof(RIL_UUS_Info));
68700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset(&dial, 0, sizeof(dial));
68800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
68900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
69000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
69100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
69200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
69300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
69400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
69500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
6967f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/**
6977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_SIM_IO *
69800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is:
69900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   int32_t command
70000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   int32_t fileid
70100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   String path
70200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *   int32_t p1, p2, p3
7037f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville *   String data
7047f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville *   String pin2
705c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville *   String aidPtr
70600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
70700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
708f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchSIM_IO (Parcel &p, RequestInfo *pRI) {
709c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    union RIL_SIM_IO {
710c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        RIL_SIM_IO_v6 v6;
711c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        RIL_SIM_IO_v5 v5;
712c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    } simIO;
713c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville
71400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t t;
715c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    int size;
71600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
71700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
71800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset (&simIO, 0, sizeof(simIO));
71900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
7207f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    // note we only check status at the end
7217f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
72200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
723c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.command = (int)t;
72400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
72500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
726c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.fileid = (int)t;
72700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
728c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.path = strdupReadString(p);
72900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
73000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
731c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.p1 = (int)t;
73200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
73300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
734c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.p2 = (int)t;
73500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
73600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
737c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.p3 = (int)t;
73800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
739c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.data = strdupReadString(p);
740c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.pin2 = strdupReadString(p);
741c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    simIO.v6.aidPtr = strdupReadString(p);
74200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
74300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
744c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    appendPrintBuf("%scmd=0x%X,efid=0x%X,path=%s,%d,%d,%d,%s,pin2=%s,aid=%s", printBuf,
745c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        simIO.v6.command, simIO.v6.fileid, (char*)simIO.v6.path,
746c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        simIO.v6.p1, simIO.v6.p2, simIO.v6.p3,
747c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        (char*)simIO.v6.data,  (char*)simIO.v6.pin2, simIO.v6.aidPtr);
74800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
74900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
7507f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
75100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR) {
75200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
75300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
75400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
755c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    size = (s_callbacks.version < 6) ? sizeof(simIO.v5) : sizeof(simIO.v6);
756c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    s_callbacks.onRequest(pRI->pCI->requestNumber, &simIO, size, pRI);
75700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
75800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
759c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    memsetString (simIO.v6.path);
760c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    memsetString (simIO.v6.data);
761c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    memsetString (simIO.v6.pin2);
762c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    memsetString (simIO.v6.aidPtr);
76300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
76400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
765c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    free (simIO.v6.path);
766c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    free (simIO.v6.data);
767c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    free (simIO.v6.pin2);
768c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    free (simIO.v6.aidPtr);
7697f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
77000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
77100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset(&simIO, 0, sizeof(simIO));
77200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
77300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
77400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
77500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
77600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
77700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
77800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
77900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
78000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/**
7812458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal * Callee expects const RIL_SIM_APDU *
7822458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal * Payload is:
7832458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal *   int32_t sessionid
7842458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal *   int32_t cla
7852458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal *   int32_t instruction
7862458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal *   int32_t p1, p2, p3
7872458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal *   String data
7882458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal */
7892458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawalstatic void
7902458d8d1e56faae7b00511ceeab19730572c22d9Shishir AgrawaldispatchSIM_APDU (Parcel &p, RequestInfo *pRI) {
7912458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    int32_t t;
7922458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status_t status;
7932458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    RIL_SIM_APDU apdu;
7942458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
7952458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    memset (&apdu, 0, sizeof(RIL_SIM_APDU));
7962458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
7972458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    // Note we only check status at the end. Any single failure leads to
7982458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    // subsequent reads filing.
7992458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8002458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.sessionid = (int)t;
8012458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8022458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8032458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.cla = (int)t;
8042458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8052458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8062458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.instruction = (int)t;
8072458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8082458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8092458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.p1 = (int)t;
8102458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8112458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8122458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.p2 = (int)t;
8132458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8142458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    status = p.readInt32(&t);
8152458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.p3 = (int)t;
8162458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8172458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    apdu.data = strdupReadString(p);
8182458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8192458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    startRequest;
8202458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    appendPrintBuf("%ssessionid=%d,cla=%d,ins=%d,p1=%d,p2=%d,p3=%d,data=%s",
8212458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        printBuf, apdu.sessionid, apdu.cla, apdu.instruction, apdu.p1, apdu.p2,
8222458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        apdu.p3, (char*)apdu.data);
8232458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    closeRequest;
8242458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    printRequest(pRI->token, pRI->pCI->requestNumber);
8252458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8262458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    if (status != NO_ERROR) {
8272458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        goto invalid;
8282458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    }
8292458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8302458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    s_callbacks.onRequest(pRI->pCI->requestNumber, &apdu, sizeof(RIL_SIM_APDU), pRI);
8312458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8322458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal#ifdef MEMSET_FREED
8332458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    memsetString(apdu.data);
8342458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal#endif
8352458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    free(apdu.data);
8362458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8372458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal#ifdef MEMSET_FREED
8382458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    memset(&apdu, 0, sizeof(RIL_SIM_APDU));
8392458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal#endif
8402458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8412458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    return;
8422458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawalinvalid:
8432458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    invalidCommandBlock(pRI);
8442458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal    return;
8452458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal}
8462458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8472458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal
8482458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal/**
84900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Callee expects const RIL_CallForwardInfo *
85000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is:
85100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  int32_t status/action
85200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  int32_t reason
85300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  int32_t serviceCode
85400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  int32_t toa
85500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  String number  (0 length -> null)
85600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *  int32_t timeSeconds
85700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
8587f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void
859f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCallForward(Parcel &p, RequestInfo *pRI) {
86000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_CallForwardInfo cff;
86100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t t;
86200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
86300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
86400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset (&cff, 0, sizeof(cff));
86500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
8667f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    // note we only check status at the end
86700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
86800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
86900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.status = (int)t;
8707f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
87100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
87200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.reason = (int)t;
87300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
87400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
87500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.serviceClass = (int)t;
87600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
87700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
87800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.toa = (int)t;
87900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
88000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.number = strdupReadString(p);
88100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
88200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&t);
88300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    cff.timeSeconds = (int)t;
88400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
88500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR) {
88600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
88700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
88800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
88900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // special case: number 0-length fields is null
89000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
89100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (cff.number != NULL && strlen (cff.number) == 0) {
89200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        cff.number = NULL;
89300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
89400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
89500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
89600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%sstat=%d,reason=%d,serv=%d,toa=%d,%s,tout=%d", printBuf,
89700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        cff.status, cff.reason, cff.serviceClass, cff.toa,
89800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        (char*)cff.number, cff.timeSeconds);
89900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
90000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
90100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
90200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, &cff, sizeof(cff), pRI);
90300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
90400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
90500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memsetString(cff.number);
90600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
90700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
90800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free (cff.number);
90900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
91000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED
91100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memset(&cff, 0, sizeof(cff));
91200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
91300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
91400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
91500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
91600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
91700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
91800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
91900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
92000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
9217f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void
922f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchRaw(Parcel &p, RequestInfo *pRI) {
92300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int32_t len;
92400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status_t status;
92500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    const void *data;
92600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
92700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    status = p.readInt32(&len);
92800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
92900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (status != NO_ERROR) {
93000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto invalid;
93100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
93200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
93300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // The java code writes -1 for null arrays
93400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (((int)len) == -1) {
93500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        data = NULL;
93600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        len = 0;
9377f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    }
93800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
93900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    data = p.readInplace(len);
94000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
94100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startRequest;
94200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%sraw_size=%d", printBuf, len);
94300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeRequest;
94400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printRequest(pRI->token, pRI->pCI->requestNumber);
94500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
94600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_callbacks.onRequest(pRI->pCI->requestNumber, const_cast<void *>(data), len, pRI);
94700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
94800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
94900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid:
95000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    invalidCommandBlock(pRI);
95100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
95200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
95300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
954a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic status_t
955a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya RajkhowaconstructCdmaSms(Parcel &p, RequestInfo *pRI, RIL_CDMA_SMS_Message& rcsm) {
956f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t  t;
957f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    uint8_t ut;
958f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status_t status;
959f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t digitCount;
960f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int digitLimit;
9617f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
962f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsm, 0, sizeof(rcsm));
963f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
964f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
965f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.uTeleserviceID = (int) t;
966f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
967f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&ut,sizeof(ut));
968f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.bIsServicePresent = (uint8_t) ut;
969f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
970f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
971f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.uServicecategory = (int) t;
972f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
973f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
974f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sAddress.digit_mode = (RIL_CDMA_SMS_DigitMode) t;
975f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
976f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
977f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sAddress.number_mode = (RIL_CDMA_SMS_NumberMode) t;
978f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
979f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
980f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sAddress.number_type = (RIL_CDMA_SMS_NumberType) t;
981f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
982f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
983f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sAddress.number_plan = (RIL_CDMA_SMS_NumberPlan) t;
984f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
985f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&ut,sizeof(ut));
986f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sAddress.number_of_digits= (uint8_t) ut;
987f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
988f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((rcsm.sAddress.number_of_digits), RIL_CDMA_SMS_ADDRESS_MAX);
989f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
990f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        status = p.read(&ut,sizeof(ut));
991f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsm.sAddress.digits[digitCount] = (uint8_t) ut;
992f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
993f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
9947f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    status = p.readInt32(&t);
995f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sSubAddress.subaddressType = (RIL_CDMA_SMS_SubaddressType) t;
996f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
9977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    status = p.read(&ut,sizeof(ut));
998f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sSubAddress.odd = (uint8_t) ut;
999f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1000f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&ut,sizeof(ut));
1001f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.sSubAddress.number_of_digits = (uint8_t) ut;
1002f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1003f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((rcsm.sSubAddress.number_of_digits), RIL_CDMA_SMS_SUBADDRESS_MAX);
10047f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
10057f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        status = p.read(&ut,sizeof(ut));
1006f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsm.sSubAddress.digits[digitCount] = (uint8_t) ut;
1007f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1008f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
10097f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    status = p.readInt32(&t);
1010f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsm.uBearerDataLen = (int) t;
1011f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1012f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((rcsm.uBearerDataLen), RIL_CDMA_SMS_BEARER_DATA_MAX);
10137f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
10147f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        status = p.read(&ut, sizeof(ut));
1015f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsm.aBearerData[digitCount] = (uint8_t) ut;
1016f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1017f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1018f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    if (status != NO_ERROR) {
1019a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        return status;
1020f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1021f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1022f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startRequest;
1023f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    appendPrintBuf("%suTeleserviceID=%d, bIsServicePresent=%d, uServicecategory=%d, \
10241b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            sAddress.digit_mode=%d, sAddress.Number_mode=%d, sAddress.number_type=%d, ",
1025f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            printBuf, rcsm.uTeleserviceID,rcsm.bIsServicePresent,rcsm.uServicecategory,
10261b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            rcsm.sAddress.digit_mode, rcsm.sAddress.number_mode,rcsm.sAddress.number_type);
1027f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    closeRequest;
10287f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
1029f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    printRequest(pRI->token, pRI->pCI->requestNumber);
1030f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1031a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return status;
1032a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa}
1033a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1034a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void
1035a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya RajkhowadispatchCdmaSms(Parcel &p, RequestInfo *pRI) {
1036a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    RIL_CDMA_SMS_Message rcsm;
1037a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1038a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    ALOGD("dispatchCdmaSms");
1039a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (NO_ERROR != constructCdmaSms(p, pRI, rcsm)) {
1040a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1041a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1042a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1043f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsm, sizeof(rcsm),pRI);
1044f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1045f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED
1046f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsm, 0, sizeof(rcsm));
1047f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
1048f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1049f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1050f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1051f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid:
1052f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    invalidCommandBlock(pRI);
1053f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1054f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
1055f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
10567f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void
1057a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya RajkhowadispatchImsCdmaSms(Parcel &p, RequestInfo *pRI, uint8_t retry, int32_t messageRef) {
1058a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    RIL_IMS_SMS_Message rism;
1059a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    RIL_CDMA_SMS_Message rcsm;
1060a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1061a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    ALOGD("dispatchImsCdmaSms: retry=%d, messageRef=%d", retry, messageRef);
1062a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1063a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (NO_ERROR != constructCdmaSms(p, pRI, rcsm)) {
1064a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1065a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1066a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    memset(&rism, 0, sizeof(rism));
1067a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.tech = RADIO_TECH_3GPP2;
1068a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.retry = retry;
1069a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.messageRef = messageRef;
1070a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.message.cdmaMessage = &rcsm;
1071a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1072a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    s_callbacks.onRequest(pRI->pCI->requestNumber, &rism,
1073a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            sizeof(RIL_RadioTechnologyFamily)+sizeof(uint8_t)+sizeof(int32_t)
1074a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            +sizeof(rcsm),pRI);
1075a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1076a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#ifdef MEMSET_FREED
1077a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    memset(&rcsm, 0, sizeof(rcsm));
1078a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    memset(&rism, 0, sizeof(rism));
1079a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#endif
1080a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1081a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1082a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1083a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowainvalid:
1084a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    invalidCommandBlock(pRI);
1085a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1086a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa}
1087a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1088a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void
1089a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya RajkhowadispatchImsGsmSms(Parcel &p, RequestInfo *pRI, uint8_t retry, int32_t messageRef) {
1090a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    RIL_IMS_SMS_Message rism;
1091a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    int32_t countStrings;
1092a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    status_t status;
1093a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    size_t datalen;
1094a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    char **pStrings;
1095a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    ALOGD("dispatchImsGsmSms: retry=%d, messageRef=%d", retry, messageRef);
1096a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1097a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    status = p.readInt32 (&countStrings);
1098a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1099a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (status != NO_ERROR) {
1100a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1101a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1102a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1103a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    memset(&rism, 0, sizeof(rism));
1104a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.tech = RADIO_TECH_3GPP;
1105a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.retry = retry;
1106a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.messageRef = messageRef;
1107a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1108a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    startRequest;
1109a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    appendPrintBuf("%sformat=%d,", printBuf, rism.format);
1110a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (countStrings == 0) {
1111a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        // just some non-null pointer
1112a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        pStrings = (char **)alloca(sizeof(char *));
1113a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        datalen = 0;
1114a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    } else if (((int)countStrings) == -1) {
1115a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        pStrings = NULL;
1116a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        datalen = 0;
1117a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    } else {
1118a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        datalen = sizeof(char *) * countStrings;
1119a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1120a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        pStrings = (char **)alloca(datalen);
1121a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1122a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        for (int i = 0 ; i < countStrings ; i++) {
1123a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            pStrings[i] = strdupReadString(p);
1124a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            appendPrintBuf("%s%s,", printBuf, pStrings[i]);
1125a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        }
1126a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1127a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    removeLastChar;
1128a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    closeRequest;
1129a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    printRequest(pRI->token, pRI->pCI->requestNumber);
1130a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1131a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    rism.message.gsmMessage = pStrings;
1132a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    s_callbacks.onRequest(pRI->pCI->requestNumber, &rism,
1133a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            sizeof(RIL_RadioTechnologyFamily)+sizeof(uint8_t)+sizeof(int32_t)
1134a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            +datalen, pRI);
1135a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1136a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (pStrings != NULL) {
1137a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        for (int i = 0 ; i < countStrings ; i++) {
1138a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#ifdef MEMSET_FREED
1139a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            memsetString (pStrings[i]);
1140a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#endif
1141a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa            free(pStrings[i]);
1142a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        }
1143a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1144a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#ifdef MEMSET_FREED
1145a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        memset(pStrings, 0, datalen);
1146a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#endif
1147a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1148a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1149a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#ifdef MEMSET_FREED
1150a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    memset(&rism, 0, sizeof(rism));
1151a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa#endif
1152a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1153a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowainvalid:
1154a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    ALOGE("dispatchImsGsmSms invalid block");
1155a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    invalidCommandBlock(pRI);
1156a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1157a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa}
1158a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1159a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void
1160a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya RajkhowadispatchImsSms(Parcel &p, RequestInfo *pRI) {
1161a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    int32_t  t;
1162a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    status_t status = p.readInt32(&t);
1163a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    RIL_RadioTechnologyFamily format;
1164a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    uint8_t retry;
1165a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    int32_t messageRef;
1166a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1167a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    ALOGD("dispatchImsSms");
1168a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (status != NO_ERROR) {
1169a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1170a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1171a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    format = (RIL_RadioTechnologyFamily) t;
1172a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1173a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    // read retry field
1174a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    status = p.read(&retry,sizeof(retry));
1175a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (status != NO_ERROR) {
1176a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1177a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1178a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    // read messageRef field
1179a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    status = p.read(&messageRef,sizeof(messageRef));
1180a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (status != NO_ERROR) {
1181a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        goto invalid;
1182a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1183a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1184a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    if (RADIO_TECH_3GPP == format) {
1185a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        dispatchImsGsmSms(p, pRI, retry, messageRef);
1186a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    } else if (RADIO_TECH_3GPP2 == format) {
1187a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        dispatchImsCdmaSms(p, pRI, retry, messageRef);
1188a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    } else {
1189a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        ALOGE("requestImsSendSMS invalid format value =%d", format);
1190a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    }
1191a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1192a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1193a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1194a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowainvalid:
1195a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    invalidCommandBlock(pRI);
1196a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa    return;
1197a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa}
1198a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa
1199a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowastatic void
1200f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCdmaSmsAck(Parcel &p, RequestInfo *pRI) {
1201f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    RIL_CDMA_SMS_Ack rcsa;
1202f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t  t;
1203f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status_t status;
1204f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t digitCount;
1205f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1206f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsa, 0, sizeof(rcsa));
1207f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1208f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1209f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsa.uErrorClass = (RIL_CDMA_SMS_ErrorClass) t;
1210f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1211f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1212f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsa.uSMSCauseCode = (int) t;
1213f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1214f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    if (status != NO_ERROR) {
1215f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        goto invalid;
1216f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1217f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1218f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startRequest;
12191b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville    appendPrintBuf("%suErrorClass=%d, uTLStatus=%d, ",
12201b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            printBuf, rcsa.uErrorClass, rcsa.uSMSCauseCode);
1221f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    closeRequest;
1222f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1223f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    printRequest(pRI->token, pRI->pCI->requestNumber);
1224f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1225f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsa, sizeof(rcsa),pRI);
1226f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1227f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED
1228f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsa, 0, sizeof(rcsa));
1229f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
1230f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1231f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1232f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1233f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid:
1234f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    invalidCommandBlock(pRI);
1235f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1236f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
1237f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1238a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void
1239a592eebc476a3d234f47f93e58252f8c822fc772Wink SavilledispatchGsmBrSmsCnf(Parcel &p, RequestInfo *pRI) {
1240a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int32_t t;
1241f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status_t status;
1242a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int32_t num;
1243f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1244a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    status = p.readInt32(&num);
1245a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    if (status != NO_ERROR) {
1246a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        goto invalid;
1247a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    }
1248f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
124996dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel    {
125096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        RIL_GSM_BroadcastSmsConfigInfo gsmBci[num];
125196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        RIL_GSM_BroadcastSmsConfigInfo *gsmBciPtrs[num];
1252f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
125396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        startRequest;
125496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        for (int i = 0 ; i < num ; i++ ) {
125596dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBciPtrs[i] = &gsmBci[i];
1256f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
125796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
125896dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBci[i].fromServiceId = (int) t;
1259f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
126096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
126196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBci[i].toServiceId = (int) t;
1262f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
126396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
126496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBci[i].fromCodeScheme = (int) t;
1265f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
126696dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
126796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBci[i].toCodeScheme = (int) t;
1268a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
126996dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
127096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            gsmBci[i].selected = (uint8_t) t;
1271a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
127296dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            appendPrintBuf("%s [%d: fromServiceId=%d, toServiceId =%d, \
127396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  fromCodeScheme=%d, toCodeScheme=%d, selected =%d]", printBuf, i,
127496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  gsmBci[i].fromServiceId, gsmBci[i].toServiceId,
127596dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  gsmBci[i].fromCodeScheme, gsmBci[i].toCodeScheme,
127696dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  gsmBci[i].selected);
127796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        }
127896dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        closeRequest;
1279f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
128096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        if (status != NO_ERROR) {
128196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            goto invalid;
128296dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        }
1283f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
128496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        s_callbacks.onRequest(pRI->pCI->requestNumber,
128596dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              gsmBciPtrs,
128696dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              num * sizeof(RIL_GSM_BroadcastSmsConfigInfo *),
128796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              pRI);
1288f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1289f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED
129096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        memset(gsmBci, 0, num * sizeof(RIL_GSM_BroadcastSmsConfigInfo));
129196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        memset(gsmBciPtrs, 0, num * sizeof(RIL_GSM_BroadcastSmsConfigInfo *));
1292f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
129396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel    }
1294f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1295f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1296f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1297f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid:
1298f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    invalidCommandBlock(pRI);
1299f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1300f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
1301f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1302a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void
1303f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCdmaBrSmsCnf(Parcel &p, RequestInfo *pRI) {
1304a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int32_t t;
1305f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status_t status;
1306a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int32_t num;
1307f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1308a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    status = p.readInt32(&num);
1309a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    if (status != NO_ERROR) {
1310a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        goto invalid;
1311a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    }
1312a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
131396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel    {
131496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        RIL_CDMA_BroadcastSmsConfigInfo cdmaBci[num];
131596dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        RIL_CDMA_BroadcastSmsConfigInfo *cdmaBciPtrs[num];
1316a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
131796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        startRequest;
131896dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        for (int i = 0 ; i < num ; i++ ) {
131996dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            cdmaBciPtrs[i] = &cdmaBci[i];
1320f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
132196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
132296dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            cdmaBci[i].service_category = (int) t;
1323f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville
132496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
132596dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            cdmaBci[i].language = (int) t;
1326f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville
132796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            status = p.readInt32(&t);
132896dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            cdmaBci[i].selected = (uint8_t) t;
1329f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
133096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            appendPrintBuf("%s [%d: service_category=%d, language =%d, \
133196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  entries.bSelected =%d]", printBuf, i, cdmaBci[i].service_category,
133296dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                  cdmaBci[i].language, cdmaBci[i].selected);
133396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        }
133496dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        closeRequest;
1335f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
133696dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        if (status != NO_ERROR) {
133796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel            goto invalid;
133896dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        }
1339f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
134096dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        s_callbacks.onRequest(pRI->pCI->requestNumber,
134196dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              cdmaBciPtrs,
134296dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo *),
134396dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel                              pRI);
1344f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1345f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED
134696dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        memset(cdmaBci, 0, num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo));
134796dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel        memset(cdmaBciPtrs, 0, num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo *));
1348f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
134996dcdbcfe5111346f1a1f4542a8533a0a6611c01Kevin Schoedel    }
1350f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1351f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1352f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1353f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid:
1354f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    invalidCommandBlock(pRI);
1355f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1356f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
1357f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1358f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchRilCdmaSmsWriteArgs(Parcel &p, RequestInfo *pRI) {
1359f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    RIL_CDMA_SMS_WriteArgs rcsw;
1360f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t  t;
1361f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    uint32_t ut;
1362f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    uint8_t  uct;
1363f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status_t status;
1364f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int32_t  digitCount;
1365f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1366f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsw, 0, sizeof(rcsw));
1367f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1368f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1369f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.status = t;
1370a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
1371f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1372f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.uTeleserviceID = (int) t;
1373f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1374f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&uct,sizeof(uct));
1375f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.bIsServicePresent = (uint8_t) uct;
1376f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1377f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1378f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.uServicecategory = (int) t;
1379f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1380f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1381f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sAddress.digit_mode = (RIL_CDMA_SMS_DigitMode) t;
1382f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1383f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1384f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sAddress.number_mode = (RIL_CDMA_SMS_NumberMode) t;
1385f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1386f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1387f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sAddress.number_type = (RIL_CDMA_SMS_NumberType) t;
1388f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1389f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.readInt32(&t);
1390f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sAddress.number_plan = (RIL_CDMA_SMS_NumberPlan) t;
1391f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1392f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&uct,sizeof(uct));
1393f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sAddress.number_of_digits = (uint8_t) uct;
1394f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1395f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_ADDRESS_MAX; digitCount ++) {
1396f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        status = p.read(&uct,sizeof(uct));
1397f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsw.message.sAddress.digits[digitCount] = (uint8_t) uct;
1398f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1399f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1400a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    status = p.readInt32(&t);
1401f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sSubAddress.subaddressType = (RIL_CDMA_SMS_SubaddressType) t;
1402f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1403a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    status = p.read(&uct,sizeof(uct));
1404f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sSubAddress.odd = (uint8_t) uct;
1405f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1406f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    status = p.read(&uct,sizeof(uct));
1407f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.sSubAddress.number_of_digits = (uint8_t) uct;
1408f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1409f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_SUBADDRESS_MAX; digitCount ++) {
1410a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        status = p.read(&uct,sizeof(uct));
1411f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsw.message.sSubAddress.digits[digitCount] = (uint8_t) uct;
1412f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1413f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1414a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    status = p.readInt32(&t);
1415f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    rcsw.message.uBearerDataLen = (int) t;
1416f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1417f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_BEARER_DATA_MAX; digitCount ++) {
1418a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        status = p.read(&uct, sizeof(uct));
1419f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        rcsw.message.aBearerData[digitCount] = (uint8_t) uct;
1420f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1421f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1422f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    if (status != NO_ERROR) {
1423f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        goto invalid;
1424f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
1425f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1426f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startRequest;
14271b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville    appendPrintBuf("%sstatus=%d, message.uTeleserviceID=%d, message.bIsServicePresent=%d, \
14281b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            message.uServicecategory=%d, message.sAddress.digit_mode=%d, \
14291b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            message.sAddress.number_mode=%d, \
14301b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            message.sAddress.number_type=%d, ",
1431f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            printBuf, rcsw.status, rcsw.message.uTeleserviceID, rcsw.message.bIsServicePresent,
14321b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            rcsw.message.uServicecategory, rcsw.message.sAddress.digit_mode,
14331b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            rcsw.message.sAddress.number_mode,
14341b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            rcsw.message.sAddress.number_type);
1435f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    closeRequest;
1436f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1437f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    printRequest(pRI->token, pRI->pCI->requestNumber);
1438f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1439f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsw, sizeof(rcsw),pRI);
1440f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1441f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED
1442f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    memset(&rcsw, 0, sizeof(rcsw));
1443f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
1444f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1445f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1446f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1447f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid:
1448f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    invalidCommandBlock(pRI);
1449f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return;
1450f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
1451f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
1452f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
14534f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti// For backwards compatibility in RIL_REQUEST_SETUP_DATA_CALL.
14544f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti// Version 4 of the RIL interface adds a new PDP type parameter to support
14554f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti// IPv6 and dual-stack PDP contexts. When dealing with a previous version of
14564f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti// RIL, remove the parameter from the request.
14574f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colittistatic void dispatchDataCall(Parcel& p, RequestInfo *pRI) {
14584f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    // In RIL v3, REQUEST_SETUP_DATA_CALL takes 6 parameters.
14594f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    const int numParamsRilV3 = 6;
14604f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti
14614f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    // The first bytes of the RIL parcel contain the request number and the
14624f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    // serial number - see processCommandBuffer(). Copy them over too.
14634f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    int pos = p.dataPosition();
14644f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti
14654f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    int numParams = p.readInt32();
14664f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    if (s_callbacks.version < 4 && numParams > numParamsRilV3) {
14674f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      Parcel p2;
14684f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      p2.appendFrom(&p, 0, pos);
14694f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      p2.writeInt32(numParamsRilV3);
14704f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      for(int i = 0; i < numParamsRilV3; i++) {
14714f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti        p2.writeString16(p.readString16());
14724f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      }
14734f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      p2.setDataPosition(pos);
14744f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      dispatchStrings(p2, pRI);
14754f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    } else {
147657ce1f2709484ef8911cabe9b5629d0c21557bd4Lorenzo Colitti      p.setDataPosition(pos);
14774f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti      dispatchStrings(p, pRI);
14784f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti    }
14794f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti}
14804f81dcf2a9bc84cbfbb6d3d658c452c22e9b6e83Lorenzo Colitti
14812bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// For backwards compatibility with RILs that dont support RIL_REQUEST_VOICE_RADIO_TECH.
14822bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// When all RILs handle this request, this function can be removed and
14832bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// the request can be sent directly to the RIL using dispatchVoid.
14842bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic void dispatchVoiceRadioTech(Parcel& p, RequestInfo *pRI) {
14852bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    RIL_RadioState state = s_callbacks.onStateRequest();
14862bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
14872bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if ((RADIO_STATE_UNAVAILABLE == state) || (RADIO_STATE_OFF == state)) {
14882bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_RADIO_NOT_AVAILABLE, NULL, 0);
14892bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
14902bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
14912bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // RILs that support RADIO_STATE_ON should support this request.
14922bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if (RADIO_STATE_ON == state) {
14932bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        dispatchVoid(p, pRI);
14942bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        return;
14952bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
14962bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
14972bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // For Older RILs, that do not support RADIO_STATE_ON, assume that they
14982bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // will not support this new request either and decode Voice Radio Technology
14992bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // from Radio State
15002bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    voiceRadioTech = decodeVoiceRadioTechnology(state);
15012bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15022bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if (voiceRadioTech < 0)
15032bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_GENERIC_FAILURE, NULL, 0);
15042bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    else
15052bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_SUCCESS, &voiceRadioTech, sizeof(int));
15062bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
15072bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15082bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// For backwards compatibility in RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE:.
15092bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// When all RILs handle this request, this function can be removed and
15102bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla// the request can be sent directly to the RIL using dispatchVoid.
15112bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic void dispatchCdmaSubscriptionSource(Parcel& p, RequestInfo *pRI) {
15122bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    RIL_RadioState state = s_callbacks.onStateRequest();
15132bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15142bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if ((RADIO_STATE_UNAVAILABLE == state) || (RADIO_STATE_OFF == state)) {
15152bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_RADIO_NOT_AVAILABLE, NULL, 0);
15162bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
15172bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15182bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // RILs that support RADIO_STATE_ON should support this request.
15192bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if (RADIO_STATE_ON == state) {
15202bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        dispatchVoid(p, pRI);
15212bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        return;
15222bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
15232bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15242bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // For Older RILs, that do not support RADIO_STATE_ON, assume that they
15252bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // will not support this new request either and decode CDMA Subscription Source
15262bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    // from Radio State
15272bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    cdmaSubscriptionSource = decodeCdmaSubscriptionSource(state);
15282bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
15292bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if (cdmaSubscriptionSource < 0)
15302bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_GENERIC_FAILURE, NULL, 0);
15312bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    else
15322bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        RIL_onRequestComplete(pRI, RIL_E_SUCCESS, &cdmaSubscriptionSource, sizeof(int));
15332bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
15342bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
153575697538e485ea2981960dcd4878bfdd032731acSungmin Choistatic void dispatchSetInitialAttachApn(Parcel &p, RequestInfo *pRI)
153675697538e485ea2981960dcd4878bfdd032731acSungmin Choi{
153775697538e485ea2981960dcd4878bfdd032731acSungmin Choi    RIL_InitialAttachApn pf;
153875697538e485ea2981960dcd4878bfdd032731acSungmin Choi    int32_t  t;
153975697538e485ea2981960dcd4878bfdd032731acSungmin Choi    status_t status;
154075697538e485ea2981960dcd4878bfdd032731acSungmin Choi
154175697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memset(&pf, 0, sizeof(pf));
154275697538e485ea2981960dcd4878bfdd032731acSungmin Choi
154375697538e485ea2981960dcd4878bfdd032731acSungmin Choi    pf.apn = strdupReadString(p);
154475697538e485ea2981960dcd4878bfdd032731acSungmin Choi    pf.protocol = strdupReadString(p);
154575697538e485ea2981960dcd4878bfdd032731acSungmin Choi
154675697538e485ea2981960dcd4878bfdd032731acSungmin Choi    status = p.readInt32(&t);
154775697538e485ea2981960dcd4878bfdd032731acSungmin Choi    pf.authtype = (int) t;
154875697538e485ea2981960dcd4878bfdd032731acSungmin Choi
154975697538e485ea2981960dcd4878bfdd032731acSungmin Choi    pf.username = strdupReadString(p);
155075697538e485ea2981960dcd4878bfdd032731acSungmin Choi    pf.password = strdupReadString(p);
155175697538e485ea2981960dcd4878bfdd032731acSungmin Choi
155275697538e485ea2981960dcd4878bfdd032731acSungmin Choi    startRequest;
155375697538e485ea2981960dcd4878bfdd032731acSungmin Choi    appendPrintBuf("%sapn=%s, protocol=%s, auth_type=%d, username=%s, password=%s",
155475697538e485ea2981960dcd4878bfdd032731acSungmin Choi            printBuf, pf.apn, pf.protocol, pf.auth_type, pf.username, pf.password);
155575697538e485ea2981960dcd4878bfdd032731acSungmin Choi    closeRequest;
155675697538e485ea2981960dcd4878bfdd032731acSungmin Choi    printRequest(pRI->token, pRI->pCI->requestNumber);
155775697538e485ea2981960dcd4878bfdd032731acSungmin Choi
155875697538e485ea2981960dcd4878bfdd032731acSungmin Choi    if (status != NO_ERROR) {
155975697538e485ea2981960dcd4878bfdd032731acSungmin Choi        goto invalid;
156075697538e485ea2981960dcd4878bfdd032731acSungmin Choi    }
156175697538e485ea2981960dcd4878bfdd032731acSungmin Choi    s_callbacks.onRequest(pRI->pCI->requestNumber, &pf, sizeof(pf), pRI);
156275697538e485ea2981960dcd4878bfdd032731acSungmin Choi
156375697538e485ea2981960dcd4878bfdd032731acSungmin Choi#ifdef MEMSET_FREED
156475697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memsetString(pf.apn);
156575697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memsetString(pf.protocol);
156675697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memsetString(pf.username);
156775697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memsetString(pf.password);
156875697538e485ea2981960dcd4878bfdd032731acSungmin Choi#endif
156975697538e485ea2981960dcd4878bfdd032731acSungmin Choi
157075697538e485ea2981960dcd4878bfdd032731acSungmin Choi    free(pf.apn);
157175697538e485ea2981960dcd4878bfdd032731acSungmin Choi    free(pf.protocol);
157275697538e485ea2981960dcd4878bfdd032731acSungmin Choi    free(pf.username);
157375697538e485ea2981960dcd4878bfdd032731acSungmin Choi    free(pf.password);
157475697538e485ea2981960dcd4878bfdd032731acSungmin Choi
157575697538e485ea2981960dcd4878bfdd032731acSungmin Choi#ifdef MEMSET_FREED
157675697538e485ea2981960dcd4878bfdd032731acSungmin Choi    memset(&pf, 0, sizeof(pf));
157775697538e485ea2981960dcd4878bfdd032731acSungmin Choi#endif
157875697538e485ea2981960dcd4878bfdd032731acSungmin Choi
157975697538e485ea2981960dcd4878bfdd032731acSungmin Choi    return;
158075697538e485ea2981960dcd4878bfdd032731acSungmin Choiinvalid:
158175697538e485ea2981960dcd4878bfdd032731acSungmin Choi    invalidCommandBlock(pRI);
158275697538e485ea2981960dcd4878bfdd032731acSungmin Choi    return;
158375697538e485ea2981960dcd4878bfdd032731acSungmin Choi}
158475697538e485ea2981960dcd4878bfdd032731acSungmin Choi
158500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int
1586f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleblockingWrite(int fd, const void *buffer, size_t len) {
15877f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    size_t writeOffset = 0;
158800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    const uint8_t *toWrite;
158900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
159000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    toWrite = (const uint8_t *)buffer;
159100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
159200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    while (writeOffset < len) {
159300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        ssize_t written;
159400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        do {
159500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            written = write (fd, toWrite + writeOffset,
159600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                len - writeOffset);
1597388849057a8cc91dbc3fff357d2df524ffec9a4dBanavathu, Srinivas Naik        } while (written < 0 && ((errno == EINTR) || (errno == EAGAIN)));
159800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
159900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (written >= 0) {
160000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            writeOffset += written;
160100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        } else {   // written < 0
16028eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE ("RIL Response: unexpected error on write errno:%d", errno);
160300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            close(fd);
160400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            return -1;
160500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
160600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
160700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
160800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
160900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
161000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
161100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int
1612f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillesendResponseRaw (const void *data, size_t dataSize) {
161300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int fd = s_fdCommand;
161400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
161500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    uint32_t header;
161600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
161700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_fdCommand < 0) {
161800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return -1;
161900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
162000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
162100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (dataSize > MAX_COMMAND_BYTES) {
16228eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("RIL: packet larger than %u (%u)",
162300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                MAX_COMMAND_BYTES, (unsigned int )dataSize);
162400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
162500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return -1;
162600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
16277f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
162800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_lock(&s_writeMutex);
162900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
163000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    header = htonl(dataSize);
163100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
163200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = blockingWrite(fd, (void *)&header, sizeof(header));
163300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
163400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
1635084f6708312265b501561a9c6d6e9cb38943985cJaikumar Ganesh        pthread_mutex_unlock(&s_writeMutex);
163600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return ret;
163700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
163800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1639ee1fadc192a63724e416b05666844a62d1e75d38Kenny    ret = blockingWrite(fd, data, dataSize);
164000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
164100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
1642084f6708312265b501561a9c6d6e9cb38943985cJaikumar Ganesh        pthread_mutex_unlock(&s_writeMutex);
164300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return ret;
164400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
164500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
164600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_unlock(&s_writeMutex);
164700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
164800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
164900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
165000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
165100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int
1652f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillesendResponse (Parcel &p) {
165300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    printResponse;
165400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return sendResponseRaw(p.data(), p.dataSize());
165500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
165600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
165700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** response is an int* pointing to an array of ints*/
16587f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
16597f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic int
1660f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleresponseInts(Parcel &p, void *response, size_t responselen) {
166100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int numInts;
166200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
166300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
16648eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
166500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
166600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
166700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen % sizeof(int) != 0) {
16688eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d\n",
166900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (int)responselen, (int)sizeof(int));
167000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
167100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
167200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
167300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int *p_int = (int *) response;
167400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
167500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    numInts = responselen / sizeof(int *);
167600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32 (numInts);
167700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
167800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* each int*/
167900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
168000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0 ; i < numInts ; i++) {
168100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        appendPrintBuf("%s%d,", printBuf, p_int[i]);
168200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_int[i]);
168300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
168400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
168500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
168600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
168700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
168800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
168900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
16904380897c6cdc99486a061b819943e3b290ebcf09Wink Saville/** response is a char **, pointing to an array of char *'s
16914380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    The parcel will begin with the version */
16924380897c6cdc99486a061b819943e3b290ebcf09Wink Savillestatic int responseStringsWithVersion(int version, Parcel &p, void *response, size_t responselen) {
16934380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    p.writeInt32(version);
16944380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    return responseStrings(p, response, responselen);
16954380897c6cdc99486a061b819943e3b290ebcf09Wink Saville}
16964380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
169700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** response is a char **, pointing to an array of char *'s */
1698f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseStrings(Parcel &p, void *response, size_t responselen) {
169900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int numStrings;
17007f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
170100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
17028eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
170300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
170400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
170500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen % sizeof(char *) != 0) {
17068eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d\n",
170700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (int)responselen, (int)sizeof(char *));
170800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
170900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
171000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
171100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL) {
171200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32 (0);
171300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
171400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        char **p_cur = (char **) response;
171500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
171600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        numStrings = responselen / sizeof(char *);
171700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32 (numStrings);
171800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
171900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* each string*/
172000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        startResponse;
172100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        for (int i = 0 ; i < numStrings ; i++) {
172200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            appendPrintBuf("%s%s,", printBuf, (char*)p_cur[i]);
172300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            writeStringToParcel (p, p_cur[i]);
172400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
172500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        removeLastChar;
172600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        closeResponse;
172700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
172800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
172900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
173000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
173100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
173200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/**
17337f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * NULL strings are accepted
173400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * FIXME currently ignores responselen
173500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
1736f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseString(Parcel &p, void *response, size_t responselen) {
173700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* one string only */
173800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
173900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%s%s", printBuf, (char*)response);
174000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
174100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
174200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    writeStringToParcel(p, (const char *)response);
174300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
174400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
174500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
174600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1747f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseVoid(Parcel &p, void *response, size_t responselen) {
174800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
174900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
175000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
175100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
175200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1753f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCallList(Parcel &p, void *response, size_t responselen) {
175400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int num;
175500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
175600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
17578eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
175800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
175900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
176000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
176100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen % sizeof (RIL_Call *) != 0) {
17628eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d\n",
176300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (int)responselen, (int)sizeof (RIL_Call *));
176400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
176500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
176600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
176700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
176800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* number of call info's */
176900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    num = responselen / sizeof(RIL_Call *);
177000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(num);
177100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
177200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0 ; i < num ; i++) {
177300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        RIL_Call *p_cur = ((RIL_Call **) response)[i];
177400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* each call info */
177500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->state);
177600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->index);
177700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->toa);
177800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->isMpty);
177900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->isMT);
178000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->als);
178100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->isVoice);
17821b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville        p.writeInt32(p_cur->isVoicePrivacy);
17831b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville        writeStringToParcel(p, p_cur->number);
17841b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville        p.writeInt32(p_cur->numberPresentation);
17851b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville        writeStringToParcel(p, p_cur->name);
17861b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville        p.writeInt32(p_cur->namePresentation);
17873a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville        // Remove when partners upgrade to version 3
178874fa38884320698c1623764850e3131b9769dff0Wink Saville        if ((s_callbacks.version < 3) || (p_cur->uusInfo == NULL || p_cur->uusInfo->uusData == NULL)) {
178974fa38884320698c1623764850e3131b9769dff0Wink Saville            p.writeInt32(0); /* UUS Information is absent */
179074fa38884320698c1623764850e3131b9769dff0Wink Saville        } else {
179174fa38884320698c1623764850e3131b9769dff0Wink Saville            RIL_UUS_Info *uusInfo = p_cur->uusInfo;
179274fa38884320698c1623764850e3131b9769dff0Wink Saville            p.writeInt32(1); /* UUS Information is present */
179374fa38884320698c1623764850e3131b9769dff0Wink Saville            p.writeInt32(uusInfo->uusType);
179474fa38884320698c1623764850e3131b9769dff0Wink Saville            p.writeInt32(uusInfo->uusDcs);
179574fa38884320698c1623764850e3131b9769dff0Wink Saville            p.writeInt32(uusInfo->uusLength);
179674fa38884320698c1623764850e3131b9769dff0Wink Saville            p.write(uusInfo->uusData, uusInfo->uusLength);
179774fa38884320698c1623764850e3131b9769dff0Wink Saville        }
17983d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        appendPrintBuf("%s[id=%d,%s,toa=%d,",
17991b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            printBuf,
18001b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->index,
18011b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            callStateToString(p_cur->state),
18023d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->toa);
18033d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        appendPrintBuf("%s%s,%s,als=%d,%s,%s,",
18043d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            printBuf,
18051b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            (p_cur->isMpty)?"conf":"norm",
18061b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            (p_cur->isMT)?"mt":"mo",
18071b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->als,
18081b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            (p_cur->isVoice)?"voc":"nonvoc",
18093d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            (p_cur->isVoicePrivacy)?"evp":"noevp");
18103d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        appendPrintBuf("%s%s,cli=%d,name='%s',%d]",
18113d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            printBuf,
18121b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->number,
18131b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->numberPresentation,
18141b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->name,
18151b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            p_cur->namePresentation);
181600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
181700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
181800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
181900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
182000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
182100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
182200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1823f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSMS(Parcel &p, void *response, size_t responselen) {
182400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL) {
18258eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
182600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
182700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
182800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
182900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen != sizeof (RIL_SMS_Response) ) {
18308eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected %d",
183100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                (int)responselen, (int)sizeof (RIL_SMS_Response));
183200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
183300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
183400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
183500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_SMS_Response *p_cur = (RIL_SMS_Response *) response;
183600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
183700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->messageRef);
183800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    writeStringToParcel(p, p_cur->ackPDU);
1839920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh    p.writeInt32(p_cur->errorCode);
184000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
184100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
1842920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh    appendPrintBuf("%s%d,%s,%d", printBuf, p_cur->messageRef,
1843920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh        (char*)p_cur->ackPDU, p_cur->errorCode);
184400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
184500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
184600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
184700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
184800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1849c0114b325877907fcdf7a5baa24e54a752e7e58bWink Savillestatic int responseDataCallListV4(Parcel &p, void *response, size_t responselen)
185000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{
185100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
18528eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
185300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
185400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
185500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1856c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    if (responselen % sizeof(RIL_Data_Call_Response_v4) != 0) {
18578eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d",
1858c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                (int)responselen, (int)sizeof(RIL_Data_Call_Response_v4));
185900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
186000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
186100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1862c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    int num = responselen / sizeof(RIL_Data_Call_Response_v4);
186300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(num);
186400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1865c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    RIL_Data_Call_Response_v4 *p_cur = (RIL_Data_Call_Response_v4 *) response;
186600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
186700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int i;
186800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (i = 0; i < num; i++) {
186900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur[i].cid);
187000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur[i].active);
187100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        writeStringToParcel(p, p_cur[i].type);
1872c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        // apn is not used, so don't send.
187300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        writeStringToParcel(p, p_cur[i].address);
1874c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        appendPrintBuf("%s[cid=%d,%s,%s,%s],", printBuf,
187500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            p_cur[i].cid,
187600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (p_cur[i].active==0)?"down":"up",
187700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (char*)p_cur[i].type,
187800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (char*)p_cur[i].address);
187900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
188000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
188100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
188200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
188300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
188400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
188500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
18864380897c6cdc99486a061b819943e3b290ebcf09Wink Savillestatic int responseDataCallList(Parcel &p, void *response, size_t responselen)
18874380897c6cdc99486a061b819943e3b290ebcf09Wink Saville{
18884380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    // Write version
18894380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    p.writeInt32(s_callbacks.version);
18904380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
18914380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    if (s_callbacks.version < 5) {
1892c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        return responseDataCallListV4(p, response, responselen);
18934380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    } else {
18944380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        if (response == NULL && responselen != 0) {
18958eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE("invalid response: NULL");
18964380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            return RIL_ERRNO_INVALID_RESPONSE;
18974380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        }
18984380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
1899c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        if (responselen % sizeof(RIL_Data_Call_Response_v6) != 0) {
19008eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE("invalid response length %d expected multiple of %d",
1901c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                    (int)responselen, (int)sizeof(RIL_Data_Call_Response_v6));
19024380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            return RIL_ERRNO_INVALID_RESPONSE;
19034380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        }
19044380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
1905c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        int num = responselen / sizeof(RIL_Data_Call_Response_v6);
19064380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        p.writeInt32(num);
19074380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
1908c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        RIL_Data_Call_Response_v6 *p_cur = (RIL_Data_Call_Response_v6 *) response;
19094380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        startResponse;
19104380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        int i;
19114380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        for (i = 0; i < num; i++) {
19124380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            p.writeInt32((int)p_cur[i].status);
1913beb25b58dcb48a2cfa2cfe10f5fb15908ff465f8Kazuhiro Ondo            p.writeInt32(p_cur[i].suggestedRetryTime);
19144380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            p.writeInt32(p_cur[i].cid);
19154380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            p.writeInt32(p_cur[i].active);
1916af1298d72fd6a8b2d5bed7db15f6d181240fce83David 'Digit' Turner            writeStringToParcel(p, p_cur[i].type);
19174380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            writeStringToParcel(p, p_cur[i].ifname);
19184380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            writeStringToParcel(p, p_cur[i].addresses);
19194380897c6cdc99486a061b819943e3b290ebcf09Wink Saville            writeStringToParcel(p, p_cur[i].dnses);
1920c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            writeStringToParcel(p, p_cur[i].gateways);
192156384157f32856066ee9c1b77cbcf96d4ee90a98Naveen Kalla            appendPrintBuf("%s[status=%d,retry=%d,cid=%d,%s,%s,%s,%s,%s,%s],", printBuf,
19224380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                p_cur[i].status,
1923beb25b58dcb48a2cfa2cfe10f5fb15908ff465f8Kazuhiro Ondo                p_cur[i].suggestedRetryTime,
19244380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                p_cur[i].cid,
19254380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                (p_cur[i].active==0)?"down":"up",
192656384157f32856066ee9c1b77cbcf96d4ee90a98Naveen Kalla                (char*)p_cur[i].type,
19274380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                (char*)p_cur[i].ifname,
19284380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                (char*)p_cur[i].addresses,
1929c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                (char*)p_cur[i].dnses,
1930c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                (char*)p_cur[i].gateways);
19314380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        }
19324380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        removeLastChar;
19334380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        closeResponse;
19344380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    }
19354380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
19364380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    return 0;
19374380897c6cdc99486a061b819943e3b290ebcf09Wink Saville}
19384380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
19394380897c6cdc99486a061b819943e3b290ebcf09Wink Savillestatic int responseSetupDataCall(Parcel &p, void *response, size_t responselen)
19404380897c6cdc99486a061b819943e3b290ebcf09Wink Saville{
19414380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    if (s_callbacks.version < 5) {
19424380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        return responseStringsWithVersion(s_callbacks.version, p, response, responselen);
19434380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    } else {
19444380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        return responseDataCallList(p, response, responselen);
19454380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    }
19464380897c6cdc99486a061b819943e3b290ebcf09Wink Saville}
19474380897c6cdc99486a061b819943e3b290ebcf09Wink Saville
1948f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseRaw(Parcel &p, void *response, size_t responselen) {
194900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
19508eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL with responselen != 0");
195100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
195200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
195300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
195400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // The java code reads -1 size as null byte array
195500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL) {
19567f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        p.writeInt32(-1);
195700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
195800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(responselen);
195900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.write(response, responselen);
196000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
196100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
196200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
196300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
196400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
196500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1966f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSIM_IO(Parcel &p, void *response, size_t responselen) {
196700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL) {
19688eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
196900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
197000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
197100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
197200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen != sizeof (RIL_SIM_IO_Response) ) {
19738eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length was %d expected %d",
197400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                (int)responselen, (int)sizeof (RIL_SIM_IO_Response));
197500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
197600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
197700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
197800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_SIM_IO_Response *p_cur = (RIL_SIM_IO_Response *) response;
197900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->sw1);
198000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->sw2);
198100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    writeStringToParcel(p, p_cur->simResponse);
198200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
198300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
198400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%ssw1=0x%X,sw2=0x%X,%s", printBuf, p_cur->sw1, p_cur->sw2,
198500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        (char*)p_cur->simResponse);
198600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
198700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
198800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
198900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
199000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
199100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
1992f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCallForwards(Parcel &p, void *response, size_t responselen) {
199300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int num;
19947f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
199500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
19968eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
199700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
199800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
199900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
200000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen % sizeof(RIL_CallForwardInfo *) != 0) {
20018eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d",
200200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                (int)responselen, (int)sizeof(RIL_CallForwardInfo *));
200300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
200400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
200500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
200600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* number of call info's */
200700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    num = responselen / sizeof(RIL_CallForwardInfo *);
200800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(num);
200900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
201000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
201100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0 ; i < num ; i++) {
201200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        RIL_CallForwardInfo *p_cur = ((RIL_CallForwardInfo **) response)[i];
201300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
201400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->status);
201500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->reason);
201600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->serviceClass);
201700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->toa);
201800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        writeStringToParcel(p, p_cur->number);
201900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->timeSeconds);
202000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        appendPrintBuf("%s[%s,reason=%d,cls=%d,toa=%d,%s,tout=%d],", printBuf,
202100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (p_cur->status==1)?"enable":"disable",
202200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            p_cur->reason, p_cur->serviceClass, p_cur->toa,
202300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (char*)p_cur->number,
202400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            p_cur->timeSeconds);
202500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
202600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
202700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
20287f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
202900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
203000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
203100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2032f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSsn(Parcel &p, void *response, size_t responselen) {
203300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL) {
20348eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
203500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
203600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
203700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
203800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen != sizeof(RIL_SuppSvcNotification)) {
20398eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length was %d expected %d",
204000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                (int)responselen, (int)sizeof (RIL_SuppSvcNotification));
204100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
204200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
204300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
204400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_SuppSvcNotification *p_cur = (RIL_SuppSvcNotification *) response;
204500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->notificationType);
204600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->code);
204700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->index);
204800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(p_cur->type);
204900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    writeStringToParcel(p, p_cur->number);
205000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
205100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
205200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("%s%s,code=%d,id=%d,type=%d,%s", printBuf,
205300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        (p_cur->notificationType==0)?"mo":"mt",
205400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project         p_cur->code, p_cur->index, p_cur->type,
205500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        (char*)p_cur->number);
205600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
205700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
205800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
205900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
206000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
20613d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCellList(Parcel &p, void *response, size_t responselen) {
206200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int num;
206300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
206400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (response == NULL && responselen != 0) {
20658eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
206600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
206700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
206800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
206900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (responselen % sizeof (RIL_NeighboringCell *) != 0) {
20708eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d\n",
207100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            (int)responselen, (int)sizeof (RIL_NeighboringCell *));
207200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return RIL_ERRNO_INVALID_RESPONSE;
207300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
207400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
207500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    startResponse;
20763d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    /* number of records */
207700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    num = responselen / sizeof(RIL_NeighboringCell *);
207800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32(num);
207900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
208000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0 ; i < num ; i++) {
208100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        RIL_NeighboringCell *p_cur = ((RIL_NeighboringCell **) response)[i];
208200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
208300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32(p_cur->rssi);
208400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        writeStringToParcel (p, p_cur->cid);
208500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
208600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        appendPrintBuf("%s[cid=%s,rssi=%d],", printBuf,
208700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            p_cur->cid, p_cur->rssi);
208800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
208900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    removeLastChar;
209000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    closeResponse;
209100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
209200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return 0;
209300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
209400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
20953d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville/**
20963d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville * Marshall the signalInfoRecord into the parcel if it exists.
20973d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville */
2098a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void marshallSignalInfoRecord(Parcel &p,
2099a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            RIL_CDMA_SignalInfoRecord &p_signalInfoRecord) {
21003d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    p.writeInt32(p_signalInfoRecord.isPresent);
21013d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    p.writeInt32(p_signalInfoRecord.signalType);
21023d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    p.writeInt32(p_signalInfoRecord.alertPitch);
21033d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    p.writeInt32(p_signalInfoRecord.signal);
21043d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
21053d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2106a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaInformationRecords(Parcel &p,
2107a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            void *response, size_t responselen) {
21083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    int num;
2109a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    char* string8 = NULL;
2110a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int buffer_lenght;
2111a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    RIL_CDMA_InformationRecord *infoRec;
21123d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
21133d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    if (response == NULL && responselen != 0) {
21148eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
21153d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
21163d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
21173d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2118a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    if (responselen != sizeof (RIL_CDMA_InformationRecords)) {
21198eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected multiple of %d\n",
2120a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            (int)responselen, (int)sizeof (RIL_CDMA_InformationRecords *));
21213d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
21223d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
21233d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2124a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    RIL_CDMA_InformationRecords *p_cur =
2125a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                             (RIL_CDMA_InformationRecords *) response;
2126a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    num = MIN(p_cur->numberOfInfoRecs, RIL_CDMA_MAX_NUMBER_OF_INFO_RECS);
21273d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
21283d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    startResponse;
2129a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    p.writeInt32(num);
21303d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2131a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    for (int i = 0 ; i < num ; i++) {
2132a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        infoRec = &p_cur->infoRec[i];
2133a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(infoRec->name);
2134a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        switch (infoRec->name) {
21353d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_DISPLAY_INFO_REC:
2136a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            case RIL_CDMA_EXTENDED_DISPLAY_INFO_REC:
2137a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                if (infoRec->rec.display.alpha_len >
2138a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                         CDMA_ALPHA_INFO_BUFFER_LENGTH) {
21398eb2a12cb7b525e74736300962a5f3848427275aWink Saville                    RLOGE("invalid display info response length %d \
2140a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                          expected not more than %d\n",
2141a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         (int)infoRec->rec.display.alpha_len,
2142a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         CDMA_ALPHA_INFO_BUFFER_LENGTH);
2143a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    return RIL_ERRNO_INVALID_RESPONSE;
21443d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                }
2145a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = (char*) malloc((infoRec->rec.display.alpha_len + 1)
2146a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                                             * sizeof(char) );
2147a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                for (int i = 0 ; i < infoRec->rec.display.alpha_len ; i++) {
2148a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    string8[i] = infoRec->rec.display.alpha_buf[i];
21493d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                }
21504380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                string8[(int)infoRec->rec.display.alpha_len] = '\0';
2151a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                writeStringToParcel(p, (const char*)string8);
2152a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                free(string8);
2153a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = NULL;
21543d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
2155a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            case RIL_CDMA_CALLED_PARTY_NUMBER_INFO_REC:
21563d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_CALLING_PARTY_NUMBER_INFO_REC:
21573d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_CONNECTED_NUMBER_INFO_REC:
2158a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                if (infoRec->rec.number.len > CDMA_NUMBER_INFO_BUFFER_LENGTH) {
21598eb2a12cb7b525e74736300962a5f3848427275aWink Saville                    RLOGE("invalid display info response length %d \
2160a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                          expected not more than %d\n",
2161a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         (int)infoRec->rec.number.len,
2162a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         CDMA_NUMBER_INFO_BUFFER_LENGTH);
2163a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    return RIL_ERRNO_INVALID_RESPONSE;
21643d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                }
2165a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = (char*) malloc((infoRec->rec.number.len + 1)
2166a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                                             * sizeof(char) );
2167a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                for (int i = 0 ; i < infoRec->rec.number.len; i++) {
2168a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    string8[i] = infoRec->rec.number.buf[i];
2169a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                }
21704380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                string8[(int)infoRec->rec.number.len] = '\0';
2171a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                writeStringToParcel(p, (const char*)string8);
2172a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                free(string8);
2173a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = NULL;
2174a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.number.number_type);
2175a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.number.number_plan);
2176a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.number.pi);
2177a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.number.si);
21783d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
21793d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_SIGNAL_INFO_REC:
2180a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.signal.isPresent);
2181a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.signal.signalType);
2182a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.signal.alertPitch);
2183a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.signal.signal);
2184a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
2185a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                appendPrintBuf("%sisPresent=%X, signalType=%X, \
2186a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                alertPitch=%X, signal=%X, ",
2187a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                   printBuf, (int)infoRec->rec.signal.isPresent,
2188a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                   (int)infoRec->rec.signal.signalType,
2189a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                   (int)infoRec->rec.signal.alertPitch,
2190a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                   (int)infoRec->rec.signal.signal);
2191a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                removeLastChar;
21923d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
21933d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_REDIRECTING_NUMBER_INFO_REC:
2194a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                if (infoRec->rec.redir.redirectingNumber.len >
2195a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                              CDMA_NUMBER_INFO_BUFFER_LENGTH) {
21968eb2a12cb7b525e74736300962a5f3848427275aWink Saville                    RLOGE("invalid display info response length %d \
2197a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                          expected not more than %d\n",
2198a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         (int)infoRec->rec.redir.redirectingNumber.len,
2199a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         CDMA_NUMBER_INFO_BUFFER_LENGTH);
2200a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    return RIL_ERRNO_INVALID_RESPONSE;
2201a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                }
2202a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = (char*) malloc((infoRec->rec.redir.redirectingNumber
2203a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                          .len + 1) * sizeof(char) );
2204a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                for (int i = 0;
2205a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         i < infoRec->rec.redir.redirectingNumber.len;
2206a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                         i++) {
2207a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    string8[i] = infoRec->rec.redir.redirectingNumber.buf[i];
22083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                }
22094380897c6cdc99486a061b819943e3b290ebcf09Wink Saville                string8[(int)infoRec->rec.redir.redirectingNumber.len] = '\0';
2210a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                writeStringToParcel(p, (const char*)string8);
2211a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                free(string8);
2212a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                string8 = NULL;
2213a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.redir.redirectingNumber.number_type);
2214a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.redir.redirectingNumber.number_plan);
2215a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.redir.redirectingNumber.pi);
2216a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.redir.redirectingNumber.si);
2217a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.redir.redirectingReason);
22183d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
22193d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_LINE_CONTROL_INFO_REC:
2220a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.lineCtrl.lineCtrlPolarityIncluded);
2221a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.lineCtrl.lineCtrlToggle);
2222a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.lineCtrl.lineCtrlReverse);
2223a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.lineCtrl.lineCtrlPowerDenial);
2224a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
2225a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                appendPrintBuf("%slineCtrlPolarityIncluded=%d, \
2226a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                lineCtrlToggle=%d, lineCtrlReverse=%d, \
2227a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                                lineCtrlPowerDenial=%d, ", printBuf,
2228a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                       (int)infoRec->rec.lineCtrl.lineCtrlPolarityIncluded,
2229a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                       (int)infoRec->rec.lineCtrl.lineCtrlToggle,
2230a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                       (int)infoRec->rec.lineCtrl.lineCtrlReverse,
2231a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                       (int)infoRec->rec.lineCtrl.lineCtrlPowerDenial);
2232a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                removeLastChar;
22333d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
22343d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_T53_CLIR_INFO_REC:
2235a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32((int)(infoRec->rec.clir.cause));
22363d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2237a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                appendPrintBuf("%scause%d", printBuf, infoRec->rec.clir.cause);
2238a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                removeLastChar;
22393d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
22403d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            case RIL_CDMA_T53_AUDIO_CONTROL_INFO_REC:
2241a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.audioCtrl.upLink);
2242a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p.writeInt32(infoRec->rec.audioCtrl.downLink);
2243a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
2244a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                appendPrintBuf("%supLink=%d, downLink=%d, ", printBuf,
2245a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                        infoRec->rec.audioCtrl.upLink,
2246a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                        infoRec->rec.audioCtrl.downLink);
2247a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                removeLastChar;
22483d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville                break;
2249a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            case RIL_CDMA_T53_RELEASE_INFO_REC:
2250a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                // TODO(Moto): See David Krause, he has the answer:)
22518eb2a12cb7b525e74736300962a5f3848427275aWink Saville                RLOGE("RIL_CDMA_T53_RELEASE_INFO_REC: return INVALID_RESPONSE");
2252a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                return RIL_ERRNO_INVALID_RESPONSE;
2253a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            default:
22548eb2a12cb7b525e74736300962a5f3848427275aWink Saville                RLOGE("Incorrect name value");
2255a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                return RIL_ERRNO_INVALID_RESPONSE;
22563d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        }
22573d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
2258a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    closeResponse;
22593d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2260a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    return 0;
22613d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
22623d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2263a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseRilSignalStrength(Parcel &p,
2264a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                    void *response, size_t responselen) {
2265a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    if (response == NULL && responselen != 0) {
22668eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
22673d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
22683d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
22693d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2270c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    if (responselen >= sizeof (RIL_SignalStrength_v5)) {
2271c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        RIL_SignalStrength_v6 *p_cur = ((RIL_SignalStrength_v6 *) response);
22723d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
22733d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->GW_SignalStrength.signalStrength);
22743d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->GW_SignalStrength.bitErrorRate);
22753d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->CDMA_SignalStrength.dbm);
22763d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->CDMA_SignalStrength.ecio);
22773d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->EVDO_SignalStrength.dbm);
22783d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->EVDO_SignalStrength.ecio);
22793d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        p.writeInt32(p_cur->EVDO_SignalStrength.signalNoiseRatio);
2280c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        if (responselen >= sizeof (RIL_SignalStrength_v6)) {
22819efcac5782b93564d47c1687e67e85849c72afedUma Maheswari Ramalingam            /*
228218e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville             * Fixup LTE for backwards compatibility
22839efcac5782b93564d47c1687e67e85849c72afedUma Maheswari Ramalingam             */
228418e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            if (s_callbacks.version <= 6) {
228518e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // signalStrength: -1 -> 99
228618e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                if (p_cur->LTE_SignalStrength.signalStrength == -1) {
228718e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                    p_cur->LTE_SignalStrength.signalStrength = 99;
228818e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                }
228918e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // rsrp: -1 -> INT_MAX all other negative value to positive.
229018e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // So remap here
229118e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                if (p_cur->LTE_SignalStrength.rsrp == -1) {
229218e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                    p_cur->LTE_SignalStrength.rsrp = INT_MAX;
229318e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                } else if (p_cur->LTE_SignalStrength.rsrp < -1) {
229418e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                    p_cur->LTE_SignalStrength.rsrp = -p_cur->LTE_SignalStrength.rsrp;
229518e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                }
229618e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // rsrq: -1 -> INT_MAX
229718e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                if (p_cur->LTE_SignalStrength.rsrq == -1) {
229818e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                    p_cur->LTE_SignalStrength.rsrq = INT_MAX;
229918e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                }
230018e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // Not remapping rssnr is already using INT_MAX
23019efcac5782b93564d47c1687e67e85849c72afedUma Maheswari Ramalingam
230218e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                // cqi: -1 -> INT_MAX
230318e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                if (p_cur->LTE_SignalStrength.cqi == -1) {
230418e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                    p_cur->LTE_SignalStrength.cqi = INT_MAX;
230518e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville                }
230618e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            }
230718e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(p_cur->LTE_SignalStrength.signalStrength);
2308c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p.writeInt32(p_cur->LTE_SignalStrength.rsrp);
2309c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p.writeInt32(p_cur->LTE_SignalStrength.rsrq);
2310c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p.writeInt32(p_cur->LTE_SignalStrength.rssnr);
2311c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p.writeInt32(p_cur->LTE_SignalStrength.cqi);
2312c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        } else {
231318e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(99);
231418e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(INT_MAX);
231518e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(INT_MAX);
231618e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(INT_MAX);
231718e4ab167c7d8549a360ab5ae1fadddcad8c0523Wink Saville            p.writeInt32(INT_MAX);
2318c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        }
2319fdf825f9d0dc639787b8523638bb61874ed0b540johnwang
2320fdf825f9d0dc639787b8523638bb61874ed0b540johnwang        startResponse;
2321a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        appendPrintBuf("%s[signalStrength=%d,bitErrorRate=%d,\
2322c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                CDMA_SS.dbm=%d,CDMA_SSecio=%d,\
2323c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                EVDO_SS.dbm=%d,EVDO_SS.ecio=%d,\
2324c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                EVDO_SS.signalNoiseRatio=%d,\
2325c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                LTE_SS.signalStrength=%d,LTE_SS.rsrp=%d,LTE_SS.rsrq=%d,\
2326c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                LTE_SS.rssnr=%d,LTE_SS.cqi=%d]",
2327a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                printBuf,
2328a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->GW_SignalStrength.signalStrength,
2329a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->GW_SignalStrength.bitErrorRate,
2330a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->CDMA_SignalStrength.dbm,
2331a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->CDMA_SignalStrength.ecio,
2332a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->EVDO_SignalStrength.dbm,
2333a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur->EVDO_SignalStrength.ecio,
2334c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->EVDO_SignalStrength.signalNoiseRatio,
2335c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->LTE_SignalStrength.signalStrength,
2336c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->LTE_SignalStrength.rsrp,
2337c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->LTE_SignalStrength.rsrq,
2338c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->LTE_SignalStrength.rssnr,
2339c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville                p_cur->LTE_SignalStrength.cqi);
2340a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        closeResponse;
2341a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
23423d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    } else {
23438eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length");
23443d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
23453d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23463d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23473d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    return 0;
23483d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
23493d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23503d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCallRing(Parcel &p, void *response, size_t responselen) {
23513d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    if ((response == NULL) || (responselen == 0)) {
23523d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return responseVoid(p, response, responselen);
23533d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    } else {
23543d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return responseCdmaSignalInfoRecord(p, response, responselen);
23553d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23563d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
23573d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23583d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaSignalInfoRecord(Parcel &p, void *response, size_t responselen) {
23593d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    if (response == NULL || responselen == 0) {
23608eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
23613d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
23623d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23633d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23643d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    if (responselen != sizeof (RIL_CDMA_SignalInfoRecord)) {
23658eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length %d expected sizeof (RIL_CDMA_SignalInfoRecord) of %d\n",
23663d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            (int)responselen, (int)sizeof (RIL_CDMA_SignalInfoRecord));
23673d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
23683d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23693d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23703d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    startResponse;
23713d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23723d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    RIL_CDMA_SignalInfoRecord *p_cur = ((RIL_CDMA_SignalInfoRecord *) response);
23733d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    marshallSignalInfoRecord(p, *p_cur);
23743d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23753d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    appendPrintBuf("%s[isPresent=%d,signalType=%d,alertPitch=%d\
23763d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              signal=%d]",
23773d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              printBuf,
23783d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              p_cur->isPresent,
23793d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              p_cur->signalType,
23803d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              p_cur->alertPitch,
23813d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville              p_cur->signal);
23823d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
23833d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    closeResponse;
23843d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    return 0;
23853d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
23863d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2387a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaCallWaiting(Parcel &p, void *response,
2388a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville            size_t responselen) {
23893d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    if (response == NULL && responselen != 0) {
23908eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
23913d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
23923d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23933d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2394c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    if (responselen < sizeof(RIL_CDMA_CallWaiting_v6)) {
23958eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGW("Upgrade to ril version %d\n", RIL_VERSION);
23963d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    }
23973d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2398c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    RIL_CDMA_CallWaiting_v6 *p_cur = ((RIL_CDMA_CallWaiting_v6 *) response);
23993d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2400c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    writeStringToParcel(p, p_cur->number);
24013d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    p.writeInt32(p_cur->numberPresentation);
2402c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    writeStringToParcel(p, p_cur->name);
24033d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    marshallSignalInfoRecord(p, p_cur->signalInfoRecord);
24043d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
2405c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    if (responselen >= sizeof(RIL_CDMA_CallWaiting_v6)) {
2406c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(p_cur->number_type);
2407c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(p_cur->number_plan);
2408c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    } else {
2409c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(0);
2410c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(0);
2411c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    }
2412c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville
2413c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville    startResponse;
24143d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    appendPrintBuf("%snumber=%s,numberPresentation=%d, name=%s,\
24153d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            signalInfoRecord[isPresent=%d,signalType=%d,alertPitch=%d\
2416c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            signal=%d,number_type=%d,number_plan=%d]",
24173d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            printBuf,
24183d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->number,
24193d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->numberPresentation,
24203d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->name,
24213d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->signalInfoRecord.isPresent,
24223d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->signalInfoRecord.signalType,
24233d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville            p_cur->signalInfoRecord.alertPitch,
2424c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p_cur->signalInfoRecord.signal,
2425c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p_cur->number_type,
2426c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            p_cur->number_plan);
24273d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    closeResponse;
24283d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
24293d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville    return 0;
24303d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
24313d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville
243245e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenkastatic int responseSimRefresh(Parcel &p, void *response, size_t responselen) {
243345e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    if (response == NULL && responselen != 0) {
24348eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("responseSimRefresh: invalid response: NULL");
243545e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        return RIL_ERRNO_INVALID_RESPONSE;
243645e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    }
243745e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka
243845e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    startResponse;
243945e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    if (s_callbacks.version == 7) {
244045e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        RIL_SimRefreshResponse_v7 *p_cur = ((RIL_SimRefreshResponse_v7 *) response);
244145e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        p.writeInt32(p_cur->result);
244245e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        p.writeInt32(p_cur->ef_id);
244345e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        writeStringToParcel(p, p_cur->aid);
244445e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka
244545e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        appendPrintBuf("%sresult=%d, ef_id=%d, aid=%s",
244645e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                printBuf,
244745e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                p_cur->result,
244845e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                p_cur->ef_id,
244945e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                p_cur->aid);
245045e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    } else {
245145e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        int *p_cur = ((int *) response);
245245e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        p.writeInt32(p_cur[0]);
245345e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        p.writeInt32(p_cur[1]);
245445e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        writeStringToParcel(p, NULL);
245545e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka
245645e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka        appendPrintBuf("%sresult=%d, ef_id=%d",
245745e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                printBuf,
245845e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                p_cur[0],
245945e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka                p_cur[1]);
246045e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    }
246145e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    closeResponse;
246245e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka
246345e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka    return 0;
246445e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka}
246545e740ef3c422bf75aadca21f98614fc120f49fbAlex Yakavenka
24668a9e02161271505de274db0c3a88087056dd5dfcWink Savillestatic int responseCellInfoList(Parcel &p, void *response, size_t responselen)
24678a9e02161271505de274db0c3a88087056dd5dfcWink Saville{
24688a9e02161271505de274db0c3a88087056dd5dfcWink Saville    if (response == NULL && responselen != 0) {
24698a9e02161271505de274db0c3a88087056dd5dfcWink Saville        RLOGE("invalid response: NULL");
24708a9e02161271505de274db0c3a88087056dd5dfcWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
24718a9e02161271505de274db0c3a88087056dd5dfcWink Saville    }
24728a9e02161271505de274db0c3a88087056dd5dfcWink Saville
24738a9e02161271505de274db0c3a88087056dd5dfcWink Saville    if (responselen % sizeof(RIL_CellInfo) != 0) {
24748a9e02161271505de274db0c3a88087056dd5dfcWink Saville        RLOGE("invalid response length %d expected multiple of %d",
24758a9e02161271505de274db0c3a88087056dd5dfcWink Saville                (int)responselen, (int)sizeof(RIL_CellInfo));
24768a9e02161271505de274db0c3a88087056dd5dfcWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
24778a9e02161271505de274db0c3a88087056dd5dfcWink Saville    }
24788a9e02161271505de274db0c3a88087056dd5dfcWink Saville
24798a9e02161271505de274db0c3a88087056dd5dfcWink Saville    int num = responselen / sizeof(RIL_CellInfo);
24808a9e02161271505de274db0c3a88087056dd5dfcWink Saville    p.writeInt32(num);
24818a9e02161271505de274db0c3a88087056dd5dfcWink Saville
24828a9e02161271505de274db0c3a88087056dd5dfcWink Saville    RIL_CellInfo *p_cur = (RIL_CellInfo *) response;
24838a9e02161271505de274db0c3a88087056dd5dfcWink Saville    startResponse;
24848a9e02161271505de274db0c3a88087056dd5dfcWink Saville    int i;
24858a9e02161271505de274db0c3a88087056dd5dfcWink Saville    for (i = 0; i < num; i++) {
24868a9e02161271505de274db0c3a88087056dd5dfcWink Saville        appendPrintBuf("%s[%d: type=%d,registered=%d,timeStampType=%d,timeStamp=%lld", printBuf, i,
24878a9e02161271505de274db0c3a88087056dd5dfcWink Saville            p_cur->cellInfoType, p_cur->registered, p_cur->timeStampType, p_cur->timeStamp);
24888a9e02161271505de274db0c3a88087056dd5dfcWink Saville        p.writeInt32((int)p_cur->cellInfoType);
24898a9e02161271505de274db0c3a88087056dd5dfcWink Saville        p.writeInt32(p_cur->registered);
24908a9e02161271505de274db0c3a88087056dd5dfcWink Saville        p.writeInt32(p_cur->timeStampType);
24918a9e02161271505de274db0c3a88087056dd5dfcWink Saville        p.writeInt64(p_cur->timeStamp);
24928a9e02161271505de274db0c3a88087056dd5dfcWink Saville        switch(p_cur->cellInfoType) {
24938a9e02161271505de274db0c3a88087056dd5dfcWink Saville            case RIL_CELL_INFO_TYPE_GSM: {
2494c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                appendPrintBuf("%s GSM id: mcc=%d,mnc=%d,lac=%d,cid=%d,", printBuf,
24958a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.gsm.cellIdentityGsm.mcc,
24968a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.gsm.cellIdentityGsm.mnc,
24978a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.gsm.cellIdentityGsm.lac,
2498c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.gsm.cellIdentityGsm.cid);
2499c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                appendPrintBuf("%s gsmSS: ss=%d,ber=%d],", printBuf,
25008a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.gsm.signalStrengthGsm.signalStrength,
25018a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.gsm.signalStrengthGsm.bitErrorRate);
25028a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25038a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.cellIdentityGsm.mcc);
25048a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.cellIdentityGsm.mnc);
25058a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.cellIdentityGsm.lac);
25068a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.cellIdentityGsm.cid);
25078a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.signalStrengthGsm.signalStrength);
25088a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.gsm.signalStrengthGsm.bitErrorRate);
25098a9e02161271505de274db0c3a88087056dd5dfcWink Saville                break;
25108a9e02161271505de274db0c3a88087056dd5dfcWink Saville            }
2511c57b3eb525db241bd3e6092453f48388bc880447Wink Saville            case RIL_CELL_INFO_TYPE_WCDMA: {
2512c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                appendPrintBuf("%s WCDMA id: mcc=%d,mnc=%d,lac=%d,cid=%d,psc=%d,", printBuf,
2513c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.cellIdentityWcdma.mcc,
2514c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.cellIdentityWcdma.mnc,
2515c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.cellIdentityWcdma.lac,
2516c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.cellIdentityWcdma.cid,
2517c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.cellIdentityWcdma.psc);
2518c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                appendPrintBuf("%s wcdmaSS: ss=%d,ber=%d],", printBuf,
2519c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.signalStrengthWcdma.signalStrength,
2520c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                    p_cur->CellInfo.wcdma.signalStrengthWcdma.bitErrorRate);
2521c57b3eb525db241bd3e6092453f48388bc880447Wink Saville
2522c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.cellIdentityWcdma.mcc);
2523c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.cellIdentityWcdma.mnc);
2524c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.cellIdentityWcdma.lac);
2525c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.cellIdentityWcdma.cid);
2526c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.cellIdentityWcdma.psc);
2527c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.signalStrengthWcdma.signalStrength);
2528c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                p.writeInt32(p_cur->CellInfo.wcdma.signalStrengthWcdma.bitErrorRate);
2529c57b3eb525db241bd3e6092453f48388bc880447Wink Saville                break;
2530c57b3eb525db241bd3e6092453f48388bc880447Wink Saville            }
25318a9e02161271505de274db0c3a88087056dd5dfcWink Saville            case RIL_CELL_INFO_TYPE_CDMA: {
25328a9e02161271505de274db0c3a88087056dd5dfcWink Saville                appendPrintBuf("%s CDMA id: nId=%d,sId=%d,bsId=%d,long=%d,lat=%d", printBuf,
25338a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.cellIdentityCdma.networkId,
25348a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.cellIdentityCdma.systemId,
25358a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.cellIdentityCdma.basestationId,
25368a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.cellIdentityCdma.longitude,
25378a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.cellIdentityCdma.latitude);
25388a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25398a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.cellIdentityCdma.networkId);
25408a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.cellIdentityCdma.systemId);
25418a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.cellIdentityCdma.basestationId);
25428a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.cellIdentityCdma.longitude);
25438a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.cellIdentityCdma.latitude);
25448a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25458a9e02161271505de274db0c3a88087056dd5dfcWink Saville                appendPrintBuf("%s cdmaSS: dbm=%d ecio=%d evdoSS: dbm=%d,ecio=%d,snr=%d", printBuf,
25468a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.signalStrengthCdma.dbm,
25478a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.signalStrengthCdma.ecio,
25488a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.signalStrengthEvdo.dbm,
25498a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.signalStrengthEvdo.ecio,
25508a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.cdma.signalStrengthEvdo.signalNoiseRatio);
25518a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25528a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.signalStrengthCdma.dbm);
25538a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.signalStrengthCdma.ecio);
25548a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.signalStrengthEvdo.dbm);
25558a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.signalStrengthEvdo.ecio);
25568a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.cdma.signalStrengthEvdo.signalNoiseRatio);
25578a9e02161271505de274db0c3a88087056dd5dfcWink Saville                break;
25588a9e02161271505de274db0c3a88087056dd5dfcWink Saville            }
25598a9e02161271505de274db0c3a88087056dd5dfcWink Saville            case RIL_CELL_INFO_TYPE_LTE: {
25608a9e02161271505de274db0c3a88087056dd5dfcWink Saville                appendPrintBuf("%s LTE id: mcc=%d,mnc=%d,ci=%d,pci=%d,tac=%d", printBuf,
25618a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.cellIdentityLte.mcc,
25628a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.cellIdentityLte.mnc,
25638a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.cellIdentityLte.ci,
25648a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.cellIdentityLte.pci,
25658a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.cellIdentityLte.tac);
25668a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25678a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.cellIdentityLte.mcc);
25688a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.cellIdentityLte.mnc);
25698a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.cellIdentityLte.ci);
25708a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.cellIdentityLte.pci);
25718a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.cellIdentityLte.tac);
25728a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25738a9e02161271505de274db0c3a88087056dd5dfcWink Saville                appendPrintBuf("%s lteSS: ss=%d,rsrp=%d,rsrq=%d,rssnr=%d,cqi=%d,ta=%d", printBuf,
25748a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.signalStrength,
25758a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.rsrp,
25768a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.rsrq,
25778a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.rssnr,
25788a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.cqi,
25798a9e02161271505de274db0c3a88087056dd5dfcWink Saville                    p_cur->CellInfo.lte.signalStrengthLte.timingAdvance);
25808a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.signalStrength);
25818a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.rsrp);
25828a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.rsrq);
25838a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.rssnr);
25848a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.cqi);
25858a9e02161271505de274db0c3a88087056dd5dfcWink Saville                p.writeInt32(p_cur->CellInfo.lte.signalStrengthLte.timingAdvance);
25868a9e02161271505de274db0c3a88087056dd5dfcWink Saville                break;
25878a9e02161271505de274db0c3a88087056dd5dfcWink Saville            }
25888a9e02161271505de274db0c3a88087056dd5dfcWink Saville        }
25898a9e02161271505de274db0c3a88087056dd5dfcWink Saville        p_cur += 1;
25908a9e02161271505de274db0c3a88087056dd5dfcWink Saville    }
25918a9e02161271505de274db0c3a88087056dd5dfcWink Saville    removeLastChar;
25928a9e02161271505de274db0c3a88087056dd5dfcWink Saville    closeResponse;
25938a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25948a9e02161271505de274db0c3a88087056dd5dfcWink Saville    return 0;
25958a9e02161271505de274db0c3a88087056dd5dfcWink Saville}
25968a9e02161271505de274db0c3a88087056dd5dfcWink Saville
25973d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic void triggerEvLoop() {
259800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
259900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (!pthread_equal(pthread_self(), s_tid_dispatch)) {
260000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* trigger event loop to wakeup. No reason to do this,
260100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project         * if we're in the event loop thread */
260200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project         do {
260300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ret = write (s_fdWakeupWrite, " ", 1);
260400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project         } while (ret < 0 && errno == EINTR);
260500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
260600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
260700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
26083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic void rilEventAddWakeup(struct ril_event *ev) {
260900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_add(ev);
261000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    triggerEvLoop();
261100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
261200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2613fd7293711394c422711ff07d15a357955ff2194fWink Savillestatic void sendSimStatusAppInfo(Parcel &p, int num_apps, RIL_AppStatus appStatus[]) {
2614fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(num_apps);
2615fd7293711394c422711ff07d15a357955ff2194fWink Saville        startResponse;
2616fd7293711394c422711ff07d15a357955ff2194fWink Saville        for (int i = 0; i < num_apps; i++) {
2617fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].app_type);
2618fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].app_state);
2619fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].perso_substate);
2620fd7293711394c422711ff07d15a357955ff2194fWink Saville            writeStringToParcel(p, (const char*)(appStatus[i].aid_ptr));
2621fd7293711394c422711ff07d15a357955ff2194fWink Saville            writeStringToParcel(p, (const char*)
2622fd7293711394c422711ff07d15a357955ff2194fWink Saville                                          (appStatus[i].app_label_ptr));
2623fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].pin1_replaced);
2624fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].pin1);
2625fd7293711394c422711ff07d15a357955ff2194fWink Saville            p.writeInt32(appStatus[i].pin2);
2626fd7293711394c422711ff07d15a357955ff2194fWink Saville            appendPrintBuf("%s[app_type=%d,app_state=%d,perso_substate=%d,\
2627fd7293711394c422711ff07d15a357955ff2194fWink Saville                    aid_ptr=%s,app_label_ptr=%s,pin1_replaced=%d,pin1=%d,pin2=%d],",
2628fd7293711394c422711ff07d15a357955ff2194fWink Saville                    printBuf,
2629fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].app_type,
2630fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].app_state,
2631fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].perso_substate,
2632fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].aid_ptr,
2633fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].app_label_ptr,
2634fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].pin1_replaced,
2635fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].pin1,
2636fd7293711394c422711ff07d15a357955ff2194fWink Saville                    appStatus[i].pin2);
2637fd7293711394c422711ff07d15a357955ff2194fWink Saville        }
2638fd7293711394c422711ff07d15a357955ff2194fWink Saville        closeResponse;
2639fd7293711394c422711ff07d15a357955ff2194fWink Saville}
2640fd7293711394c422711ff07d15a357955ff2194fWink Saville
2641f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSimStatus(Parcel &p, void *response, size_t responselen) {
2642f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int i;
2643f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2644f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    if (response == NULL && responselen != 0) {
26458eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
2646f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
2647f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2648f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
26492c1fb3a4e7aa8039bdefacceec98aa43cfe5784cWink Saville    if (responselen == sizeof (RIL_CardStatus_v6)) {
2650fd7293711394c422711ff07d15a357955ff2194fWink Saville        RIL_CardStatus_v6 *p_cur = ((RIL_CardStatus_v6 *) response);
2651fd7293711394c422711ff07d15a357955ff2194fWink Saville
2652fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->card_state);
2653fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->universal_pin_state);
2654fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->gsm_umts_subscription_app_index);
2655fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->cdma_subscription_app_index);
2656c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(p_cur->ims_subscription_app_index);
2657fd7293711394c422711ff07d15a357955ff2194fWink Saville
2658fd7293711394c422711ff07d15a357955ff2194fWink Saville        sendSimStatusAppInfo(p, p_cur->num_applications, p_cur->applications);
26592c1fb3a4e7aa8039bdefacceec98aa43cfe5784cWink Saville    } else if (responselen == sizeof (RIL_CardStatus_v5)) {
2660fd7293711394c422711ff07d15a357955ff2194fWink Saville        RIL_CardStatus_v5 *p_cur = ((RIL_CardStatus_v5 *) response);
2661fd7293711394c422711ff07d15a357955ff2194fWink Saville
2662fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->card_state);
2663fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->universal_pin_state);
2664fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->gsm_umts_subscription_app_index);
2665fd7293711394c422711ff07d15a357955ff2194fWink Saville        p.writeInt32(p_cur->cdma_subscription_app_index);
2666c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        p.writeInt32(-1);
2667f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2668fd7293711394c422711ff07d15a357955ff2194fWink Saville        sendSimStatusAppInfo(p, p_cur->num_applications, p_cur->applications);
26692c1fb3a4e7aa8039bdefacceec98aa43cfe5784cWink Saville    } else {
26708eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("responseSimStatus: A RilCardStatus_v6 or _v5 expected\n");
26712c1fb3a4e7aa8039bdefacceec98aa43cfe5784cWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
2672f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2673f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2674f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return 0;
26753d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville}
2676f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2677a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseGsmBrSmsCnf(Parcel &p, void *response, size_t responselen) {
2678a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int num = responselen / sizeof(RIL_GSM_BroadcastSmsConfigInfo *);
2679f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(num);
2680f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2681f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startResponse;
2682a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    RIL_GSM_BroadcastSmsConfigInfo **p_cur =
2683a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                (RIL_GSM_BroadcastSmsConfigInfo **) response;
2684a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    for (int i = 0; i < num; i++) {
2685a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->fromServiceId);
2686a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->toServiceId);
2687a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->fromCodeScheme);
2688a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->toCodeScheme);
2689a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->selected);
2690a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville
2691a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        appendPrintBuf("%s [%d: fromServiceId=%d, toServiceId=%d, \
2692a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                fromCodeScheme=%d, toCodeScheme=%d, selected =%d]",
2693a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                printBuf, i, p_cur[i]->fromServiceId, p_cur[i]->toServiceId,
2694a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur[i]->fromCodeScheme, p_cur[i]->toCodeScheme,
2695a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville                p_cur[i]->selected);
2696a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    }
2697f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    closeResponse;
2698f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2699f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return 0;
2700f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
2701f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2702a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaBrSmsCnf(Parcel &p, void *response, size_t responselen) {
2703a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    RIL_CDMA_BroadcastSmsConfigInfo **p_cur =
2704a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville               (RIL_CDMA_BroadcastSmsConfigInfo **) response;
2705f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2706a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    int num = responselen / sizeof (RIL_CDMA_BroadcastSmsConfigInfo *);
2707a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    p.writeInt32(num);
2708f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2709f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startResponse;
2710a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    for (int i = 0 ; i < num ; i++ ) {
2711a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->service_category);
2712a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->language);
2713a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        p.writeInt32(p_cur[i]->selected);
2714f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2715a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        appendPrintBuf("%s [%d: srvice_category=%d, language =%d, \
2716a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville              selected =%d], ",
2717a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville              printBuf, i, p_cur[i]->service_category, p_cur[i]->language,
2718a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville              p_cur[i]->selected);
2719f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville    }
2720a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville    closeResponse;
2721f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville
2722f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return 0;
2723f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
2724f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2725f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCdmaSms(Parcel &p, void *response, size_t responselen) {
2726f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int num;
2727f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int digitCount;
2728f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    int digitLimit;
2729f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    uint8_t uct;
2730f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    void* dest;
2731f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
27328eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGD("Inside responseCdmaSms");
2733f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville
2734f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    if (response == NULL && responselen != 0) {
27358eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response: NULL");
2736f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
2737f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2738f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2739f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville    if (responselen != sizeof(RIL_CDMA_SMS_Message)) {
27408eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("invalid response length was %d expected %d",
2741f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville                (int)responselen, (int)sizeof(RIL_CDMA_SMS_Message));
2742f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        return RIL_ERRNO_INVALID_RESPONSE;
2743f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2744f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2745f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    RIL_CDMA_SMS_Message *p_cur = (RIL_CDMA_SMS_Message *) response;
2746f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->uTeleserviceID);
2747f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.write(&(p_cur->bIsServicePresent),sizeof(uct));
2748f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->uServicecategory);
2749f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->sAddress.digit_mode);
2750f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->sAddress.number_mode);
2751f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->sAddress.number_type);
2752f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->sAddress.number_plan);
2753f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.write(&(p_cur->sAddress.number_of_digits), sizeof(uct));
2754f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((p_cur->sAddress.number_of_digits), RIL_CDMA_SMS_ADDRESS_MAX);
2755f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
2756f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        p.write(&(p_cur->sAddress.digits[digitCount]),sizeof(uct));
2757f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2758f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2759f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->sSubAddress.subaddressType);
2760f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.write(&(p_cur->sSubAddress.odd),sizeof(uct));
2761f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.write(&(p_cur->sSubAddress.number_of_digits),sizeof(uct));
2762f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((p_cur->sSubAddress.number_of_digits), RIL_CDMA_SMS_SUBADDRESS_MAX);
2763f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
2764f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        p.write(&(p_cur->sSubAddress.digits[digitCount]),sizeof(uct));
2765f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2766f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2767f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    digitLimit= MIN((p_cur->uBearerDataLen), RIL_CDMA_SMS_BEARER_DATA_MAX);
2768f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    p.writeInt32(p_cur->uBearerDataLen);
2769f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for(digitCount =0 ; digitCount < digitLimit; digitCount ++) {
2770f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville       p.write(&(p_cur->aBearerData[digitCount]), sizeof(uct));
2771f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    }
2772f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2773f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    startResponse;
2774f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    appendPrintBuf("%suTeleserviceID=%d, bIsServicePresent=%d, uServicecategory=%d, \
27751b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            sAddress.digit_mode=%d, sAddress.number_mode=%d, sAddress.number_type=%d, ",
2776f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            printBuf, p_cur->uTeleserviceID,p_cur->bIsServicePresent,p_cur->uServicecategory,
2777f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            p_cur->sAddress.digit_mode, p_cur->sAddress.number_mode,p_cur->sAddress.number_type);
2778f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    closeResponse;
2779f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
2780f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    return 0;
2781f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville}
2782f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
278300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/**
278400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * A write on the wakeup fd is done just to pop us out of select()
278500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * We empty the buffer here and then ril_event will reset the timers on the
278600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * way back down
278700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
2788f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void processWakeupCallback(int fd, short flags, void *param) {
278900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char buff[16];
279000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
279100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
27928eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGV("processWakeupCallback");
279300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
279400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* empty our wakeup socket out */
279500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    do {
279600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        ret = read(s_fdWakeupRead, &buff, sizeof(buff));
27977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    } while (ret > 0 || (ret < 0 && errno == EINTR));
279800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
279900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2800f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void onCommandsSocketClosed() {
280100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
280200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RequestInfo *p_cur;
280300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
280400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* mark pending requests as "cancelled" so we dont report responses */
280500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
280600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_lock(&s_pendingRequestsMutex);
280700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
280800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
280900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_cur = s_pendingRequests;
281000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
28117f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    for (p_cur = s_pendingRequests
281200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ; p_cur != NULL
281300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ; p_cur  = p_cur->p_next
281400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ) {
281500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p_cur->cancelled = 1;
281600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
281700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
281800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_mutex_unlock(&s_pendingRequestsMutex);
281900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (ret == 0);
282000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
282100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2822f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void processCommandsCallback(int fd, short flags, void *param) {
282300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RecordStream *p_rs;
282400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    void *p_record;
282500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t recordlen;
282600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
282700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
282800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert(fd == s_fdCommand);
282900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
283000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_rs = (RecordStream *)param;
283100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
283200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (;;) {
283300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* loop until EAGAIN/EINTR, end of stream, or other error */
283400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        ret = record_stream_get_next(p_rs, &p_record, &recordlen);
283500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
283600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (ret == 0 && p_record == NULL) {
283700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            /* end-of-stream */
283800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
283900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        } else if (ret < 0) {
284000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
284100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        } else if (ret == 0) { /* && p_record != NULL */
284200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            processCommandBuffer(p_record, recordlen);
284300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
284400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
284500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
284600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret == 0 || !(errno == EAGAIN || errno == EINTR)) {
284700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* fatal error or end-of-stream */
284800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (ret != 0) {
28498eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE("error on reading command socket errno:%d\n", errno);
285000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        } else {
28518eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGW("EOS.  Closing command socket.");
285200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
28537f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
285400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        close(s_fdCommand);
285500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_fdCommand = -1;
285600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
285700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        ril_event_del(&s_commands_event);
285800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
285900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        record_stream_free(p_rs);
286000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
286100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* start listening for new connections again */
286200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        rilEventAddWakeup(&s_listen_event);
286300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
286400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        onCommandsSocketClosed();
286500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
286600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
286700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
286800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2869f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void onNewCommandConnect() {
28705b9df33c53682addaebc0b6073901a8b441d82f9Wink Saville    // Inform we are connected and the ril version
2871a9c18d17769ee475cf4fd5e76e18ddfa4070c7cdJake Hamby    int rilVer = s_callbacks.version;
28725b9df33c53682addaebc0b6073901a8b441d82f9Wink Saville    RIL_onUnsolicitedResponse(RIL_UNSOL_RIL_CONNECTED,
28735b9df33c53682addaebc0b6073901a8b441d82f9Wink Saville                                    &rilVer, sizeof(rilVer));
28745b9df33c53682addaebc0b6073901a8b441d82f9Wink Saville
287500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // implicit radio state changed
287600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_onUnsolicitedResponse(RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED,
287700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                    NULL, 0);
287800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
287900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Send last NITZ time data, in case it was missed
288000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_lastNITZTimeData != NULL) {
288100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        sendResponseRaw(s_lastNITZTimeData, s_lastNITZTimeDataSize);
288200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
288300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        free(s_lastNITZTimeData);
288400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_lastNITZTimeData = NULL;
288500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
288600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
288700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Get version string
288800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_callbacks.getVersion != NULL) {
288900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        const char *version;
289000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        version = s_callbacks.getVersion();
28918eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGI("RIL Daemon version: %s\n", version);
28927f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
289300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        property_set(PROPERTY_RIL_IMPL, version);
289400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
28958eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGI("RIL Daemon version: unavailable\n");
289600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        property_set(PROPERTY_RIL_IMPL, "unavailable");
289700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
289800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
289900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
290000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2901f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void listenCallback (int fd, short flags, void *param) {
290200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
290300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int err;
290400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int is_phone_socket;
290500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RecordStream *p_rs;
290600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
290700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct sockaddr_un peeraddr;
290800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    socklen_t socklen = sizeof (peeraddr);
290900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
291000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct ucred creds;
291100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    socklen_t szCreds = sizeof(creds);
291200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
291300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct passwd *pwd = NULL;
291400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
291500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (s_fdCommand < 0);
291600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    assert (fd == s_fdListen);
29177f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
291800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdCommand = accept(s_fdListen, (sockaddr *) &peeraddr, &socklen);
291900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
292000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_fdCommand < 0 ) {
29218eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Error on accept() errno:%d", errno);
292200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* start listening for new connections again */
292300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        rilEventAddWakeup(&s_listen_event);
2924f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville	      return;
292500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
292600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
292700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* check the credential of the other side and only accept socket from
292800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project     * phone process
29297f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville     */
293000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    errno = 0;
293100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    is_phone_socket = 0;
2932f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
293300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    err = getsockopt(s_fdCommand, SOL_SOCKET, SO_PEERCRED, &creds, &szCreds);
2934f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville
293500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (err == 0 && szCreds > 0) {
2936f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        errno = 0;
2937f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        pwd = getpwuid(creds.uid);
2938f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        if (pwd != NULL) {
2939f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            if (strcmp(pwd->pw_name, PHONE_PROCESS) == 0) {
2940f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville                is_phone_socket = 1;
2941f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            } else {
29428eb2a12cb7b525e74736300962a5f3848427275aWink Saville                RLOGE("RILD can't accept socket from process %s", pwd->pw_name);
2943f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville            }
2944f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        } else {
29458eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE("Error on getpwuid() errno: %d", errno);
2946f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        }
294700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
29488eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGD("Error on getsockopt() errno: %d", errno);
294900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
295000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
295100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if ( !is_phone_socket ) {
29528eb2a12cb7b525e74736300962a5f3848427275aWink Saville      RLOGE("RILD must accept socket from %s", PHONE_PROCESS);
29537f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
295400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      close(s_fdCommand);
295500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      s_fdCommand = -1;
295600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
295700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      onCommandsSocketClosed();
295800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
295900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      /* start listening for new connections again */
296000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      rilEventAddWakeup(&s_listen_event);
296100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
296200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project      return;
296300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
296400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
296500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = fcntl(s_fdCommand, F_SETFL, O_NONBLOCK);
296600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
296700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
29688eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE ("Error setting O_NONBLOCK errno:%d", errno);
296900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
297000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
29718eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGI("libril: new connection");
297200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
297300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_rs = record_stream_new(s_fdCommand, MAX_COMMAND_BYTES);
297400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
29757f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    ril_event_set (&s_commands_event, s_fdCommand, 1,
297600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        processCommandsCallback, p_rs);
297700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
297800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    rilEventAddWakeup (&s_commands_event);
297900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
298000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    onNewCommandConnect();
298100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
298200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
298300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void freeDebugCallbackArgs(int number, char **args) {
298400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0; i < number; i++) {
298500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (args[i] != NULL) {
298600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            free(args[i]);
298700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
298800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
298900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free(args);
299000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
299100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
2992f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void debugCallback (int fd, short flags, void *param) {
299300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int acceptFD, option;
299400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct sockaddr_un peeraddr;
299500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    socklen_t socklen = sizeof (peeraddr);
299600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int data;
299700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    unsigned int qxdm_data[6];
299800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    const char *deactData[1] = {"1"};
299900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char *actData[1];
300000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RIL_Dial dialData;
300100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int hangupData[1] = {1};
300200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int number;
300300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    char **args;
300400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
300500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    acceptFD = accept (fd,  (sockaddr *) &peeraddr, &socklen);
300600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
300700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (acceptFD < 0) {
30088eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE ("error accepting on debug port: %d\n", errno);
300900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
301000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
301100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
301200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (recv(acceptFD, &number, sizeof(int), 0) != sizeof(int)) {
30138eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE ("error reading on socket: number of Args: \n");
301400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
301500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
301600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    args = (char **) malloc(sizeof(char*) * number);
301700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
301800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    for (int i = 0; i < number; i++) {
301900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        int len;
302000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (recv(acceptFD, &len, sizeof(int), 0) != sizeof(int)) {
30218eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE ("error reading on socket: Len of Args: \n");
302200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            freeDebugCallbackArgs(i, args);
302300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            return;
302400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
302500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // +1 for null-term
302600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        args[i] = (char *) malloc((sizeof(char) * len) + 1);
30277f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        if (recv(acceptFD, args[i], sizeof(char) * len, 0)
30281b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville            != (int)sizeof(char) * len) {
30298eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE ("error reading on socket: Args[%d] \n", i);
303000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            freeDebugCallbackArgs(i, args);
303100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            return;
303200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
303300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        char * buf = args[i];
303400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        buf[len] = 0;
303500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
303600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
303700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch (atoi(args[0])) {
303800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 0:
30398eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI ("Connection on debug port: issuing reset.");
304000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_RESET_RADIO, NULL, 0);
304100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
304200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 1:
30438eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI ("Connection on debug port: issuing radio power off.");
304400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            data = 0;
304500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_RADIO_POWER, &data, sizeof(int));
304600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // Close the socket
304700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            close(s_fdCommand);
304800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            s_fdCommand = -1;
304900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
305000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 2:
30518eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI ("Debug port: issuing unsolicited voice network change.");
3052c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville            RIL_onUnsolicitedResponse(RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED,
305300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                      NULL, 0);
305400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
305500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 3:
30568eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI ("Debug port: QXDM log enable.");
3057d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[0] = 65536;     // head.func_tag
3058d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[1] = 16;        // head.len
3059d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[2] = 1;         // mode: 1 for 'start logging'
3060d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[3] = 32;        // log_file_size: 32megabytes
3061d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[4] = 0;         // log_mask
3062d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[5] = 8;         // log_max_fileindex
30637f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville            issueLocalRequest(RIL_REQUEST_OEM_HOOK_RAW, qxdm_data,
306400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                              6 * sizeof(int));
306500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
306600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 4:
30678eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI ("Debug port: QXDM log disable.");
306800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            qxdm_data[0] = 65536;
306900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            qxdm_data[1] = 16;
3070d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[2] = 0;          // mode: 0 for 'stop logging'
307100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            qxdm_data[3] = 32;
307200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            qxdm_data[4] = 0;
3073d855ef4370e1185d79ecb3fb3434c9b5f84d15bdXia Wang            qxdm_data[5] = 8;
307400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_OEM_HOOK_RAW, qxdm_data,
307500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                              6 * sizeof(int));
307600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
307700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 5:
30788eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: Radio On");
307900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            data = 1;
308000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_RADIO_POWER, &data, sizeof(int));
308100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            sleep(2);
308200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // Set network selection automatic.
308300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC, NULL, 0);
308400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
308500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 6:
30868eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: Setup Data Call, Apn :%s\n", args[1]);
308700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            actData[0] = args[1];
30887f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville            issueLocalRequest(RIL_REQUEST_SETUP_DATA_CALL, &actData,
308900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                              sizeof(actData));
309000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
309100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 7:
30928eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: Deactivate Data Call");
30937f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville            issueLocalRequest(RIL_REQUEST_DEACTIVATE_DATA_CALL, &deactData,
309400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                              sizeof(deactData));
309500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
309600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 8:
30978eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: Dial Call");
309800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            dialData.clir = 0;
309900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            dialData.address = args[1];
310000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_DIAL, &dialData, sizeof(dialData));
310100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
310200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 9:
31038eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: Answer Call");
310400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            issueLocalRequest(RIL_REQUEST_ANSWER, NULL, 0);
310500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
310600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case 10:
31078eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGI("Debug port: End Call");
31087f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville            issueLocalRequest(RIL_REQUEST_HANGUP, &hangupData,
310900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                              sizeof(hangupData));
311000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
311100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default:
31128eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGE ("Invalid request");
311300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
311400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
311500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    freeDebugCallbackArgs(number, args);
311600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    close(acceptFD);
311700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
311800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
311900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3120f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void userTimerCallback (int fd, short flags, void *param) {
312100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    UserCallbackInfo *p_info;
312200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
312300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_info = (UserCallbackInfo *)param;
312400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
312500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_info->p_callback(p_info->userParam);
312600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
312700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
312800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // FIXME generalize this...there should be a cancel mechanism
312900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_last_wake_timeout_info != NULL && s_last_wake_timeout_info == p_info) {
313000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_last_wake_timeout_info = NULL;
313100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
313200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
313300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free(p_info);
313400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
313500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
313600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
313700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void *
3138f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleeventLoop(void *param) {
313900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
314000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int filedes[2];
314100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
314200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_init();
314300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
314400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_lock(&s_startupMutex);
314500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
314600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_started = 1;
314700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_cond_broadcast(&s_startupCond);
314800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
314900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_unlock(&s_startupMutex);
315000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
315100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pipe(filedes);
315200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
315300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
31548eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Error in pipe() errno:%d", errno);
315500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return NULL;
315600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
315700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
315800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdWakeupRead = filedes[0];
315900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdWakeupWrite = filedes[1];
316000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
316100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    fcntl(s_fdWakeupRead, F_SETFL, O_NONBLOCK);
316200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
316300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_set (&s_wakeupfd_event, s_fdWakeupRead, true,
316400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                processWakeupCallback, NULL);
316500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
316600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    rilEventAddWakeup (&s_wakeupfd_event);
316700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
316800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Only returns on error
316900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_loop();
31708eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGE ("error in event_loop_base errno:%d", errno);
31715cdc1354de1e1b98347fe67c5fefdb0be7e0f589Kazuhiro Ondo    // kill self to restart on error
31725cdc1354de1e1b98347fe67c5fefdb0be7e0f589Kazuhiro Ondo    kill(0, SIGKILL);
317300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
317400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return NULL;
317500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
317600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
31777f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void
3178f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_startEventLoop(void) {
317900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
318000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_attr_t attr;
31817f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
318200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* spin up eventLoop thread and wait for it to get started */
318300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_started = 0;
318400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_lock(&s_startupMutex);
318500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
318600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_attr_init (&attr);
31877f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
318800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = pthread_create(&s_tid_dispatch, &attr, eventLoop, NULL);
318900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
319000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    while (s_started == 0) {
319100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pthread_cond_wait(&s_startupCond, &s_startupMutex);
319200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
319300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
319400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_unlock(&s_startupMutex);
319500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
319600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
31978eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Failed to create dispatch thread errno:%d", errno);
319800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
319900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
320000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
320100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
320200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Used for testing purpose only.
320300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" void RIL_setcallbacks (const RIL_RadioFunctions *callbacks) {
320400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memcpy(&s_callbacks, callbacks, sizeof (RIL_RadioFunctions));
320500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
320600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
32077f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void
3208f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_register (const RIL_RadioFunctions *callbacks) {
320900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
321000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int flags;
321100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
32124380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    if (callbacks == NULL) {
32138eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("RIL_register: RIL_RadioFunctions * null");
321400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
321500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
32164380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    if (callbacks->version < RIL_VERSION_MIN) {
32178eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("RIL_register: version %d is to old, min version is %d",
32184380897c6cdc99486a061b819943e3b290ebcf09Wink Saville             callbacks->version, RIL_VERSION_MIN);
32194380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        return;
32204380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    }
32214380897c6cdc99486a061b819943e3b290ebcf09Wink Saville    if (callbacks->version > RIL_VERSION) {
32228eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("RIL_register: version %d is too new, max version is %d",
32234380897c6cdc99486a061b819943e3b290ebcf09Wink Saville             callbacks->version, RIL_VERSION);
32244380897c6cdc99486a061b819943e3b290ebcf09Wink Saville        return;
32253a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville    }
32268eb2a12cb7b525e74736300962a5f3848427275aWink Saville    RLOGE("RIL_register: RIL version %d", callbacks->version);
322700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
322800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_registerCalled > 0) {
32298eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("RIL_register has been called more than once. "
323000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                "Subsequent call ignored");
323100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
323200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
323300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
323400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    memcpy(&s_callbacks, callbacks, sizeof (RIL_RadioFunctions));
323500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
323600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_registerCalled = 1;
323700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
323800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Little self-check
323900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3240f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for (int i = 0; i < (int)NUM_ELEMS(s_commands); i++) {
324100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        assert(i == s_commands[i].requestNumber);
324200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
324300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3244f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville    for (int i = 0; i < (int)NUM_ELEMS(s_unsolResponses); i++) {
32457f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        assert(i + RIL_UNSOL_RESPONSE_BASE
324600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                == s_unsolResponses[i].requestNumber);
324700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
324800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
324900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // New rild impl calls RIL_startEventLoop() first
325000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // old standalone impl wants it here.
325100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
325200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_started == 0) {
325300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        RIL_startEventLoop();
325400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
325500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
325600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // start listen socket
325700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
325800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if 0
32597f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    ret = socket_local_server (SOCKET_NAME_RIL,
326000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ANDROID_SOCKET_NAMESPACE_ABSTRACT, SOCK_STREAM);
326100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
326200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
32638eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Unable to bind socket errno:%d", errno);
326400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        exit (-1);
326500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
326600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdListen = ret;
326700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
326800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#else
326900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdListen = android_get_control_socket(SOCKET_NAME_RIL);
327000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_fdListen < 0) {
32718eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Failed to get socket '" SOCKET_NAME_RIL "'");
327200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        exit(-1);
327300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
327400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
327500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = listen(s_fdListen, 4);
327600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
327700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
32788eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Failed to listen on control socket '%d': %s",
327900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project             s_fdListen, strerror(errno));
328000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        exit(-1);
328100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
328200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
328300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
328400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
328500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    /* note: non-persistent so we can accept only one connection at a time */
32867f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    ril_event_set (&s_listen_event, s_fdListen, false,
328700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                listenCallback, NULL);
328800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
328900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    rilEventAddWakeup (&s_listen_event);
329000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
329100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if 1
329200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // start debug interface socket
329300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
329400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    s_fdDebug = android_get_control_socket(SOCKET_NAME_RIL_DEBUG);
329500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_fdDebug < 0) {
32968eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Failed to get socket '" SOCKET_NAME_RIL_DEBUG "' errno:%d", errno);
329700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        exit(-1);
329800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
329900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
330000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = listen(s_fdDebug, 4);
330100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
330200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret < 0) {
33038eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("Failed to listen on ril debug socket '%d': %s",
330400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project             s_fdDebug, strerror(errno));
330500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        exit(-1);
330600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
330700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
330800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_set (&s_debug_event, s_fdDebug, true,
330900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                debugCallback, NULL);
331000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
331100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    rilEventAddWakeup (&s_debug_event);
331200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif
331300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
331400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
331500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
331600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int
3317f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillecheckAndDequeueRequestInfo(struct RequestInfo *pRI) {
331800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret = 0;
33197f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
332000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (pRI == NULL) {
332100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return 0;
332200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
332300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
332400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_lock(&s_pendingRequestsMutex);
332500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
33267f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    for(RequestInfo **ppCur = &s_pendingRequests
33277f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville        ; *ppCur != NULL
332800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        ; ppCur = &((*ppCur)->p_next)
332900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ) {
333000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (pRI == *ppCur) {
333100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ret = 1;
333200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
333300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            *ppCur = (*ppCur)->p_next;
333400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
333500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
333600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
333700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
333800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pthread_mutex_unlock(&s_pendingRequestsMutex);
333900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
334000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return ret;
334100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
334200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
334300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
334400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" void
3345f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_onRequestComplete(RIL_Token t, RIL_Errno e, void *response, size_t responselen) {
334600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    RequestInfo *pRI;
334700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
334800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    size_t errorOffset;
334900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
335000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    pRI = (RequestInfo *)t;
335100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
335200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (!checkAndDequeueRequestInfo(pRI)) {
33538eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE ("RIL_onRequestComplete: invalid RIL_Token");
335400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
335500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
335600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
335700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (pRI->local > 0) {
335800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // Locally issued command...void only!
335900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // response does not go back up the command socket
33608eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGD("C[locl]< %s", requestToString(pRI->pCI->requestNumber));
336100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
336200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto done;
336300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
336400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
336500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("[%04d]< %s",
336600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        pRI->token, requestToString(pRI->pCI->requestNumber));
336700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
336800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (pRI->cancelled == 0) {
336900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        Parcel p;
337000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
337100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32 (RESPONSE_SOLICITED);
337200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32 (pRI->token);
337300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        errorOffset = p.dataPosition();
337400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
337500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        p.writeInt32 (e);
337600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
3377b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang        if (response != NULL) {
3378b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang            // there is a response payload, no matter success or not.
337900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            ret = pRI->pCI->responseFunction(p, response, responselen);
338000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
338100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            /* if an error occurred, rewind and mark it */
338200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            if (ret != 0) {
338300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                p.setDataPosition(errorOffset);
338400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                p.writeInt32 (ret);
338500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            }
3386b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang        }
3387b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang
3388b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang        if (e != RIL_E_SUCCESS) {
3389b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang            appendPrintBuf("%s fails by %s", printBuf, failCauseToString(e));
339000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
339100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
339200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (s_fdCommand < 0) {
33938eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGD ("RIL onRequestComplete: Command channel closed");
339400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
339500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        sendResponse(p);
339600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
339700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
339800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectdone:
339900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    free(pRI);
340000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
340100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
340200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
340300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
3404f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillegrabPartialWakeLock() {
340500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    acquire_wake_lock(PARTIAL_WAKE_LOCK, ANDROID_WAKE_LOCK_NAME);
340600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
340700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
340800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
3409f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillereleaseWakeLock() {
341000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    release_wake_lock(ANDROID_WAKE_LOCK_NAME);
341100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
341200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
341300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/**
341400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Timer callback to put us back to sleep before the default timeout
341500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */
341600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void
3417f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillewakeTimeoutCallback (void *param) {
341800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // We're using "param != NULL" as a cancellation mechanism
341900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (param == NULL) {
34208eb2a12cb7b525e74736300962a5f3848427275aWink Saville        //RLOGD("wakeTimeout: releasing wake lock");
342100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
342200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        releaseWakeLock();
342300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
34248eb2a12cb7b525e74736300962a5f3848427275aWink Saville        //RLOGD("wakeTimeout: releasing wake lock CANCELLED");
342500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
342600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
342700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
34282bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic int
34292bc78d614e349574426d198c37e51ccb7455b5bbNaveen KalladecodeVoiceRadioTechnology (RIL_RadioState radioState) {
34302bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    switch (radioState) {
34312bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_NOT_READY:
34322bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_LOCKED_OR_ABSENT:
34332bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_READY:
34342bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return RADIO_TECH_UMTS;
34352bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34362bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_NOT_READY:
34372bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_READY:
34382bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_LOCKED_OR_ABSENT:
34392bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_NV_NOT_READY:
34402bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_NV_READY:
34412bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return RADIO_TECH_1xRTT;
34422bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34432bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        default:
34448eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGD("decodeVoiceRadioTechnology: Invoked with incorrect RadioState");
34452bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return -1;
34462bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
34472bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
34482bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34492bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic int
34502bc78d614e349574426d198c37e51ccb7455b5bbNaveen KalladecodeCdmaSubscriptionSource (RIL_RadioState radioState) {
34512bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    switch (radioState) {
34522bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_NOT_READY:
34532bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_LOCKED_OR_ABSENT:
34542bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_SIM_READY:
34552bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_NOT_READY:
34562bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_READY:
34572bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_RUIM_LOCKED_OR_ABSENT:
34582bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return CDMA_SUBSCRIPTION_SOURCE_RUIM_SIM;
34592bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34602bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_NV_NOT_READY:
34612bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_NV_READY:
34622bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return CDMA_SUBSCRIPTION_SOURCE_NV;
34632bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34642bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        default:
34658eb2a12cb7b525e74736300962a5f3848427275aWink Saville            RLOGD("decodeCdmaSubscriptionSource: Invoked with incorrect RadioState");
34662bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return -1;
34672bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
34682bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
34692bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34702bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic int
34712bc78d614e349574426d198c37e51ccb7455b5bbNaveen KalladecodeSimStatus (RIL_RadioState radioState) {
34722bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   switch (radioState) {
34732bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_SIM_NOT_READY:
34742bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_RUIM_NOT_READY:
34752bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_NV_NOT_READY:
34762bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_NV_READY:
34772bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla           return -1;
34782bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_SIM_LOCKED_OR_ABSENT:
34792bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_SIM_READY:
34802bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_RUIM_READY:
34812bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       case RADIO_STATE_RUIM_LOCKED_OR_ABSENT:
34822bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla           return radioState;
34832bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla       default:
34848eb2a12cb7b525e74736300962a5f3848427275aWink Saville           RLOGD("decodeSimStatus: Invoked with incorrect RadioState");
34852bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla           return -1;
34862bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla   }
34872bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
34882bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
34892bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic bool is3gpp2(int radioTech) {
34902bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    switch (radioTech) {
34912bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_IS95A:
34922bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_IS95B:
34932bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_1xRTT:
34942bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_EVDO_0:
34952bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_EVDO_A:
34962bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_EVDO_B:
34972bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_TECH_EHRPD:
34982bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return true;
34992bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        default:
35002bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            return false;
35012bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
35022bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
35032bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
35042bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla/* If RIL sends SIM states or RUIM states, store the voice radio
35052bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla * technology and subscription source information so that they can be
35062bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla * returned when telephony framework requests them
35072bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla */
35082bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kallastatic RIL_RadioState
35092bc78d614e349574426d198c37e51ccb7455b5bbNaveen KallaprocessRadioState(RIL_RadioState newRadioState) {
35102bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
35112bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    if((newRadioState > RADIO_STATE_UNAVAILABLE) && (newRadioState < RADIO_STATE_ON)) {
35122bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        int newVoiceRadioTech;
35132bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        int newCdmaSubscriptionSource;
35142bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        int newSimStatus;
35152bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
35162bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        /* This is old RIL. Decode Subscription source and Voice Radio Technology
35172bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla           from Radio State and send change notifications if there has been a change */
35182bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        newVoiceRadioTech = decodeVoiceRadioTechnology(newRadioState);
35192bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        if(newVoiceRadioTech != voiceRadioTech) {
35202bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            voiceRadioTech = newVoiceRadioTech;
35212bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            RIL_onUnsolicitedResponse (RIL_UNSOL_VOICE_RADIO_TECH_CHANGED,
35222bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla                        &voiceRadioTech, sizeof(voiceRadioTech));
35232bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        }
35242bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        if(is3gpp2(newVoiceRadioTech)) {
35252bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            newCdmaSubscriptionSource = decodeCdmaSubscriptionSource(newRadioState);
35262bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            if(newCdmaSubscriptionSource != cdmaSubscriptionSource) {
35272bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla                cdmaSubscriptionSource = newCdmaSubscriptionSource;
35282bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla                RIL_onUnsolicitedResponse (RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED,
35292bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla                        &cdmaSubscriptionSource, sizeof(cdmaSubscriptionSource));
35302bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            }
35312bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        }
35322bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        newSimStatus = decodeSimStatus(newRadioState);
35332bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        if(newSimStatus != simRuimStatus) {
35342bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            simRuimStatus = newSimStatus;
35352bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            RIL_onUnsolicitedResponse(RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED, NULL, 0);
35362bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        }
35372bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
35382bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        /* Send RADIO_ON to telephony */
35392bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        newRadioState = RADIO_STATE_ON;
35402bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    }
35412bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
35422bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    return newRadioState;
35432bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla}
35442bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla
354500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C"
35466e7c1966c6a41b6e7c0431dcc6bf65678438c79eBernhard Rosenkränzervoid RIL_onUnsolicitedResponse(int unsolResponse, const void *data,
354700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                size_t datalen)
354800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{
354900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int unsolResponseIndex;
355000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int ret;
355100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    int64_t timeReceived = 0;
355200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    bool shouldScheduleTimeout = false;
35532bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla    RIL_RadioState newState;
355400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
355500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (s_registerCalled == 0) {
355600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // Ignore RIL_onUnsolicitedResponse before RIL_register
35578eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGW("RIL_onUnsolicitedResponse called before RIL_register");
355800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
355900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
35607f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville
356100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    unsolResponseIndex = unsolResponse - RIL_UNSOL_RESPONSE_BASE;
356200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
356300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if ((unsolResponseIndex < 0)
356400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        || (unsolResponseIndex >= (int32_t)NUM_ELEMS(s_unsolResponses))) {
35658eb2a12cb7b525e74736300962a5f3848427275aWink Saville        RLOGE("unsupported unsolicited response code %d", unsolResponse);
356600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        return;
356700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
356800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
356900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Grab a wake lock if needed for this reponse,
357000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // as we exit we'll either release it immediately
357100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // or set a timer to release it later.
357200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch (s_unsolResponses[unsolResponseIndex].wakeType) {
357300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case WAKE_PARTIAL:
357400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            grabPartialWakeLock();
357500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            shouldScheduleTimeout = true;
357600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        break;
357700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
357800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case DONT_WAKE:
357900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default:
358000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // No wake lock is grabed so don't set timeout
358100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            shouldScheduleTimeout = false;
358200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            break;
358300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
358400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
358500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Mark the time this was received, doing this
358600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // after grabing the wakelock incase getting
358700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // the elapsedRealTime might cause us to goto
358800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // sleep.
358900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (unsolResponse == RIL_UNSOL_NITZ_TIME_RECEIVED) {
359000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        timeReceived = elapsedRealtime();
359100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
359200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
359300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    appendPrintBuf("[UNSL]< %s", requestToString(unsolResponse));
359400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
359500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    Parcel p;
359600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
359700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32 (RESPONSE_UNSOLICITED);
359800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p.writeInt32 (unsolResponse);
359900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
360000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = s_unsolResponses[unsolResponseIndex]
36016e7c1966c6a41b6e7c0431dcc6bf65678438c79eBernhard Rosenkränzer                .responseFunction(p, const_cast<void*>(data), datalen);
360200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret != 0) {
360300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // Problem with the response. Don't continue;
360400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        goto error_exit;
360500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
360600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
360700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // some things get more payload
360800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch(unsolResponse) {
360900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED:
36102bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            newState = processRadioState(s_callbacks.onStateRequest());
36112bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla            p.writeInt32(newState);
361200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            appendPrintBuf("%s {%s}", printBuf,
361300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                radioStateToString(s_callbacks.onStateRequest()));
361400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        break;
361500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
361600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
361700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_NITZ_TIME_RECEIVED:
361800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // Store the time that this was received so the
361900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // handler of this message can account for
362000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // the time it takes to arrive and process. In
362100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // particular the system has been known to sleep
362200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            // before this message can be processed.
362300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            p.writeInt64(timeReceived);
362400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        break;
362500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
362600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
362700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ret = sendResponse(p);
362800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (ret != 0 && unsolResponse == RIL_UNSOL_NITZ_TIME_RECEIVED) {
362900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
363000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // Unfortunately, NITZ time is not poll/update like everything
363100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // else in the system. So, if the upstream client isn't connected,
363200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // keep a copy of the last NITZ response (with receive time noted
363300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // above) around so we can deliver it when it is connected
363400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
363500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (s_lastNITZTimeData != NULL) {
363600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            free (s_lastNITZTimeData);
363700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            s_lastNITZTimeData = NULL;
363800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
363900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
364000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_lastNITZTimeData = malloc(p.dataSize());
364100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_lastNITZTimeDataSize = p.dataSize();
364200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        memcpy(s_lastNITZTimeData, p.data(), p.dataSize());
364300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
364400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
364500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // For now, we automatically go back to sleep after TIMEVAL_WAKE_TIMEOUT
364600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // FIXME The java code should handshake here to release wake lock
364700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
364800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (shouldScheduleTimeout) {
364900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        // Cancel the previous request
365000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        if (s_last_wake_timeout_info != NULL) {
365100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            s_last_wake_timeout_info->userParam = (void *)1;
365200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        }
365300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
365400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        s_last_wake_timeout_info
365500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project            = internalRequestTimedCallback(wakeTimeoutCallback, NULL,
365600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project                                            &TIMEVAL_WAKE_TIMEOUT);
365700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
365800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
365900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    // Normal exit
366000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return;
366100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
366200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecterror_exit:
366300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (shouldScheduleTimeout) {
366400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        releaseWakeLock();
366500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
366600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
366700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
36687f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** FIXME generalize this if you track UserCAllbackInfo, clear it
36697f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    when the callback occurs
367000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project*/
367100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UserCallbackInfo *
36727f8568086f2ea14885b0091c793e14c2656f0da2Wink SavilleinternalRequestTimedCallback (RIL_TimedCallback callback, void *param,
36730d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn                                const struct timeval *relativeTime)
367400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{
367500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    struct timeval myRelativeTime;
367600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    UserCallbackInfo *p_info;
367700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
367800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_info = (UserCallbackInfo *) malloc (sizeof(UserCallbackInfo));
367900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
36807f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville    p_info->p_callback = callback;
368100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    p_info->userParam = param;
36820d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn
368300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    if (relativeTime == NULL) {
368400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* treat null parameter as a 0 relative time */
368500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        memset (&myRelativeTime, 0, sizeof(myRelativeTime));
368600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    } else {
368700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        /* FIXME I think event_add's tv param is really const anyway */
368800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        memcpy (&myRelativeTime, relativeTime, sizeof(myRelativeTime));
368900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
369000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
369100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_event_set(&(p_info->event), -1, false, userTimerCallback, p_info);
369200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
369300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    ril_timer_add(&(p_info->event), &myRelativeTime);
369400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
369500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    triggerEvLoop();
369600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    return p_info;
369700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
369800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
369900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
37000d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackbornextern "C" void
37017f8568086f2ea14885b0091c793e14c2656f0da2Wink SavilleRIL_requestTimedCallback (RIL_TimedCallback callback, void *param,
3702f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville                                const struct timeval *relativeTime) {
37030d9f0c0ea45a0239653e04f2c63ccecb1bc62c6bDianne Hackborn    internalRequestTimedCallback (callback, param, relativeTime);
370400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
370500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
370600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char *
3707f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillefailCauseToString(RIL_Errno e) {
370800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch(e) {
370900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_SUCCESS: return "E_SUCCESS";
37102126ab2f05c1033fdca7542f38372dffd1468e1cRobert Greenwalt        case RIL_E_RADIO_NOT_AVAILABLE: return "E_RADIO_NOT_AVAILABLE";
371100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_GENERIC_FAILURE: return "E_GENERIC_FAILURE";
371200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_PASSWORD_INCORRECT: return "E_PASSWORD_INCORRECT";
371300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_SIM_PIN2: return "E_SIM_PIN2";
371400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_SIM_PUK2: return "E_SIM_PUK2";
371500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_REQUEST_NOT_SUPPORTED: return "E_REQUEST_NOT_SUPPORTED";
371600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_CANCELLED: return "E_CANCELLED";
371700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_OP_NOT_ALLOWED_DURING_VOICE_CALL: return "E_OP_NOT_ALLOWED_DURING_VOICE_CALL";
371800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW: return "E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW";
371900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_E_SMS_SEND_FAIL_RETRY: return "E_SMS_SEND_FAIL_RETRY";
3720f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_E_SIM_ABSENT:return "E_SIM_ABSENT";
37217553447d44bb3f494b00d573215d81398f61cfcdJohn Wang        case RIL_E_ILLEGAL_SIM_OR_ME:return "E_ILLEGAL_SIM_OR_ME";
37227f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville#ifdef FEATURE_MULTIMODE_ANDROID
3723f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_E_SUBSCRIPTION_NOT_AVAILABLE:return "E_SUBSCRIPTION_NOT_AVAILABLE";
3724f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_E_MODE_NOT_SUPPORTED:return "E_MODE_NOT_SUPPORTED";
3725f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif
372600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default: return "<unknown error>";
372700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
372800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
372900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
373000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char *
3731f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleradioStateToString(RIL_RadioState s) {
373200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch(s) {
373300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RADIO_STATE_OFF: return "RADIO_OFF";
373400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RADIO_STATE_UNAVAILABLE: return "RADIO_UNAVAILABLE";
373500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RADIO_STATE_SIM_NOT_READY: return "RADIO_SIM_NOT_READY";
373600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RADIO_STATE_SIM_LOCKED_OR_ABSENT: return "RADIO_SIM_LOCKED_OR_ABSENT";
373700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RADIO_STATE_SIM_READY: return "RADIO_SIM_READY";
3738f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RADIO_STATE_RUIM_NOT_READY:return"RADIO_RUIM_NOT_READY";
3739f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RADIO_STATE_RUIM_READY:return"RADIO_RUIM_READY";
3740f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RADIO_STATE_RUIM_LOCKED_OR_ABSENT:return"RADIO_RUIM_LOCKED_OR_ABSENT";
3741f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RADIO_STATE_NV_NOT_READY:return"RADIO_NV_NOT_READY";
3742f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RADIO_STATE_NV_READY:return"RADIO_NV_READY";
37432bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RADIO_STATE_ON:return"RADIO_ON";
374400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default: return "<unknown state>";
374500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
374600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
374700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
374800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char *
3749f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillecallStateToString(RIL_CallState s) {
375000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch(s) {
375100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_ACTIVE : return "ACTIVE";
375200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_HOLDING: return "HOLDING";
375300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_DIALING: return "DIALING";
375400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_ALERTING: return "ALERTING";
375500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_INCOMING: return "INCOMING";
375600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_CALL_WAITING: return "WAITING";
375700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default: return "<unknown state>";
375800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
375900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
376000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
376100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char *
3762f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillerequestToString(int request) {
376300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*
376400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cat libs/telephony/ril_commands.h \
376500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | egrep "^ *{RIL_" \
376600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | sed -re 's/\{RIL_([^,]+),[^,]+,([^}]+).+/case RIL_\1: return "\1";/'
376700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
376800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
376900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cat libs/telephony/ril_unsol_commands.h \
377000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | egrep "^ *{RIL_" \
377100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | sed -re 's/\{RIL_([^,]+),([^}]+).+/case RIL_\1: return "\1";/'
377200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
377300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project*/
377400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    switch(request) {
377500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_SIM_STATUS: return "GET_SIM_STATUS";
377600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ENTER_SIM_PIN: return "ENTER_SIM_PIN";
377700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ENTER_SIM_PUK: return "ENTER_SIM_PUK";
377800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ENTER_SIM_PIN2: return "ENTER_SIM_PIN2";
377900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ENTER_SIM_PUK2: return "ENTER_SIM_PUK2";
378000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_CHANGE_SIM_PIN: return "CHANGE_SIM_PIN";
378100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_CHANGE_SIM_PIN2: return "CHANGE_SIM_PIN2";
378200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION: return "ENTER_NETWORK_DEPERSONALIZATION";
378300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_CURRENT_CALLS: return "GET_CURRENT_CALLS";
378400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_DIAL: return "DIAL";
378500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_IMSI: return "GET_IMSI";
378600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_HANGUP: return "HANGUP";
378700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND: return "HANGUP_WAITING_OR_BACKGROUND";
378800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND: return "HANGUP_FOREGROUND_RESUME_BACKGROUND";
378900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE: return "SWITCH_WAITING_OR_HOLDING_AND_ACTIVE";
379000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_CONFERENCE: return "CONFERENCE";
379100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_UDUB: return "UDUB";
379200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_LAST_CALL_FAIL_CAUSE: return "LAST_CALL_FAIL_CAUSE";
379300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SIGNAL_STRENGTH: return "SIGNAL_STRENGTH";
3794c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_REQUEST_VOICE_REGISTRATION_STATE: return "VOICE_REGISTRATION_STATE";
3795c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_REQUEST_DATA_REGISTRATION_STATE: return "DATA_REGISTRATION_STATE";
379600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_OPERATOR: return "OPERATOR";
379700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_RADIO_POWER: return "RADIO_POWER";
379800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_DTMF: return "DTMF";
379900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SEND_SMS: return "SEND_SMS";
380000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SEND_SMS_EXPECT_MORE: return "SEND_SMS_EXPECT_MORE";
3801f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_SETUP_DATA_CALL: return "SETUP_DATA_CALL";
380200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SIM_IO: return "SIM_IO";
380300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SEND_USSD: return "SEND_USSD";
380400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_CANCEL_USSD: return "CANCEL_USSD";
380500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_CLIR: return "GET_CLIR";
380600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_CLIR: return "SET_CLIR";
380700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_CALL_FORWARD_STATUS: return "QUERY_CALL_FORWARD_STATUS";
380800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_CALL_FORWARD: return "SET_CALL_FORWARD";
380900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_CALL_WAITING: return "QUERY_CALL_WAITING";
381000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_CALL_WAITING: return "SET_CALL_WAITING";
381100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SMS_ACKNOWLEDGE: return "SMS_ACKNOWLEDGE";
381200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_IMEI: return "GET_IMEI";
381300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_IMEISV: return "GET_IMEISV";
381400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_ANSWER: return "ANSWER";
3815f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_DEACTIVATE_DATA_CALL: return "DEACTIVATE_DATA_CALL";
381600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_FACILITY_LOCK: return "QUERY_FACILITY_LOCK";
381700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_FACILITY_LOCK: return "SET_FACILITY_LOCK";
381800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_CHANGE_BARRING_PASSWORD: return "CHANGE_BARRING_PASSWORD";
381900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE: return "QUERY_NETWORK_SELECTION_MODE";
382000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC: return "SET_NETWORK_SELECTION_AUTOMATIC";
382100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL: return "SET_NETWORK_SELECTION_MANUAL";
382200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_AVAILABLE_NETWORKS : return "QUERY_AVAILABLE_NETWORKS ";
382300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_DTMF_START: return "DTMF_START";
382400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_DTMF_STOP: return "DTMF_STOP";
382500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_BASEBAND_VERSION: return "BASEBAND_VERSION";
382600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SEPARATE_CONNECTION: return "SEPARATE_CONNECTION";
382700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE: return "SET_PREFERRED_NETWORK_TYPE";
382800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE: return "GET_PREFERRED_NETWORK_TYPE";
382900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_NEIGHBORING_CELL_IDS: return "GET_NEIGHBORING_CELL_IDS";
383000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_MUTE: return "SET_MUTE";
383100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_GET_MUTE: return "GET_MUTE";
383200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_QUERY_CLIP: return "QUERY_CLIP";
3833f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE: return "LAST_DATA_CALL_FAIL_CAUSE";
3834f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_DATA_CALL_LIST: return "DATA_CALL_LIST";
383500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_RESET_RADIO: return "RESET_RADIO";
383600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_OEM_HOOK_RAW: return "OEM_HOOK_RAW";
383700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_OEM_HOOK_STRINGS: return "OEM_HOOK_STRINGS";
3838f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_SET_BAND_MODE: return "SET_BAND_MODE";
3839f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE: return "QUERY_AVAILABLE_BAND_MODE";
384000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_STK_GET_PROFILE: return "STK_GET_PROFILE";
384100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_STK_SET_PROFILE: return "STK_SET_PROFILE";
384200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND: return "STK_SEND_ENVELOPE_COMMAND";
384300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE: return "STK_SEND_TERMINAL_RESPONSE";
384400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM: return "STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM";
384500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SCREEN_STATE: return "SCREEN_STATE";
384600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_EXPLICIT_CALL_TRANSFER: return "EXPLICIT_CALL_TRANSFER";
384700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_REQUEST_SET_LOCATION_UPDATES: return "SET_LOCATION_UPDATES";
3848c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE:return"CDMA_SET_SUBSCRIPTION_SOURCE";
3849f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE:return"CDMA_SET_ROAMING_PREFERENCE";
3850f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE:return"CDMA_QUERY_ROAMING_PREFERENCE";
3851f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_SET_TTY_MODE:return"SET_TTY_MODE";
3852f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_QUERY_TTY_MODE:return"QUERY_TTY_MODE";
3853f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE";
3854f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE";
3855f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_FLASH:return"CDMA_FLASH";
3856f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_BURST_DTMF:return"CDMA_BURST_DTMF";
3857f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_SEND_SMS:return"CDMA_SEND_SMS";
3858f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE:return"CDMA_SMS_ACKNOWLEDGE";
3859a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        case RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG:return"GSM_GET_BROADCAST_SMS_CONFIG";
3860a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        case RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG:return"GSM_SET_BROADCAST_SMS_CONFIG";
3861a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        case RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG:return "CDMA_GET_BROADCAST_SMS_CONFIG";
3862a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        case RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG:return "CDMA_SET_BROADCAST_SMS_CONFIG";
3863a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville        case RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION:return "CDMA_SMS_BROADCAST_ACTIVATION";
386403c1edf23e76a83b95ac6847e333cb1329bbfa1dNaveen Kalla        case RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY: return"CDMA_VALIDATE_AND_WRITE_AKEY";
3865f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_SUBSCRIPTION: return"CDMA_SUBSCRIPTION";
3866f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM: return "CDMA_WRITE_SMS_TO_RUIM";
3867f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM: return "CDMA_DELETE_SMS_ON_RUIM";
3868f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_REQUEST_DEVICE_IDENTITY: return "DEVICE_IDENTITY";
3869000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh        case RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE: return "EXIT_EMERGENCY_CALLBACK_MODE";
3870000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh        case RIL_REQUEST_GET_SMSC_ADDRESS: return "GET_SMSC_ADDRESS";
3871000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh        case RIL_REQUEST_SET_SMSC_ADDRESS: return "SET_SMSC_ADDRESS";
387209a68ba315ca3d6b092fd8078cc42b93b7934a1ajsh        case RIL_REQUEST_REPORT_SMS_MEMORY_STATUS: return "REPORT_SMS_MEMORY_STATUS";
3873563fd7207da27322bf3f3587ef6000a944a617b7jsh        case RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING: return "REPORT_STK_SERVICE_IS_RUNNING";
3874c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE: return "CDMA_GET_SUBSCRIPTION_SOURCE";
3875fa8d584ca7984bf7d73ff37c7c2bc1e0dfa5fb71Jake Hamby        case RIL_REQUEST_ISIM_AUTHENTICATION: return "ISIM_AUTHENTICATION";
3876300105d1487f5238940c18792b879793826b61f4Jake Hamby        case RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU: return "RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU";
3877300105d1487f5238940c18792b879793826b61f4Jake Hamby        case RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS: return "RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS";
38782bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RIL_REQUEST_VOICE_RADIO_TECH: return "VOICE_RADIO_TECH";
38798a9e02161271505de274db0c3a88087056dd5dfcWink Saville        case RIL_REQUEST_GET_CELL_INFO_LIST: return"GET_CELL_INFO_LIST";
38808a9e02161271505de274db0c3a88087056dd5dfcWink Saville        case RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE: return"SET_UNSOL_CELL_INFO_LIST_RATE";
388175697538e485ea2981960dcd4878bfdd032731acSungmin Choi        case RIL_REQUEST_SET_INITIAL_ATTACH_APN: return "RIL_REQUEST_SET_INITIAL_ATTACH_APN";
3882a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        case RIL_REQUEST_IMS_REGISTRATION_STATE: return "IMS_REGISTRATION_STATE";
3883a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        case RIL_REQUEST_IMS_SEND_SMS: return "IMS_SEND_SMS";
38842458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        case RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC: return "SIM_TRANSMIT_APDU_BASIC";
38852458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        case RIL_REQUEST_SIM_OPEN_CHANNEL: return "SIM_OPEN_CHANNEL";
38862458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        case RIL_REQUEST_SIM_CLOSE_CHANNEL: return "SIM_CLOSE_CHANNEL";
38872458d8d1e56faae7b00511ceeab19730572c22d9Shishir Agrawal        case RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL: return "SIM_TRANSMIT_APDU_CHANNEL";
388800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED: return "UNSOL_RESPONSE_RADIO_STATE_CHANGED";
388900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED: return "UNSOL_RESPONSE_CALL_STATE_CHANGED";
3890c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED: return "UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED";
389100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_NEW_SMS: return "UNSOL_RESPONSE_NEW_SMS";
389200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT: return "UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT";
389300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM: return "UNSOL_RESPONSE_NEW_SMS_ON_SIM";
389400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_ON_USSD: return "UNSOL_ON_USSD";
389500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_ON_USSD_REQUEST: return "UNSOL_ON_USSD_REQUEST(obsolete)";
389600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_NITZ_TIME_RECEIVED: return "UNSOL_NITZ_TIME_RECEIVED";
389700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_SIGNAL_STRENGTH: return "UNSOL_SIGNAL_STRENGTH";
389800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_STK_SESSION_END: return "UNSOL_STK_SESSION_END";
389900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_STK_PROACTIVE_COMMAND: return "UNSOL_STK_PROACTIVE_COMMAND";
390000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_STK_EVENT_NOTIFY: return "UNSOL_STK_EVENT_NOTIFY";
390100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_STK_CALL_SETUP: return "UNSOL_STK_CALL_SETUP";
390200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_SIM_SMS_STORAGE_FULL: return "UNSOL_SIM_SMS_STORAGE_FUL";
390300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_SIM_REFRESH: return "UNSOL_SIM_REFRESH";
3904f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_UNSOL_DATA_CALL_LIST_CHANGED: return "UNSOL_DATA_CALL_LIST_CHANGED";
390500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        case RIL_UNSOL_CALL_RING: return "UNSOL_CALL_RING";
3906f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED: return "UNSOL_RESPONSE_SIM_STATUS_CHANGED";
3907f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_UNSOL_RESPONSE_CDMA_NEW_SMS: return "UNSOL_NEW_CDMA_SMS";
3908f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS: return "UNSOL_NEW_BROADCAST_SMS";
3909f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville        case RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL: return "UNSOL_CDMA_RUIM_SMS_STORAGE_FULL";
39103d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        case RIL_UNSOL_RESTRICTED_STATE_CHANGED: return "UNSOL_RESTRICTED_STATE_CHANGED";
39113d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        case RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE: return "UNSOL_ENTER_EMERGENCY_CALLBACK_MODE";
39123d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        case RIL_UNSOL_CDMA_CALL_WAITING: return "UNSOL_CDMA_CALL_WAITING";
39133d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        case RIL_UNSOL_CDMA_OTA_PROVISION_STATUS: return "UNSOL_CDMA_OTA_PROVISION_STATUS";
39143d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville        case RIL_UNSOL_CDMA_INFO_REC: return "UNSOL_CDMA_INFO_REC";
3915af6ecbf0fa03379818038459ee1b61ea393ffd4fJaikumar Ganesh        case RIL_UNSOL_OEM_HOOK_RAW: return "UNSOL_OEM_HOOK_RAW";
39165d621da539abea83309d77317ede40126f47d5f0John Wang        case RIL_UNSOL_RINGBACK_TONE: return "UNSOL_RINGBACK_TONE";
39175909cf831f0d687e93164daaecc43a2ff792cc3aJohn Wang        case RIL_UNSOL_RESEND_INCALL_MUTE: return "UNSOL_RESEND_INCALL_MUTE";
3918ee2745825fae9561c5f83fcf179bbbfa111e5224Wink Saville        case RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED: return "UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED";
3919c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_UNSOL_CDMA_PRL_CHANGED: return "UNSOL_CDMA_PRL_CHANGED";
3920c0114b325877907fcdf7a5baa24e54a752e7e58bWink Saville        case RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE: return "UNSOL_EXIT_EMERGENCY_CALLBACK_MODE";
39215b9df33c53682addaebc0b6073901a8b441d82f9Wink Saville        case RIL_UNSOL_RIL_CONNECTED: return "UNSOL_RIL_CONNECTED";
39222bc78d614e349574426d198c37e51ccb7455b5bbNaveen Kalla        case RIL_UNSOL_VOICE_RADIO_TECH_CHANGED: return "UNSOL_VOICE_RADIO_TECH_CHANGED";
39238a9e02161271505de274db0c3a88087056dd5dfcWink Saville        case RIL_UNSOL_CELL_INFO_LIST: return "UNSOL_CELL_INFO_LIST";
3924a18b9d1e1a014290691d63a7f335085dadc83e46Sukanya Rajkhowa        case RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED: return "RESPONSE_IMS_NETWORK_STATE_CHANGED";
392500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project        default: return "<unknown request>";
392600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project    }
392700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}
392800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project
392900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} /* namespace android */
3930