ril.cpp revision 7553447d44bb3f494b00d573215d81398f61cfcd
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> 2600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/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> 3400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <pwd.h> 3500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 3600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdio.h> 3700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdlib.h> 3800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <stdarg.h> 3900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <string.h> 4000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <unistd.h> 4100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <fcntl.h> 4200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <time.h> 4300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <errno.h> 4400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <assert.h> 4500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <ctype.h> 4600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <alloca.h> 4700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <sys/un.h> 4800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <assert.h> 4900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <netinet/in.h> 5000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <cutils/properties.h> 5100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include <ril_event.h> 5300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectnamespace android { 5500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PHONE_PROCESS "radio" 5700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define SOCKET_NAME_RIL "rild" 5900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define SOCKET_NAME_RIL_DEBUG "rild-debug" 6000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define ANDROID_WAKE_LOCK_NAME "radio-interface" 6200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PROPERTY_RIL_IMPL "gsm.version.ril-impl" 6500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// match with constant in RIL.java 6700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define MAX_COMMAND_BYTES (8 * 1024) 6800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Basically: memset buffers that the client library 7000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// shouldn't be using anymore in an attempt to find 7100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// memory usage issues sooner. 7200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define MEMSET_FREED 1 7300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 7400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define NUM_ELEMS(a) (sizeof (a) / sizeof (a)[0]) 7500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 76f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#define MIN(a,b) ((a)<(b) ? (a) : (b)) 77f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 7800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* Constants for response types */ 7900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RESPONSE_SOLICITED 0 8000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RESPONSE_UNSOLICITED 1 8100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 8200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* Negative values for private RIL errno's */ 8300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RIL_ERRNO_INVALID_RESPONSE -1 8400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 8500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// request, response, and unsolicited msg print macro 8600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define PRINTBUF_SIZE 8096 8700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 8800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Enable RILC log 8900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#define RILC_LOG 0 9000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 9100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if RILC_LOG 9200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define startRequest sprintf(printBuf, "(") 9300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define closeRequest sprintf(printBuf, "%s)", printBuf) 9400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define printRequest(token, req) \ 9500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGD("[%04d]> %s %s", token, requestToString(req), printBuf) 9600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 9700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define startResponse sprintf(printBuf, "%s {", printBuf) 9800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define closeResponse sprintf(printBuf, "%s}", printBuf) 9900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define printResponse LOGD("%s", printBuf) 10000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 10100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define clearPrintBuf printBuf[0] = 0 10200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define removeLastChar printBuf[strlen(printBuf)-1] = 0 10300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define appendPrintBuf(x...) sprintf(printBuf, x) 10400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#else 10500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define startRequest 10600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define closeRequest 10700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define printRequest(token, req) 10800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define startResponse 10900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define closeResponse 11000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define printResponse 11100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define clearPrintBuf 11200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define removeLastChar 11300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project #define appendPrintBuf(x...) 11400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 11500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 11600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectenum WakeType {DONT_WAKE, WAKE_PARTIAL}; 11700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 11800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct { 11900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int requestNumber; 12000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project void (*dispatchFunction) (Parcel &p, struct RequestInfo *pRI); 12100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int(*responseFunction) (Parcel &p, void *response, size_t responselen); 12200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} CommandInfo; 12300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 12400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct { 12500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int requestNumber; 12600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int (*responseFunction) (Parcel &p, void *response, size_t responselen); 12700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project WakeType wakeType; 12800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} UnsolResponseInfo; 12900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 13000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecttypedef struct RequestInfo { 1317f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville int32_t token; //this is not RIL_Token 13200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project CommandInfo *pCI; 13300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct RequestInfo *p_next; 13400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char cancelled; 13500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char local; // responses to local commands do not go back to command process 13600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} RequestInfo; 13700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1383d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savilletypedef struct UserCallbackInfo { 13900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_TimedCallback p_callback; 14000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project void *userParam; 14100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct ril_event event; 14200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct UserCallbackInfo *p_next; 14300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} UserCallbackInfo; 14400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 14500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 14600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*******************************************************************/ 14700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 14800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source ProjectRIL_RadioFunctions s_callbacks = {0, NULL, NULL, NULL, NULL, NULL}; 14900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_registerCalled = 0; 15000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 15100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_t s_tid_dispatch; 15200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_t s_tid_reader; 15300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_started = 0; 15400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 15500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdListen = -1; 15600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdCommand = -1; 15700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdDebug = -1; 15800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 15900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdWakeupRead; 16000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int s_fdWakeupWrite; 16100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 16200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_commands_event; 16300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_wakeupfd_event; 16400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_listen_event; 16500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_wake_timeout_event; 16600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic struct ril_event s_debug_event; 16700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 16800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 16900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic const struct timeval TIMEVAL_WAKE_TIMEOUT = {1,0}; 17000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 17100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_pendingRequestsMutex = PTHREAD_MUTEX_INITIALIZER; 17200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_writeMutex = PTHREAD_MUTEX_INITIALIZER; 17300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_startupMutex = PTHREAD_MUTEX_INITIALIZER; 17400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_cond_t s_startupCond = PTHREAD_COND_INITIALIZER; 17500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 17600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_mutex_t s_dispatchMutex = PTHREAD_MUTEX_INITIALIZER; 17700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic pthread_cond_t s_dispatchCond = PTHREAD_COND_INITIALIZER; 17800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 17900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_pendingRequests = NULL; 18000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 18100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_toDispatchHead = NULL; 18200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic RequestInfo *s_toDispatchTail = NULL; 18300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 18400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UserCallbackInfo *s_last_wake_timeout_info = NULL; 18500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 18600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void *s_lastNITZTimeData = NULL; 18700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic size_t s_lastNITZTimeDataSize; 18800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 18900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if RILC_LOG 19000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project static char printBuf[PRINTBUF_SIZE]; 19100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 19200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 19300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/*******************************************************************/ 19400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 19500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchVoid (Parcel& p, RequestInfo *pRI); 19600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchString (Parcel& p, RequestInfo *pRI); 19700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchStrings (Parcel& p, RequestInfo *pRI); 19800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchInts (Parcel& p, RequestInfo *pRI); 19900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchDial (Parcel& p, RequestInfo *pRI); 20000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchSIM_IO (Parcel& p, RequestInfo *pRI); 20100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchCallForward(Parcel& p, RequestInfo *pRI); 20200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchRaw(Parcel& p, RequestInfo *pRI); 20300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void dispatchSmsWrite (Parcel &p, RequestInfo *pRI); 20400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 205f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaSms(Parcel &p, RequestInfo *pRI); 206f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaSmsAck(Parcel &p, RequestInfo *pRI); 207a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void dispatchGsmBrSmsCnf(Parcel &p, RequestInfo *pRI); 208f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchCdmaBrSmsCnf(Parcel &p, RequestInfo *pRI); 209f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchRilCdmaSmsWriteArgs(Parcel &p, RequestInfo *pRI); 21000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseInts(Parcel &p, void *response, size_t responselen); 21100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseStrings(Parcel &p, void *response, size_t responselen); 21200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseString(Parcel &p, void *response, size_t responselen); 21300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseVoid(Parcel &p, void *response, size_t responselen); 21400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCallList(Parcel &p, void *response, size_t responselen); 21500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSMS(Parcel &p, void *response, size_t responselen); 21600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSIM_IO(Parcel &p, void *response, size_t responselen); 21700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCallForwards(Parcel &p, void *response, size_t responselen); 218f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseDataCallList(Parcel &p, void *response, size_t responselen); 21900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseRaw(Parcel &p, void *response, size_t responselen); 22000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseSsn(Parcel &p, void *response, size_t responselen); 221f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSimStatus(Parcel &p, void *response, size_t responselen); 222a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseGsmBrSmsCnf(Parcel &p, void *response, size_t responselen); 223a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaBrSmsCnf(Parcel &p, void *response, size_t responselen); 224f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCdmaSms(Parcel &p, void *response, size_t responselen); 22500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int responseCellList(Parcel &p, void *response, size_t responselen); 2263d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaInformationRecords(Parcel &p,void *response, size_t responselen); 2273d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseRilSignalStrength(Parcel &p,void *response, size_t responselen); 2283d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCallRing(Parcel &p, void *response, size_t responselen); 2293d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaSignalInfoRecord(Parcel &p,void *response, size_t responselen); 2303d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaCallWaiting(Parcel &p,void *response, size_t responselen); 23100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 23200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * requestToString(int request); 23300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * failCauseToString(RIL_Errno); 23400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * callStateToString(RIL_CallState); 23500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" const char * radioStateToString(RIL_RadioState); 23600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 23700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef RIL_SHLIB 2387f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void RIL_onUnsolicitedResponse(int unsolResponse, void *data, 23900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t datalen); 24000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 24100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2427f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic UserCallbackInfo * internalRequestTimedCallback 2437f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville (RIL_TimedCallback callback, void *param, 24400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const struct timeval *relativeTime); 24500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 24600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Index == requestNumber */ 24700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic CommandInfo s_commands[] = { 24800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include "ril_commands.h" 24900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}; 25000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 25100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UnsolResponseInfo s_unsolResponses[] = { 25200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#include "ril_unsol_commands.h" 25300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project}; 25400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 25500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 25600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic char * 257f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillestrdupReadString(Parcel &p) { 25800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t stringlen; 25900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const char16_t *s16; 2607f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 26100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s16 = p.readString16Inplace(&stringlen); 2627f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 26300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return strndup16to8(s16, stringlen); 26400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 26500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 266f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void writeStringToParcel(Parcel &p, const char *s) { 26700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char16_t *s16; 26800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t s16_len; 26900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s16 = strdup8to16(s, &s16_len); 27000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeString16(s16, s16_len); 27100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(s16); 27200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 27300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 27400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 27500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 276f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillememsetString (char *s) { 27700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s != NULL) { 27800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (s, 0, strlen(s)); 27900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 28000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 28100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 28200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectvoid nullParcelReleaseFunction (const uint8_t* data, size_t dataSize, 28300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const size_t* objects, size_t objectsSize, 284f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville void* cookie) { 28500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // do nothing -- the data reference lives longer than the Parcel object 28600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 28700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2887f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** 28900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * To be called from dispatch thread 29000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Issue a single local request, ensuring that the response 2917f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * is not sent back up to the command process 29200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 29300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 294f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleissueLocalRequest(int request, void *data, int len) { 29500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RequestInfo *pRI; 29600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 29700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 29800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI = (RequestInfo *)calloc(1, sizeof(RequestInfo)); 29900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 30000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->local = 1; 30100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->token = 0xffffffff; // token is not used in this context 30200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->pCI = &(s_commands[request]); 30300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 30400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_lock(&s_pendingRequestsMutex); 30500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 30600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 30700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->p_next = s_pendingRequests; 30800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_pendingRequests = pRI; 30900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 31000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_unlock(&s_pendingRequestsMutex); 31100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 31200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 31300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGD("C[locl]> %s", requestToString(request)); 31400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 31500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(request, data, len, pRI); 31600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 31700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 31800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 31900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 32000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int 321f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleprocessCommandBuffer(void *buffer, size_t buflen) { 32200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project Parcel p; 32300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 32400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t request; 32500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t token; 32600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RequestInfo *pRI; 32700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 32800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 32900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.setData((uint8_t *) buffer, buflen); 33000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 33100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // status checked at end 33200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&request); 33300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32 (&token); 33400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 33500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 33600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid request block"); 33700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 33800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 33900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 34000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (request < 1 || request >= (int32_t)NUM_ELEMS(s_commands)) { 34100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("unsupported request code %d token %d", request, token); 34200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // FIXME this should perhaps return a response 34300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 34400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 34500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 34600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 34700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI = (RequestInfo *)calloc(1, sizeof(RequestInfo)); 34800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 34900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->token = token; 35000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->pCI = &(s_commands[request]); 35100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 35200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_lock(&s_pendingRequestsMutex); 35300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 35400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 35500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->p_next = s_pendingRequests; 35600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_pendingRequests = pRI; 35700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 35800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_unlock(&s_pendingRequestsMutex); 35900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 36000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 36100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* sLastDispatchedToken = token; */ 36200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 3637f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville pRI->pCI->dispatchFunction(p, pRI); 36400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 36500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 36600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 36700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 36800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 369f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleinvalidCommandBlock (RequestInfo *pRI) { 3707f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid command block for token %d request %s", 37100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->token, requestToString(pRI->pCI->requestNumber)); 37200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 37300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 37400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects NULL */ 3757f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void 376f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchVoid (Parcel& p, RequestInfo *pRI) { 37700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project clearPrintBuf; 37800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 37900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, NULL, 0, pRI); 38000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 38100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 38200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const char * */ 38300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 384f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchString (Parcel& p, RequestInfo *pRI) { 38500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 38600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t datalen; 38700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t stringlen; 38800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char *string8 = NULL; 38900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 39000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project string8 = strdupReadString(p); 39100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 39200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 39300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%s", printBuf, string8); 39400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 39500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 39600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 39700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, string8, 39800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sizeof(char *), pRI); 39900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 40000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 40100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString(string8); 40200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 40300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 40400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(string8); 40500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 40600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 40700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 40800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 40900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 41000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 41100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const char ** */ 41200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 413f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchStrings (Parcel &p, RequestInfo *pRI) { 41400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t countStrings; 41500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 41600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t datalen; 41700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char **pStrings; 41800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 41900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32 (&countStrings); 42000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 42100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 42200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 42300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 42400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 42500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 42600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (countStrings == 0) { 42700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // just some non-null pointer 42800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pStrings = (char **)alloca(sizeof(char *)); 42900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project datalen = 0; 43000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else if (((int)countStrings) == -1) { 43100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pStrings = NULL; 43200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project datalen = 0; 43300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 43400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project datalen = sizeof(char *) * countStrings; 4357f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 43600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pStrings = (char **)alloca(datalen); 43700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 43800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < countStrings ; i++) { 43900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pStrings[i] = strdupReadString(p); 44000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%s,", printBuf, pStrings[i]); 44100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 44200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 44300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 44400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 44500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 44600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 44700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, pStrings, datalen, pRI); 44800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 44900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (pStrings != NULL) { 45000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < countStrings ; i++) { 45100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 45200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (pStrings[i]); 45300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 45400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(pStrings[i]); 45500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 45600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 45700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 45800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(pStrings, 0, datalen); 45900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 46000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 4617f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 46200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 46300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 46400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 46500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 46600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 46700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 46800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** Callee expects const int * */ 46900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 470f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchInts (Parcel &p, RequestInfo *pRI) { 47100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t count; 47200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 47300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t datalen; 47400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int *pInts; 47500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 47600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32 (&count); 47700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 47800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR || count == 0) { 47900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 48000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 48100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 48200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project datalen = sizeof(int) * count; 48300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pInts = (int *)alloca(datalen); 48400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 48500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 48600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < count ; i++) { 48700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t t; 48800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 48900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 49000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pInts[i] = (int)t; 49100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%d,", printBuf, t); 49200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 49300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 49400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 49500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 49600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 49700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 49800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 49900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 50000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5017f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, const_cast<int *>(pInts), 50200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project datalen, pRI); 50300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 50400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 50500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(pInts, 0, datalen); 50600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 50700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 50800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 50900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 51000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 51100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 51200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 51300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 51400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5157f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** 5167f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_SMS_WriteArgs * 51700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is: 51800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t status 51900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * String pdu 52000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 52100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 522f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchSmsWrite (Parcel &p, RequestInfo *pRI) { 52300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_SMS_WriteArgs args; 52400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t t; 52500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 52600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 52700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (&args, 0, sizeof(args)); 52800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 52900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 53000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project args.status = (int)t; 53100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 53200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project args.pdu = strdupReadString(p); 53300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 53400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR || args.pdu == NULL) { 53500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 53600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 53700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 53800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project args.smsc = strdupReadString(p); 53900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 54000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 54100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%d,%s,smsc=%s", printBuf, args.status, 54200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)args.pdu, (char*)args.smsc); 54300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 54400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 5457f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 54600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, &args, sizeof(args), pRI); 54700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 54800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 54900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (args.pdu); 55000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 55100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 55200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (args.pdu); 5537f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 55400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 55500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(&args, 0, sizeof(args)); 55600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 55700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 55800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 55900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 56000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 56100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 56200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 56300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5647f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** 5657f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_Dial * 56600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is: 56700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * String address 56800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t clir 56900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 57000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 571f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchDial (Parcel &p, RequestInfo *pRI) { 57200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_Dial dial; 57374fa38884320698c1623764850e3131b9769dff0Wink Saville RIL_UUS_Info uusInfo; 5747bce082edcee07339ebb06a35970b4b218ab8288Wink Saville int32_t sizeOfDial; 57500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t t; 57674fa38884320698c1623764850e3131b9769dff0Wink Saville int32_t uusPresent; 57700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 57800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 57900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (&dial, 0, sizeof(dial)); 58000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 58100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project dial.address = strdupReadString(p); 58200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 58300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 58400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project dial.clir = (int)t; 58500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 58600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR || dial.address == NULL) { 58700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 58800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 58900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 5903a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville if (s_callbacks.version < 3) { // Remove when partners upgrade to version 3 59174fa38884320698c1623764850e3131b9769dff0Wink Saville uusPresent = 0; 5927bce082edcee07339ebb06a35970b4b218ab8288Wink Saville sizeOfDial = sizeof(dial) - sizeof(RIL_UUS_Info *); 59374fa38884320698c1623764850e3131b9769dff0Wink Saville } else { 59474fa38884320698c1623764850e3131b9769dff0Wink Saville status = p.readInt32(&uusPresent); 59574fa38884320698c1623764850e3131b9769dff0Wink Saville 59674fa38884320698c1623764850e3131b9769dff0Wink Saville if (status != NO_ERROR) { 59774fa38884320698c1623764850e3131b9769dff0Wink Saville goto invalid; 59874fa38884320698c1623764850e3131b9769dff0Wink Saville } 59974fa38884320698c1623764850e3131b9769dff0Wink Saville 60074fa38884320698c1623764850e3131b9769dff0Wink Saville if (uusPresent == 0) { 60174fa38884320698c1623764850e3131b9769dff0Wink Saville dial.uusInfo = NULL; 60274fa38884320698c1623764850e3131b9769dff0Wink Saville } else { 60374fa38884320698c1623764850e3131b9769dff0Wink Saville int32_t len; 60474fa38884320698c1623764850e3131b9769dff0Wink Saville 60574fa38884320698c1623764850e3131b9769dff0Wink Saville memset(&uusInfo, 0, sizeof(RIL_UUS_Info)); 60674fa38884320698c1623764850e3131b9769dff0Wink Saville 60774fa38884320698c1623764850e3131b9769dff0Wink Saville status = p.readInt32(&t); 60874fa38884320698c1623764850e3131b9769dff0Wink Saville uusInfo.uusType = (RIL_UUS_Type) t; 60974fa38884320698c1623764850e3131b9769dff0Wink Saville 61074fa38884320698c1623764850e3131b9769dff0Wink Saville status = p.readInt32(&t); 61174fa38884320698c1623764850e3131b9769dff0Wink Saville uusInfo.uusDcs = (RIL_UUS_DCS) t; 61274fa38884320698c1623764850e3131b9769dff0Wink Saville 61374fa38884320698c1623764850e3131b9769dff0Wink Saville status = p.readInt32(&len); 61474fa38884320698c1623764850e3131b9769dff0Wink Saville if (status != NO_ERROR) { 61574fa38884320698c1623764850e3131b9769dff0Wink Saville goto invalid; 61674fa38884320698c1623764850e3131b9769dff0Wink Saville } 61774fa38884320698c1623764850e3131b9769dff0Wink Saville 61874fa38884320698c1623764850e3131b9769dff0Wink Saville // The java code writes -1 for null arrays 61974fa38884320698c1623764850e3131b9769dff0Wink Saville if (((int) len) == -1) { 62074fa38884320698c1623764850e3131b9769dff0Wink Saville uusInfo.uusData = NULL; 62174fa38884320698c1623764850e3131b9769dff0Wink Saville len = 0; 62274fa38884320698c1623764850e3131b9769dff0Wink Saville } else { 62374fa38884320698c1623764850e3131b9769dff0Wink Saville uusInfo.uusData = (char*) p.readInplace(len); 62474fa38884320698c1623764850e3131b9769dff0Wink Saville } 62574fa38884320698c1623764850e3131b9769dff0Wink Saville 62674fa38884320698c1623764850e3131b9769dff0Wink Saville uusInfo.uusLength = len; 62774fa38884320698c1623764850e3131b9769dff0Wink Saville dial.uusInfo = &uusInfo; 62874fa38884320698c1623764850e3131b9769dff0Wink Saville } 6297bce082edcee07339ebb06a35970b4b218ab8288Wink Saville sizeOfDial = sizeof(dial); 63074fa38884320698c1623764850e3131b9769dff0Wink Saville } 63174fa38884320698c1623764850e3131b9769dff0Wink Saville 63200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 63300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%snum=%s,clir=%d", printBuf, dial.address, dial.clir); 63474fa38884320698c1623764850e3131b9769dff0Wink Saville if (uusPresent) { 63574fa38884320698c1623764850e3131b9769dff0Wink Saville appendPrintBuf("%s,uusType=%d,uusDcs=%d,uusLen=%d", printBuf, 63674fa38884320698c1623764850e3131b9769dff0Wink Saville dial.uusInfo->uusType, dial.uusInfo->uusDcs, 63774fa38884320698c1623764850e3131b9769dff0Wink Saville dial.uusInfo->uusLength); 63874fa38884320698c1623764850e3131b9769dff0Wink Saville } 63900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 64000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 64100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6427bce082edcee07339ebb06a35970b4b218ab8288Wink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, &dial, sizeOfDial, pRI); 64300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 64400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 64500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (dial.address); 64600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 64700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 64800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (dial.address); 6497f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 65000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 65174fa38884320698c1623764850e3131b9769dff0Wink Saville memset(&uusInfo, 0, sizeof(RIL_UUS_Info)); 65200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(&dial, 0, sizeof(dial)); 65300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 65400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 65500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 65600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 65700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 65800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 65900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 66000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6617f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** 6627f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * Callee expects const RIL_SIM_IO * 66300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is: 66400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t command 66500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t fileid 66600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * String path 66700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t p1, p2, p3 6687f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * String data 6697f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * String pin2 67000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 67100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 672f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchSIM_IO (Parcel &p, RequestInfo *pRI) { 67300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_SIM_IO simIO; 67400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t t; 67500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 67600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 67700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (&simIO, 0, sizeof(simIO)); 67800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6797f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville // note we only check status at the end 6807f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 68100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 68200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.command = (int)t; 68300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 68400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 68500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.fileid = (int)t; 68600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 68700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.path = strdupReadString(p); 68800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 68900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 69000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.p1 = (int)t; 69100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 69200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 69300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.p2 = (int)t; 69400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 69500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 69600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.p3 = (int)t; 69700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 69800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.data = strdupReadString(p); 69900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.pin2 = strdupReadString(p); 70000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 70100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 70200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%scmd=0x%X,efid=0x%X,path=%s,%d,%d,%d,%s,pin2=%s", printBuf, 70300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.command, simIO.fileid, (char*)simIO.path, 70400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project simIO.p1, simIO.p2, simIO.p3, 70500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)simIO.data, (char*)simIO.pin2); 70600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 70700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 7087f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 70900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 71000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 71100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 71200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 71300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, &simIO, sizeof(simIO), pRI); 71400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 71500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 71600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (simIO.path); 71700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (simIO.data); 71800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString (simIO.pin2); 71900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 72000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 72100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (simIO.path); 72200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (simIO.data); 72300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (simIO.pin2); 7247f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 72500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 72600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(&simIO, 0, sizeof(simIO)); 72700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 72800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 72900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 73000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 73100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 73200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 73300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 73400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 73500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** 73600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Callee expects const RIL_CallForwardInfo * 73700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Payload is: 73800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t status/action 73900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t reason 74000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t serviceCode 74100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t toa 74200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * String number (0 length -> null) 74300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * int32_t timeSeconds 74400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 7457f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void 746f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCallForward(Parcel &p, RequestInfo *pRI) { 74700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_CallForwardInfo cff; 74800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t t; 74900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 75000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 75100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (&cff, 0, sizeof(cff)); 75200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 7537f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville // note we only check status at the end 75400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 75500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 75600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.status = (int)t; 7577f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 75800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 75900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.reason = (int)t; 76000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 76100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 76200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.serviceClass = (int)t; 76300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 76400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 76500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.toa = (int)t; 76600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 76700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.number = strdupReadString(p); 76800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 76900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&t); 77000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.timeSeconds = (int)t; 77100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 77200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 77300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 77400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 77500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 77600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // special case: number 0-length fields is null 77700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 77800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (cff.number != NULL && strlen (cff.number) == 0) { 77900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.number = NULL; 78000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 78100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 78200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 78300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%sstat=%d,reason=%d,serv=%d,toa=%d,%s,tout=%d", printBuf, 78400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cff.status, cff.reason, cff.serviceClass, cff.toa, 78500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)cff.number, cff.timeSeconds); 78600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 78700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 78800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 78900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, &cff, sizeof(cff), pRI); 79000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 79100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 79200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memsetString(cff.number); 79300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 79400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 79500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (cff.number); 79600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 79700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#ifdef MEMSET_FREED 79800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset(&cff, 0, sizeof(cff)); 79900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 80000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 80100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 80200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 80300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 80400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 80500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 80600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 80700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 8087f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void 809f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchRaw(Parcel &p, RequestInfo *pRI) { 81000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int32_t len; 81100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status_t status; 81200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const void *data; 81300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 81400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project status = p.readInt32(&len); 81500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 81600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (status != NO_ERROR) { 81700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto invalid; 81800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 81900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 82000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // The java code writes -1 for null arrays 82100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (((int)len) == -1) { 82200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project data = NULL; 82300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project len = 0; 8247f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville } 82500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 82600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project data = p.readInplace(len); 82700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 82800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startRequest; 82900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%sraw_size=%d", printBuf, len); 83000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeRequest; 83100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printRequest(pRI->token, pRI->pCI->requestNumber); 83200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 83300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_callbacks.onRequest(pRI->pCI->requestNumber, const_cast<void *>(data), len, pRI); 83400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 83500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 83600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectinvalid: 83700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project invalidCommandBlock(pRI); 83800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 83900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 84000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 8417f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void 842f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCdmaSms(Parcel &p, RequestInfo *pRI) { 843f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_CDMA_SMS_Message rcsm; 844f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t t; 845f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville uint8_t ut; 846f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status_t status; 847f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t digitCount; 848f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int digitLimit; 8497f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 850f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsm, 0, sizeof(rcsm)); 851f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 852f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 853f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.uTeleserviceID = (int) t; 854f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 855f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&ut,sizeof(ut)); 856f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.bIsServicePresent = (uint8_t) ut; 857f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 858f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 859f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.uServicecategory = (int) t; 860f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 861f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 862f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.digit_mode = (RIL_CDMA_SMS_DigitMode) t; 863f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 864f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 865f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.number_mode = (RIL_CDMA_SMS_NumberMode) t; 866f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 867f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 868f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.number_type = (RIL_CDMA_SMS_NumberType) t; 869f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 870f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 871f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.number_plan = (RIL_CDMA_SMS_NumberPlan) t; 872f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 873f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&ut,sizeof(ut)); 874f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.number_of_digits= (uint8_t) ut; 875f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 876f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((rcsm.sAddress.number_of_digits), RIL_CDMA_SMS_ADDRESS_MAX); 877f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 878f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&ut,sizeof(ut)); 879f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sAddress.digits[digitCount] = (uint8_t) ut; 880f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 881f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 8827f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville status = p.readInt32(&t); 883f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sSubAddress.subaddressType = (RIL_CDMA_SMS_SubaddressType) t; 884f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 8857f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville status = p.read(&ut,sizeof(ut)); 886f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sSubAddress.odd = (uint8_t) ut; 887f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 888f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&ut,sizeof(ut)); 889f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sSubAddress.number_of_digits = (uint8_t) ut; 890f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 891f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((rcsm.sSubAddress.number_of_digits), RIL_CDMA_SMS_SUBADDRESS_MAX); 8927f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 8937f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville status = p.read(&ut,sizeof(ut)); 894f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.sSubAddress.digits[digitCount] = (uint8_t) ut; 895f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 896f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 8977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville status = p.readInt32(&t); 898f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.uBearerDataLen = (int) t; 899f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 900f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((rcsm.uBearerDataLen), RIL_CDMA_SMS_BEARER_DATA_MAX); 9017f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 9027f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville status = p.read(&ut, sizeof(ut)); 903f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsm.aBearerData[digitCount] = (uint8_t) ut; 904f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 905f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 906f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (status != NO_ERROR) { 907f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville goto invalid; 908f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 909f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 910f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startRequest; 911f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville appendPrintBuf("%suTeleserviceID=%d, bIsServicePresent=%d, uServicecategory=%d, \ 9121b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville sAddress.digit_mode=%d, sAddress.Number_mode=%d, sAddress.number_type=%d, ", 913f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printBuf, rcsm.uTeleserviceID,rcsm.bIsServicePresent,rcsm.uServicecategory, 9141b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville rcsm.sAddress.digit_mode, rcsm.sAddress.number_mode,rcsm.sAddress.number_type); 915f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeRequest; 9167f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 917f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printRequest(pRI->token, pRI->pCI->requestNumber); 918f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 919f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsm, sizeof(rcsm),pRI); 920f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 921f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED 922f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsm, 0, sizeof(rcsm)); 923f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 924f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 925f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 926f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 927f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid: 928f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville invalidCommandBlock(pRI); 929f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 930f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 931f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 9327f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic void 933f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCdmaSmsAck(Parcel &p, RequestInfo *pRI) { 934f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_CDMA_SMS_Ack rcsa; 935f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t t; 936f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status_t status; 937f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t digitCount; 938f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 939f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsa, 0, sizeof(rcsa)); 940f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 941f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 942f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsa.uErrorClass = (RIL_CDMA_SMS_ErrorClass) t; 943f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 944f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 945f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsa.uSMSCauseCode = (int) t; 946f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 947f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (status != NO_ERROR) { 948f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville goto invalid; 949f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 950f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 951f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startRequest; 9521b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville appendPrintBuf("%suErrorClass=%d, uTLStatus=%d, ", 9531b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville printBuf, rcsa.uErrorClass, rcsa.uSMSCauseCode); 954f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeRequest; 955f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 956f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printRequest(pRI->token, pRI->pCI->requestNumber); 957f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 958f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsa, sizeof(rcsa),pRI); 959f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 960f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED 961f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsa, 0, sizeof(rcsa)); 962f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 963f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 964f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 965f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 966f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid: 967f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville invalidCommandBlock(pRI); 968f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 969f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 970f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 971a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void 972a592eebc476a3d234f47f93e58252f8c822fc772Wink SavilledispatchGsmBrSmsCnf(Parcel &p, RequestInfo *pRI) { 973a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int32_t t; 974f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status_t status; 975a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int32_t num; 976f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 977a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&num); 978a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (status != NO_ERROR) { 979a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville goto invalid; 980a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 981f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 982a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_GSM_BroadcastSmsConfigInfo gsmBci[num]; 983a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_GSM_BroadcastSmsConfigInfo *gsmBciPtrs[num]; 984f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 985a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville startRequest; 986a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < num ; i++ ) { 987a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBciPtrs[i] = &gsmBci[i]; 988f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 989a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 990a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].fromServiceId = (int) t; 991f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 992a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 993a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].toServiceId = (int) t; 994f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 995a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 996a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].fromCodeScheme = (int) t; 997f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 998a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 999a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].toCodeScheme = (int) t; 1000a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1001a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1002a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].selected = (uint8_t) t; 1003a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1004a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s [%d: fromServiceId=%d, toServiceId =%d, \ 1005a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville fromCodeScheme=%d, toCodeScheme=%d, selected =%d]", printBuf, i, 1006a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].fromServiceId, gsmBci[i].toServiceId, 1007a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].fromCodeScheme, gsmBci[i].toCodeScheme, 1008a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBci[i].selected); 1009a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1010f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeRequest; 1011f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1012a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (status != NO_ERROR) { 1013a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville goto invalid; 1014a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1015f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1016a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, 1017a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville gsmBciPtrs, 1018a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville num * sizeof(RIL_GSM_BroadcastSmsConfigInfo *), 1019a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville pRI); 1020f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1021f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED 1022a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville memset(gsmBci, 0, num * sizeof(RIL_GSM_BroadcastSmsConfigInfo)); 1023a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville memset(gsmBciPtrs, 0, num * sizeof(RIL_GSM_BroadcastSmsConfigInfo *)); 1024f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 1025f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1026f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1027f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1028f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid: 1029f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville invalidCommandBlock(pRI); 1030f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1031f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 1032f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1033a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void 1034f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilledispatchCdmaBrSmsCnf(Parcel &p, RequestInfo *pRI) { 1035a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int32_t t; 1036f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status_t status; 1037a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int32_t num; 1038f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1039a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&num); 1040a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (status != NO_ERROR) { 1041a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville goto invalid; 1042a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1043a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1044a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_BroadcastSmsConfigInfo cdmaBci[num]; 1045a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_BroadcastSmsConfigInfo *cdmaBciPtrs[num]; 1046a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1047a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville startRequest; 1048a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < num ; i++ ) { 1049a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBciPtrs[i] = &cdmaBci[i]; 1050f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1051a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1052a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBci[i].service_category = (int) t; 1053f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville 1054a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1055a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBci[i].language = (int) t; 1056f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville 1057a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1058a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBci[i].selected = (uint8_t) t; 1059f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1060a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s [%d: service_category=%d, language =%d, \ 1061a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville entries.bSelected =%d]", printBuf, i, cdmaBci[i].service_category, 1062a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBci[i].language, cdmaBci[i].selected); 1063f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville } 1064a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville closeRequest; 1065f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1066f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (status != NO_ERROR) { 1067f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville goto invalid; 1068f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1069f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1070f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, 1071a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville cdmaBciPtrs, 1072a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo *), 1073f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville pRI); 1074f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1075f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED 1076a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville memset(cdmaBci, 0, num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo)); 1077a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville memset(cdmaBciPtrs, 0, num * sizeof(RIL_CDMA_BroadcastSmsConfigInfo *)); 1078f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 1079f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1080f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1081f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1082f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid: 1083f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville invalidCommandBlock(pRI); 1084f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1085f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 1086f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1087f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void dispatchRilCdmaSmsWriteArgs(Parcel &p, RequestInfo *pRI) { 1088f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_CDMA_SMS_WriteArgs rcsw; 1089f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t t; 1090f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville uint32_t ut; 1091f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville uint8_t uct; 1092f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status_t status; 1093f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int32_t digitCount; 1094f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1095f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsw, 0, sizeof(rcsw)); 1096f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1097f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1098f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.status = t; 1099a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1100f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1101f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.uTeleserviceID = (int) t; 1102f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1103f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&uct,sizeof(uct)); 1104f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.bIsServicePresent = (uint8_t) uct; 1105f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1106f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1107f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.uServicecategory = (int) t; 1108f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1109f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1110f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.digit_mode = (RIL_CDMA_SMS_DigitMode) t; 1111f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1112f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1113f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.number_mode = (RIL_CDMA_SMS_NumberMode) t; 1114f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1115f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1116f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.number_type = (RIL_CDMA_SMS_NumberType) t; 1117f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1118f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.readInt32(&t); 1119f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.number_plan = (RIL_CDMA_SMS_NumberPlan) t; 1120f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1121f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&uct,sizeof(uct)); 1122f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.number_of_digits = (uint8_t) uct; 1123f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1124f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_ADDRESS_MAX; digitCount ++) { 1125f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&uct,sizeof(uct)); 1126f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sAddress.digits[digitCount] = (uint8_t) uct; 1127f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1128f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1129a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1130f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sSubAddress.subaddressType = (RIL_CDMA_SMS_SubaddressType) t; 1131f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1132a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.read(&uct,sizeof(uct)); 1133f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sSubAddress.odd = (uint8_t) uct; 1134f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1135f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville status = p.read(&uct,sizeof(uct)); 1136f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sSubAddress.number_of_digits = (uint8_t) uct; 1137f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1138f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_SUBADDRESS_MAX; digitCount ++) { 1139a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.read(&uct,sizeof(uct)); 1140f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.sSubAddress.digits[digitCount] = (uint8_t) uct; 1141f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1142f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1143a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.readInt32(&t); 1144f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.uBearerDataLen = (int) t; 1145f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1146f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount = 0 ; digitCount < RIL_CDMA_SMS_BEARER_DATA_MAX; digitCount ++) { 1147a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville status = p.read(&uct, sizeof(uct)); 1148f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville rcsw.message.aBearerData[digitCount] = (uint8_t) uct; 1149f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1150f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1151f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (status != NO_ERROR) { 1152f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville goto invalid; 1153f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1154f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1155f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startRequest; 11561b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville appendPrintBuf("%sstatus=%d, message.uTeleserviceID=%d, message.bIsServicePresent=%d, \ 11571b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville message.uServicecategory=%d, message.sAddress.digit_mode=%d, \ 11581b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville message.sAddress.number_mode=%d, \ 11591b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville message.sAddress.number_type=%d, ", 1160f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printBuf, rcsw.status, rcsw.message.uTeleserviceID, rcsw.message.bIsServicePresent, 11611b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville rcsw.message.uServicecategory, rcsw.message.sAddress.digit_mode, 11621b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville rcsw.message.sAddress.number_mode, 11631b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville rcsw.message.sAddress.number_type); 1164f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeRequest; 1165f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1166f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printRequest(pRI->token, pRI->pCI->requestNumber); 1167f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1168f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville s_callbacks.onRequest(pRI->pCI->requestNumber, &rcsw, sizeof(rcsw),pRI); 1169f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1170f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#ifdef MEMSET_FREED 1171f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville memset(&rcsw, 0, sizeof(rcsw)); 1172f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 1173f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1174f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1175f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1176f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savilleinvalid: 1177f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville invalidCommandBlock(pRI); 1178f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 1179f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1180f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 1181f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 118200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int 1183f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleblockingWrite(int fd, const void *buffer, size_t len) { 11847f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville size_t writeOffset = 0; 118500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const uint8_t *toWrite; 118600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 118700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project toWrite = (const uint8_t *)buffer; 118800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 118900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project while (writeOffset < len) { 119000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ssize_t written; 119100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project do { 119200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project written = write (fd, toWrite + writeOffset, 119300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project len - writeOffset); 119400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } while (written < 0 && errno == EINTR); 119500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 119600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (written >= 0) { 119700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeOffset += written; 119800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { // written < 0 119900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("RIL Response: unexpected error on write errno:%d", errno); 120000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project close(fd); 120100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return -1; 120200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 120300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 120400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 120500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 120600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 120700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 120800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int 1209f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillesendResponseRaw (const void *data, size_t dataSize) { 121000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int fd = s_fdCommand; 121100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 121200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project uint32_t header; 121300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 121400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_fdCommand < 0) { 121500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return -1; 121600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 121700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 121800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (dataSize > MAX_COMMAND_BYTES) { 121900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("RIL: packet larger than %u (%u)", 122000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project MAX_COMMAND_BYTES, (unsigned int )dataSize); 122100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 122200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return -1; 122300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 12247f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 122500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_lock(&s_writeMutex); 122600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 122700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project header = htonl(dataSize); 122800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 122900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = blockingWrite(fd, (void *)&header, sizeof(header)); 123000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 123100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 1232084f6708312265b501561a9c6d6e9cb38943985cJaikumar Ganesh pthread_mutex_unlock(&s_writeMutex); 123300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return ret; 123400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 123500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1236ee1fadc192a63724e416b05666844a62d1e75d38Kenny ret = blockingWrite(fd, data, dataSize); 123700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 123800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 1239084f6708312265b501561a9c6d6e9cb38943985cJaikumar Ganesh pthread_mutex_unlock(&s_writeMutex); 124000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return ret; 124100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 124200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 124300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_unlock(&s_writeMutex); 124400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 124500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 124600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 124700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 124800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int 1249f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillesendResponse (Parcel &p) { 125000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project printResponse; 125100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return sendResponseRaw(p.data(), p.dataSize()); 125200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 125300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 125400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** response is an int* pointing to an array of ints*/ 12557f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 12567f8568086f2ea14885b0091c793e14c2656f0da2Wink Savillestatic int 1257f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleresponseInts(Parcel &p, void *response, size_t responselen) { 125800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int numInts; 125900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 126000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 126100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 126200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 126300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 126400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen % sizeof(int) != 0) { 12657f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid response length %d expected multiple of %d\n", 126600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof(int)); 126700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 126800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 126900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 127000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int *p_int = (int *) response; 127100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 127200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project numInts = responselen / sizeof(int *); 127300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (numInts); 127400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 127500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* each int*/ 127600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 127700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < numInts ; i++) { 127800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%d,", printBuf, p_int[i]); 127900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_int[i]); 128000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 128100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 128200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 128300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 128400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 128500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 128600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 128700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** response is a char **, pointing to an array of char *'s */ 1288f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseStrings(Parcel &p, void *response, size_t responselen) { 128900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int numStrings; 12907f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 129100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 129200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 129300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 129400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 129500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen % sizeof(char *) != 0) { 12967f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid response length %d expected multiple of %d\n", 129700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof(char *)); 129800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 129900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 130000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 130100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL) { 130200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (0); 130300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 130400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char **p_cur = (char **) response; 130500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 130600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project numStrings = responselen / sizeof(char *); 130700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (numStrings); 130800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 130900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* each string*/ 131000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 131100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < numStrings ; i++) { 131200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%s,", printBuf, (char*)p_cur[i]); 131300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel (p, p_cur[i]); 131400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 131500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 131600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 131700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 131800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 131900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 132000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 132100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 132200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** 13237f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville * NULL strings are accepted 132400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * FIXME currently ignores responselen 132500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 1326f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseString(Parcel &p, void *response, size_t responselen) { 132700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* one string only */ 132800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 132900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%s", printBuf, (char*)response); 133000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 133100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 133200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, (const char *)response); 133300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 133400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 133500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 133600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1337f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseVoid(Parcel &p, void *response, size_t responselen) { 133800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 133900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 134000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 134100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 134200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1343f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCallList(Parcel &p, void *response, size_t responselen) { 134400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int num; 134500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 134600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 134700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 134800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 134900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 135000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 135100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen % sizeof (RIL_Call *) != 0) { 13523d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response length %d expected multiple of %d\n", 135300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof (RIL_Call *)); 135400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 135500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 135600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 135700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 135800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* number of call info's */ 135900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project num = responselen / sizeof(RIL_Call *); 136000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(num); 136100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 136200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < num ; i++) { 136300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_Call *p_cur = ((RIL_Call **) response)[i]; 136400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* each call info */ 136500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->state); 136600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->index); 136700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->toa); 136800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->isMpty); 136900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->isMT); 137000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->als); 137100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->isVoice); 13721b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p.writeInt32(p_cur->isVoicePrivacy); 13731b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville writeStringToParcel(p, p_cur->number); 13741b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p.writeInt32(p_cur->numberPresentation); 13751b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville writeStringToParcel(p, p_cur->name); 13761b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p.writeInt32(p_cur->namePresentation); 13773a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville // Remove when partners upgrade to version 3 137874fa38884320698c1623764850e3131b9769dff0Wink Saville if ((s_callbacks.version < 3) || (p_cur->uusInfo == NULL || p_cur->uusInfo->uusData == NULL)) { 137974fa38884320698c1623764850e3131b9769dff0Wink Saville p.writeInt32(0); /* UUS Information is absent */ 138074fa38884320698c1623764850e3131b9769dff0Wink Saville } else { 138174fa38884320698c1623764850e3131b9769dff0Wink Saville RIL_UUS_Info *uusInfo = p_cur->uusInfo; 138274fa38884320698c1623764850e3131b9769dff0Wink Saville p.writeInt32(1); /* UUS Information is present */ 138374fa38884320698c1623764850e3131b9769dff0Wink Saville p.writeInt32(uusInfo->uusType); 138474fa38884320698c1623764850e3131b9769dff0Wink Saville p.writeInt32(uusInfo->uusDcs); 138574fa38884320698c1623764850e3131b9769dff0Wink Saville p.writeInt32(uusInfo->uusLength); 138674fa38884320698c1623764850e3131b9769dff0Wink Saville p.write(uusInfo->uusData, uusInfo->uusLength); 138774fa38884320698c1623764850e3131b9769dff0Wink Saville } 13883d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville appendPrintBuf("%s[id=%d,%s,toa=%d,", 13891b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville printBuf, 13901b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->index, 13911b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville callStateToString(p_cur->state), 13923d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->toa); 13933d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville appendPrintBuf("%s%s,%s,als=%d,%s,%s,", 13943d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville printBuf, 13951b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville (p_cur->isMpty)?"conf":"norm", 13961b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville (p_cur->isMT)?"mt":"mo", 13971b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->als, 13981b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville (p_cur->isVoice)?"voc":"nonvoc", 13993d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville (p_cur->isVoicePrivacy)?"evp":"noevp"); 14003d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville appendPrintBuf("%s%s,cli=%d,name='%s',%d]", 14013d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville printBuf, 14021b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->number, 14031b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->numberPresentation, 14041b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->name, 14051b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville p_cur->namePresentation); 140600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 140700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 140800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 140900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 141000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 141100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 141200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1413f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSMS(Parcel &p, void *response, size_t responselen) { 141400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL) { 141500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 141600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 141700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 141800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 141900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen != sizeof (RIL_SMS_Response) ) { 14207f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid response length %d expected %d", 142100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof (RIL_SMS_Response)); 142200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 142300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 142400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 142500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_SMS_Response *p_cur = (RIL_SMS_Response *) response; 142600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 142700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->messageRef); 142800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur->ackPDU); 1429920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh p.writeInt32(p_cur->errorCode); 143000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 143100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 1432920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh appendPrintBuf("%s%d,%s,%d", printBuf, p_cur->messageRef, 1433920c78f166e787dc799bf5df7d6be30034ac0e77Jaikumar Ganesh (char*)p_cur->ackPDU, p_cur->errorCode); 143400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 143500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 143600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 143700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 143800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1439f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseDataCallList(Parcel &p, void *response, size_t responselen) 144000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{ 144100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 144200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 144300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 144400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 144500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1446f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (responselen % sizeof(RIL_Data_Call_Response) != 0) { 14477f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid response length %d expected multiple of %d", 1448f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville (int)responselen, (int)sizeof(RIL_Data_Call_Response)); 144900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 145000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 145100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1452f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int num = responselen / sizeof(RIL_Data_Call_Response); 145300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(num); 145400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1455f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_Data_Call_Response *p_cur = (RIL_Data_Call_Response *) response; 145600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 145700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int i; 145800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (i = 0; i < num; i++) { 145900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur[i].cid); 146000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur[i].active); 146100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur[i].type); 146200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur[i].apn); 146300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur[i].address); 146400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s[cid=%d,%s,%s,%s,%s],", printBuf, 146500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur[i].cid, 146600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (p_cur[i].active==0)?"down":"up", 146700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur[i].type, 146800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur[i].apn, 146900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur[i].address); 147000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 147100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 147200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 147300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 147400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 147500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 147600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1477f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseRaw(Parcel &p, void *response, size_t responselen) { 147800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 147900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL with responselen != 0"); 148000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 148100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 148200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 148300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // The java code reads -1 size as null byte array 148400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL) { 14857f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville p.writeInt32(-1); 148600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 148700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(responselen); 148800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.write(response, responselen); 148900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 149000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 149100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 149200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 149300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 149400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1495f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSIM_IO(Parcel &p, void *response, size_t responselen) { 149600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL) { 149700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 149800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 149900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 150000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 150100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen != sizeof (RIL_SIM_IO_Response) ) { 150200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response length was %d expected %d", 150300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof (RIL_SIM_IO_Response)); 150400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 150500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 150600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 150700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_SIM_IO_Response *p_cur = (RIL_SIM_IO_Response *) response; 150800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->sw1); 150900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->sw2); 151000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur->simResponse); 151100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 151200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 151300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%ssw1=0x%X,sw2=0x%X,%s", printBuf, p_cur->sw1, p_cur->sw2, 151400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur->simResponse); 151500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 151600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 151700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 151800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 151900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 152000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1521f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCallForwards(Parcel &p, void *response, size_t responselen) { 152200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int num; 15237f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 152400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 152500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 152600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 152700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 152800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 152900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen % sizeof(RIL_CallForwardInfo *) != 0) { 15307f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville LOGE("invalid response length %d expected multiple of %d", 153100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof(RIL_CallForwardInfo *)); 153200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 153300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 153400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 153500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* number of call info's */ 153600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project num = responselen / sizeof(RIL_CallForwardInfo *); 153700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(num); 153800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 153900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 154000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < num ; i++) { 154100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_CallForwardInfo *p_cur = ((RIL_CallForwardInfo **) response)[i]; 154200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 154300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->status); 154400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->reason); 154500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->serviceClass); 154600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->toa); 154700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur->number); 154800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->timeSeconds); 154900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s[%s,reason=%d,cls=%d,toa=%d,%s,tout=%d],", printBuf, 155000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (p_cur->status==1)?"enable":"disable", 155100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur->reason, p_cur->serviceClass, p_cur->toa, 155200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur->number, 155300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur->timeSeconds); 155400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 155500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 155600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 15577f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 155800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 155900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 156000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1561f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSsn(Parcel &p, void *response, size_t responselen) { 156200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL) { 156300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 156400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 156500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 156600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 156700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen != sizeof(RIL_SuppSvcNotification)) { 156800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response length was %d expected %d", 156900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof (RIL_SuppSvcNotification)); 157000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 157100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 157200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 157300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_SuppSvcNotification *p_cur = (RIL_SuppSvcNotification *) response; 157400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->notificationType); 157500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->code); 157600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->index); 157700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->type); 157800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel(p, p_cur->number); 157900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 158000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 158100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s%s,code=%d,id=%d,type=%d,%s", printBuf, 158200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (p_cur->notificationType==0)?"mo":"mt", 158300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur->code, p_cur->index, p_cur->type, 158400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (char*)p_cur->number); 158500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 158600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 158700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 158800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 158900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 15903d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCellList(Parcel &p, void *response, size_t responselen) { 159100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int num; 159200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 159300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (response == NULL && responselen != 0) { 159400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response: NULL"); 159500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 159600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 159700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 159800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (responselen % sizeof (RIL_NeighboringCell *) != 0) { 159900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("invalid response length %d expected multiple of %d\n", 160000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project (int)responselen, (int)sizeof (RIL_NeighboringCell *)); 160100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return RIL_ERRNO_INVALID_RESPONSE; 160200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 160300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 160400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project startResponse; 16053d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville /* number of records */ 160600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project num = responselen / sizeof(RIL_NeighboringCell *); 160700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(num); 160800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 160900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0 ; i < num ; i++) { 161000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_NeighboringCell *p_cur = ((RIL_NeighboringCell **) response)[i]; 161100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 161200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(p_cur->rssi); 161300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project writeStringToParcel (p, p_cur->cid); 161400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 161500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s[cid=%s,rssi=%d],", printBuf, 161600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur->cid, p_cur->rssi); 161700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 161800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project removeLastChar; 161900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project closeResponse; 162000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 162100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 162200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 162300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 16243d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville/** 16253d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville * Marshall the signalInfoRecord into the parcel if it exists. 16263d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville */ 1627a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic void marshallSignalInfoRecord(Parcel &p, 1628a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_SignalInfoRecord &p_signalInfoRecord) { 16293d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_signalInfoRecord.isPresent); 16303d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_signalInfoRecord.signalType); 16313d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_signalInfoRecord.alertPitch); 16323d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_signalInfoRecord.signal); 16333d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 16343d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1635a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaInformationRecords(Parcel &p, 1636a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville void *response, size_t responselen) { 16373d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville int num; 1638a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville char* string8 = NULL; 1639a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int buffer_lenght; 1640a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_InformationRecord *infoRec; 16413d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 16423d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if (response == NULL && responselen != 0) { 16433d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response: NULL"); 16443d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 16453d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 16463d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1647a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (responselen != sizeof (RIL_CDMA_InformationRecords)) { 1648a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("invalid response length %d expected multiple of %d\n", 1649a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)responselen, (int)sizeof (RIL_CDMA_InformationRecords *)); 16503d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 16513d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 16523d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1653a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_InformationRecords *p_cur = 1654a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (RIL_CDMA_InformationRecords *) response; 1655a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville num = MIN(p_cur->numberOfInfoRecs, RIL_CDMA_MAX_NUMBER_OF_INFO_RECS); 16563d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 16573d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville startResponse; 1658a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(num); 16593d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1660a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < num ; i++) { 1661a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville infoRec = &p_cur->infoRec[i]; 1662a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->name); 1663a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville switch (infoRec->name) { 16643d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_DISPLAY_INFO_REC: 1665a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_CDMA_EXTENDED_DISPLAY_INFO_REC: 1666a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (infoRec->rec.display.alpha_len > 1667a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_ALPHA_INFO_BUFFER_LENGTH) { 1668a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("invalid display info response length %d \ 1669a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville expected not more than %d\n", 1670a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.display.alpha_len, 1671a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_ALPHA_INFO_BUFFER_LENGTH); 1672a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return RIL_ERRNO_INVALID_RESPONSE; 16733d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 1674a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = (char*) malloc((infoRec->rec.display.alpha_len + 1) 1675a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville * sizeof(char) ); 1676a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < infoRec->rec.display.alpha_len ; i++) { 1677a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[i] = infoRec->rec.display.alpha_buf[i]; 16783d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 1679a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[infoRec->rec.display.alpha_len] = '\0'; 1680a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville writeStringToParcel(p, (const char*)string8); 1681a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville free(string8); 1682a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = NULL; 16833d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 1684a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_CDMA_CALLED_PARTY_NUMBER_INFO_REC: 16853d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_CALLING_PARTY_NUMBER_INFO_REC: 16863d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_CONNECTED_NUMBER_INFO_REC: 1687a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (infoRec->rec.number.len > CDMA_NUMBER_INFO_BUFFER_LENGTH) { 1688a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("invalid display info response length %d \ 1689a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville expected not more than %d\n", 1690a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.number.len, 1691a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_NUMBER_INFO_BUFFER_LENGTH); 1692a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return RIL_ERRNO_INVALID_RESPONSE; 16933d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 1694a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = (char*) malloc((infoRec->rec.number.len + 1) 1695a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville * sizeof(char) ); 1696a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < infoRec->rec.number.len; i++) { 1697a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[i] = infoRec->rec.number.buf[i]; 1698a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1699a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[infoRec->rec.number.len] = '\0'; 1700a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville writeStringToParcel(p, (const char*)string8); 1701a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville free(string8); 1702a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = NULL; 1703a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.number.number_type); 1704a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.number.number_plan); 1705a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.number.pi); 1706a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.number.si); 17073d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 17083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_SIGNAL_INFO_REC: 1709a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.signal.isPresent); 1710a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.signal.signalType); 1711a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.signal.alertPitch); 1712a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.signal.signal); 1713a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1714a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%sisPresent=%X, signalType=%X, \ 1715a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville alertPitch=%X, signal=%X, ", 1716a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville printBuf, (int)infoRec->rec.signal.isPresent, 1717a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.signal.signalType, 1718a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.signal.alertPitch, 1719a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.signal.signal); 1720a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville removeLastChar; 17213d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 17223d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_REDIRECTING_NUMBER_INFO_REC: 1723a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (infoRec->rec.redir.redirectingNumber.len > 1724a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_NUMBER_INFO_BUFFER_LENGTH) { 1725a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("invalid display info response length %d \ 1726a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville expected not more than %d\n", 1727a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.redir.redirectingNumber.len, 1728a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_NUMBER_INFO_BUFFER_LENGTH); 1729a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return RIL_ERRNO_INVALID_RESPONSE; 1730a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1731a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = (char*) malloc((infoRec->rec.redir.redirectingNumber 1732a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville .len + 1) * sizeof(char) ); 1733a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0; 1734a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville i < infoRec->rec.redir.redirectingNumber.len; 1735a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville i++) { 1736a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[i] = infoRec->rec.redir.redirectingNumber.buf[i]; 17373d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 1738a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8[infoRec->rec.redir.redirectingNumber.len] = '\0'; 1739a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville writeStringToParcel(p, (const char*)string8); 1740a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville free(string8); 1741a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville string8 = NULL; 1742a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.redir.redirectingNumber.number_type); 1743a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.redir.redirectingNumber.number_plan); 1744a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.redir.redirectingNumber.pi); 1745a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.redir.redirectingNumber.si); 1746a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.redir.redirectingReason); 17473d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 17483d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_LINE_CONTROL_INFO_REC: 1749a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.lineCtrl.lineCtrlPolarityIncluded); 1750a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.lineCtrl.lineCtrlToggle); 1751a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.lineCtrl.lineCtrlReverse); 1752a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.lineCtrl.lineCtrlPowerDenial); 1753a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1754a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%slineCtrlPolarityIncluded=%d, \ 1755a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville lineCtrlToggle=%d, lineCtrlReverse=%d, \ 1756a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville lineCtrlPowerDenial=%d, ", printBuf, 1757a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.lineCtrl.lineCtrlPolarityIncluded, 1758a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.lineCtrl.lineCtrlToggle, 1759a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.lineCtrl.lineCtrlReverse, 1760a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (int)infoRec->rec.lineCtrl.lineCtrlPowerDenial); 1761a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville removeLastChar; 17623d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 17633d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_T53_CLIR_INFO_REC: 1764a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32((int)(infoRec->rec.clir.cause)); 17653d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1766a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%scause%d", printBuf, infoRec->rec.clir.cause); 1767a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville removeLastChar; 17683d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 17693d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_CDMA_T53_AUDIO_CONTROL_INFO_REC: 1770a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.audioCtrl.upLink); 1771a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(infoRec->rec.audioCtrl.downLink); 1772a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1773a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%supLink=%d, downLink=%d, ", printBuf, 1774a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville infoRec->rec.audioCtrl.upLink, 1775a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville infoRec->rec.audioCtrl.downLink); 1776a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville removeLastChar; 17773d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville break; 1778a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_CDMA_T53_RELEASE_INFO_REC: 1779a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville // TODO(Moto): See David Krause, he has the answer:) 1780a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("RIL_CDMA_T53_RELEASE_INFO_REC: return INVALID_RESPONSE"); 1781a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return RIL_ERRNO_INVALID_RESPONSE; 1782a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville default: 1783a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville LOGE("Incorrect name value"); 1784a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return RIL_ERRNO_INVALID_RESPONSE; 17853d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 17863d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 1787a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville closeResponse; 17883d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1789a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville return 0; 17903d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 17913d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1792a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseRilSignalStrength(Parcel &p, 1793a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville void *response, size_t responselen) { 1794a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (response == NULL && responselen != 0) { 17953d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response: NULL"); 17963d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 17973d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 17983d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1799a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville if (responselen == sizeof (RIL_SignalStrength)) { 18003d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville // New RIL 18013d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville RIL_SignalStrength *p_cur = ((RIL_SignalStrength *) response); 18023d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18033d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->GW_SignalStrength.signalStrength); 18043d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->GW_SignalStrength.bitErrorRate); 18053d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->CDMA_SignalStrength.dbm); 18063d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->CDMA_SignalStrength.ecio); 18073d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->EVDO_SignalStrength.dbm); 18083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->EVDO_SignalStrength.ecio); 18093d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->EVDO_SignalStrength.signalNoiseRatio); 1810fdf825f9d0dc639787b8523638bb61874ed0b540johnwang 1811fdf825f9d0dc639787b8523638bb61874ed0b540johnwang startResponse; 1812a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s[signalStrength=%d,bitErrorRate=%d,\ 1813a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville CDMA_SignalStrength.dbm=%d,CDMA_SignalStrength.ecio=%d,\ 1814a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville EVDO_SignalStrength.dbm =%d,EVDO_SignalStrength.ecio=%d,\ 1815a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville EVDO_SignalStrength.signalNoiseRatio=%d]", 1816a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville printBuf, 1817a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->GW_SignalStrength.signalStrength, 1818a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->GW_SignalStrength.bitErrorRate, 1819a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->CDMA_SignalStrength.dbm, 1820a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->CDMA_SignalStrength.ecio, 1821a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->EVDO_SignalStrength.dbm, 1822a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->EVDO_SignalStrength.ecio, 1823a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur->EVDO_SignalStrength.signalNoiseRatio); 1824a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1825a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville closeResponse; 1826a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1827a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } else if (responselen % sizeof (int) == 0) { 1828a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville // Old RIL deprecated 1829a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int *p_cur = (int *) response; 1830a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1831a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville startResponse; 1832a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1833a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville // With the Old RIL we see one or 2 integers. 1834a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville size_t num = responselen / sizeof (int); // Number of integers from ril 1835a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville size_t totalIntegers = 7; // Number of integers in RIL_SignalStrength 1836a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville size_t i; 1837a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1838a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s[", printBuf); 1839a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (i = 0; i < num; i++) { 1840a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s %d", printBuf, *p_cur); 1841a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(*p_cur++); 1842a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1843a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s]", printBuf); 1844a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1845a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville // Fill the remainder with zero's. 1846a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (; i < totalIntegers; i++) { 1847a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(0); 1848a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 1849a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 1850fdf825f9d0dc639787b8523638bb61874ed0b540johnwang closeResponse; 18513d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } else { 18523d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response length"); 18533d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 18543d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 18553d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18563d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return 0; 18573d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 18583d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18593d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCallRing(Parcel &p, void *response, size_t responselen) { 18603d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if ((response == NULL) || (responselen == 0)) { 18613d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return responseVoid(p, response, responselen); 18623d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } else { 18633d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return responseCdmaSignalInfoRecord(p, response, responselen); 18643d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 18653d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 18663d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18673d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic int responseCdmaSignalInfoRecord(Parcel &p, void *response, size_t responselen) { 18683d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if (response == NULL || responselen == 0) { 18693d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response: NULL"); 18703d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 18713d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 18723d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18733d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if (responselen != sizeof (RIL_CDMA_SignalInfoRecord)) { 18743d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response length %d expected sizeof (RIL_CDMA_SignalInfoRecord) of %d\n", 18753d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville (int)responselen, (int)sizeof (RIL_CDMA_SignalInfoRecord)); 18763d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 18773d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 18783d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18793d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville startResponse; 18803d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18813d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville RIL_CDMA_SignalInfoRecord *p_cur = ((RIL_CDMA_SignalInfoRecord *) response); 18823d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville marshallSignalInfoRecord(p, *p_cur); 18833d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18843d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville appendPrintBuf("%s[isPresent=%d,signalType=%d,alertPitch=%d\ 18853d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville signal=%d]", 18863d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville printBuf, 18873d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->isPresent, 18883d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signalType, 18893d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->alertPitch, 18903d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signal); 18913d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 18923d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville closeResponse; 18933d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return 0; 18943d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 18953d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 1896a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaCallWaiting(Parcel &p, void *response, 1897a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville size_t responselen) { 18983d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if (response == NULL && responselen != 0) { 18993d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response: NULL"); 19003d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 19013d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 19023d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19033d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville if (responselen != sizeof(RIL_CDMA_CallWaiting)) { 19043d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response length %d expected %d\n", 19053d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville (int)responselen, (int)sizeof(RIL_CDMA_CallWaiting)); 19063d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return RIL_ERRNO_INVALID_RESPONSE; 19073d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville } 19083d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19093d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville startResponse; 19103d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville RIL_CDMA_CallWaiting *p_cur = ((RIL_CDMA_CallWaiting *) response); 19113d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19123d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville writeStringToParcel (p, p_cur->number); 19133d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p.writeInt32(p_cur->numberPresentation); 19143d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville writeStringToParcel (p, p_cur->name); 19153d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville marshallSignalInfoRecord(p, p_cur->signalInfoRecord); 19163d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19173d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville appendPrintBuf("%snumber=%s,numberPresentation=%d, name=%s,\ 19183d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville signalInfoRecord[isPresent=%d,signalType=%d,alertPitch=%d\ 19193d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville signal=%d]", 19203d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville printBuf, 19213d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->number, 19223d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->numberPresentation, 19233d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->name, 19243d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signalInfoRecord.isPresent, 19253d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signalInfoRecord.signalType, 19263d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signalInfoRecord.alertPitch, 19273d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville p_cur->signalInfoRecord.signal); 19283d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19293d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville closeResponse; 19303d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19313d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville return 0; 19323d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 19333d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville 19343d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic void triggerEvLoop() { 193500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 193600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (!pthread_equal(pthread_self(), s_tid_dispatch)) { 193700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* trigger event loop to wakeup. No reason to do this, 193800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * if we're in the event loop thread */ 193900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project do { 194000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = write (s_fdWakeupWrite, " ", 1); 194100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } while (ret < 0 && errno == EINTR); 194200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 194300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 194400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 19453d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Savillestatic void rilEventAddWakeup(struct ril_event *ev) { 194600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_add(ev); 194700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project triggerEvLoop(); 194800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 194900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 1950f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseSimStatus(Parcel &p, void *response, size_t responselen) { 1951f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int i; 1952f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1953f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (response == NULL && responselen != 0) { 1954f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGE("invalid response: NULL"); 1955f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return RIL_ERRNO_INVALID_RESPONSE; 1956f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1957f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1958f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (responselen % sizeof (RIL_CardStatus *) != 0) { 19593d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville LOGE("invalid response length %d expected multiple of %d\n", 1960f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville (int)responselen, (int)sizeof (RIL_CardStatus *)); 1961f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return RIL_ERRNO_INVALID_RESPONSE; 1962f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1963f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1964f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_CardStatus *p_cur = ((RIL_CardStatus *) response); 1965f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1966f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->card_state); 1967f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->universal_pin_state); 1968f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->gsm_umts_subscription_app_index); 1969f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->cdma_subscription_app_index); 1970f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->num_applications); 1971f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1972f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startResponse; 1973f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for (i = 0; i < p_cur->num_applications; i++) { 1974f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].app_type); 1975f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].app_state); 1976f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].perso_substate); 1977a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville writeStringToParcel(p, (const char*)(p_cur->applications[i].aid_ptr)); 1978a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville writeStringToParcel(p, (const char*) 1979a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (p_cur->applications[i].app_label_ptr)); 1980f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].pin1_replaced); 1981f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].pin1); 1982f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->applications[i].pin2); 1983a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s[app_type=%d,app_state=%d,perso_substate=%d,\ 1984a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville aid_ptr=%s,app_label_ptr=%s,pin1_replaced=%d,pin1=%d,pin2=%d],", 1985f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printBuf, 1986f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].app_type, 1987f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].app_state, 1988f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].perso_substate, 1989f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].aid_ptr, 1990f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].app_label_ptr, 1991f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].pin1_replaced, 1992f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].pin1, 1993f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->applications[i].pin2); 1994f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 1995f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeResponse; 1996f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 1997f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return 0; 19983d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville} 1999f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2000a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseGsmBrSmsCnf(Parcel &p, void *response, size_t responselen) { 2001a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int num = responselen / sizeof(RIL_GSM_BroadcastSmsConfigInfo *); 2002f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(num); 2003f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2004f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startResponse; 2005a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_GSM_BroadcastSmsConfigInfo **p_cur = 2006a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (RIL_GSM_BroadcastSmsConfigInfo **) response; 2007a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0; i < num; i++) { 2008a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->fromServiceId); 2009a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->toServiceId); 2010a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->fromCodeScheme); 2011a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->toCodeScheme); 2012a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->selected); 2013a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville 2014a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s [%d: fromServiceId=%d, toServiceId=%d, \ 2015a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville fromCodeScheme=%d, toCodeScheme=%d, selected =%d]", 2016a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville printBuf, i, p_cur[i]->fromServiceId, p_cur[i]->toServiceId, 2017a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur[i]->fromCodeScheme, p_cur[i]->toCodeScheme, 2018a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur[i]->selected); 2019a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville } 2020f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeResponse; 2021f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2022f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return 0; 2023f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 2024f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2025a592eebc476a3d234f47f93e58252f8c822fc772Wink Savillestatic int responseCdmaBrSmsCnf(Parcel &p, void *response, size_t responselen) { 2026a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville RIL_CDMA_BroadcastSmsConfigInfo **p_cur = 2027a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville (RIL_CDMA_BroadcastSmsConfigInfo **) response; 2028f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2029a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville int num = responselen / sizeof (RIL_CDMA_BroadcastSmsConfigInfo *); 2030a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(num); 2031f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2032f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startResponse; 2033a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville for (int i = 0 ; i < num ; i++ ) { 2034a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->service_category); 2035a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->language); 2036a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p.writeInt32(p_cur[i]->selected); 2037f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2038a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville appendPrintBuf("%s [%d: srvice_category=%d, language =%d, \ 2039a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville selected =%d], ", 2040a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville printBuf, i, p_cur[i]->service_category, p_cur[i]->language, 2041a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville p_cur[i]->selected); 2042f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville } 2043a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville closeResponse; 2044f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville 2045f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return 0; 2046f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 2047f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2048f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic int responseCdmaSms(Parcel &p, void *response, size_t responselen) { 2049f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int num; 2050f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int digitCount; 2051f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville int digitLimit; 2052f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville uint8_t uct; 2053f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville void* dest; 2054f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2055f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville LOGD("Inside responseCdmaSms"); 2056f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville 2057f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (response == NULL && responselen != 0) { 2058f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGE("invalid response: NULL"); 2059f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return RIL_ERRNO_INVALID_RESPONSE; 2060f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2061f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2062f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville if (responselen != sizeof(RIL_CDMA_SMS_Message)) { 2063f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGE("invalid response length was %d expected %d", 2064f5903dfd25c2ef104b3e9267b53f6ee3e7588063Wink Saville (int)responselen, (int)sizeof(RIL_CDMA_SMS_Message)); 2065f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return RIL_ERRNO_INVALID_RESPONSE; 2066f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2067f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2068f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville RIL_CDMA_SMS_Message *p_cur = (RIL_CDMA_SMS_Message *) response; 2069f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->uTeleserviceID); 2070f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->bIsServicePresent),sizeof(uct)); 2071f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->uServicecategory); 2072f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->sAddress.digit_mode); 2073f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->sAddress.number_mode); 2074f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->sAddress.number_type); 2075f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->sAddress.number_plan); 2076f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->sAddress.number_of_digits), sizeof(uct)); 2077f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((p_cur->sAddress.number_of_digits), RIL_CDMA_SMS_ADDRESS_MAX); 2078f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 2079f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->sAddress.digits[digitCount]),sizeof(uct)); 2080f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2081f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2082f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->sSubAddress.subaddressType); 2083f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->sSubAddress.odd),sizeof(uct)); 2084f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->sSubAddress.number_of_digits),sizeof(uct)); 2085f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((p_cur->sSubAddress.number_of_digits), RIL_CDMA_SMS_SUBADDRESS_MAX); 2086f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 2087f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->sSubAddress.digits[digitCount]),sizeof(uct)); 2088f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2089f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2090f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville digitLimit= MIN((p_cur->uBearerDataLen), RIL_CDMA_SMS_BEARER_DATA_MAX); 2091f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.writeInt32(p_cur->uBearerDataLen); 2092f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for(digitCount =0 ; digitCount < digitLimit; digitCount ++) { 2093f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p.write(&(p_cur->aBearerData[digitCount]), sizeof(uct)); 2094f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2095f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2096f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville startResponse; 2097f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville appendPrintBuf("%suTeleserviceID=%d, bIsServicePresent=%d, uServicecategory=%d, \ 20981b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville sAddress.digit_mode=%d, sAddress.number_mode=%d, sAddress.number_type=%d, ", 2099f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville printBuf, p_cur->uTeleserviceID,p_cur->bIsServicePresent,p_cur->uServicecategory, 2100f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville p_cur->sAddress.digit_mode, p_cur->sAddress.number_mode,p_cur->sAddress.number_type); 2101f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville closeResponse; 2102f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 2103f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return 0; 2104f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville} 2105f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 210600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** 210700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * A write on the wakeup fd is done just to pop us out of select() 210800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * We empty the buffer here and then ril_event will reset the timers on the 210900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * way back down 211000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 2111f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void processWakeupCallback(int fd, short flags, void *param) { 211200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char buff[16]; 211300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 211400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 211500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGV("processWakeupCallback"); 211600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 211700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* empty our wakeup socket out */ 211800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project do { 211900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = read(s_fdWakeupRead, &buff, sizeof(buff)); 21207f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville } while (ret > 0 || (ret < 0 && errno == EINTR)); 212100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 212200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2123f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void onCommandsSocketClosed() { 212400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 212500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RequestInfo *p_cur; 212600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 212700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* mark pending requests as "cancelled" so we dont report responses */ 212800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 212900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_lock(&s_pendingRequestsMutex); 213000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 213100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 213200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur = s_pendingRequests; 213300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 21347f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville for (p_cur = s_pendingRequests 213500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ; p_cur != NULL 213600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ; p_cur = p_cur->p_next 213700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ) { 213800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_cur->cancelled = 1; 213900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 214000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 214100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_mutex_unlock(&s_pendingRequestsMutex); 214200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (ret == 0); 214300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 214400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2145f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void processCommandsCallback(int fd, short flags, void *param) { 214600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RecordStream *p_rs; 214700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project void *p_record; 214800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t recordlen; 214900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 215000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 215100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert(fd == s_fdCommand); 215200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 215300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_rs = (RecordStream *)param; 215400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 215500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (;;) { 215600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* loop until EAGAIN/EINTR, end of stream, or other error */ 215700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = record_stream_get_next(p_rs, &p_record, &recordlen); 215800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 215900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret == 0 && p_record == NULL) { 216000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* end-of-stream */ 216100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 216200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else if (ret < 0) { 216300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 216400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else if (ret == 0) { /* && p_record != NULL */ 216500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project processCommandBuffer(p_record, recordlen); 216600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 216700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 216800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 216900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret == 0 || !(errno == EAGAIN || errno == EINTR)) { 217000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* fatal error or end-of-stream */ 217100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret != 0) { 217200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("error on reading command socket errno:%d\n", errno); 217300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 217400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGW("EOS. Closing command socket."); 217500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 21767f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 217700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project close(s_fdCommand); 217800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdCommand = -1; 217900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 218000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_del(&s_commands_event); 218100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 218200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project record_stream_free(p_rs); 218300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 218400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* start listening for new connections again */ 218500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup(&s_listen_event); 218600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 218700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project onCommandsSocketClosed(); 218800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 218900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 219000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 219100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2192f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void onNewCommandConnect() { 219300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // implicit radio state changed 219400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_onUnsolicitedResponse(RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED, 219500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project NULL, 0); 219600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 219700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Send last NITZ time data, in case it was missed 219800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_lastNITZTimeData != NULL) { 219900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sendResponseRaw(s_lastNITZTimeData, s_lastNITZTimeDataSize); 220000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 220100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(s_lastNITZTimeData); 220200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_lastNITZTimeData = NULL; 220300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 220400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 220500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Get version string 220600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_callbacks.getVersion != NULL) { 220700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const char *version; 220800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project version = s_callbacks.getVersion(); 220900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("RIL Daemon version: %s\n", version); 22107f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 221100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project property_set(PROPERTY_RIL_IMPL, version); 221200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 221300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("RIL Daemon version: unavailable\n"); 221400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project property_set(PROPERTY_RIL_IMPL, "unavailable"); 221500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 221600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 221700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 221800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2219f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void listenCallback (int fd, short flags, void *param) { 222000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 222100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int err; 222200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int is_phone_socket; 222300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RecordStream *p_rs; 222400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 222500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct sockaddr_un peeraddr; 222600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project socklen_t socklen = sizeof (peeraddr); 222700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 222800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct ucred creds; 222900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project socklen_t szCreds = sizeof(creds); 223000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 223100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct passwd *pwd = NULL; 223200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 223300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (s_fdCommand < 0); 223400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert (fd == s_fdListen); 22357f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 223600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdCommand = accept(s_fdListen, (sockaddr *) &peeraddr, &socklen); 223700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 223800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_fdCommand < 0 ) { 223900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Error on accept() errno:%d", errno); 224000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* start listening for new connections again */ 224100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup(&s_listen_event); 2242f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville return; 224300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 224400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 224500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* check the credential of the other side and only accept socket from 224600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * phone process 22477f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville */ 224800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project errno = 0; 224900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project is_phone_socket = 0; 2250f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 225100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project err = getsockopt(s_fdCommand, SOL_SOCKET, SO_PEERCRED, &creds, &szCreds); 2252f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville 225300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (err == 0 && szCreds > 0) { 2254f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville errno = 0; 2255f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville pwd = getpwuid(creds.uid); 2256f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (pwd != NULL) { 2257f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville if (strcmp(pwd->pw_name, PHONE_PROCESS) == 0) { 2258f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville is_phone_socket = 1; 2259f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } else { 2260f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGE("RILD can't accept socket from process %s", pwd->pw_name); 2261f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 2262f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } else { 2263f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGE("Error on getpwuid() errno: %d", errno); 2264f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville } 226500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 2266f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGD("Error on getsockopt() errno: %d", errno); 226700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 226800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 226900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if ( !is_phone_socket ) { 227000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("RILD must accept socket from %s", PHONE_PROCESS); 22717f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 227200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project close(s_fdCommand); 227300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdCommand = -1; 227400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 227500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project onCommandsSocketClosed(); 227600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 227700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* start listening for new connections again */ 227800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup(&s_listen_event); 227900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 228000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 228100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 228200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 228300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = fcntl(s_fdCommand, F_SETFL, O_NONBLOCK); 228400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 228500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 228600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("Error setting O_NONBLOCK errno:%d", errno); 228700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 228800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 228900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("libril: new connection"); 229000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 229100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_rs = record_stream_new(s_fdCommand, MAX_COMMAND_BYTES); 229200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 22937f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville ril_event_set (&s_commands_event, s_fdCommand, 1, 229400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project processCommandsCallback, p_rs); 229500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 229600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup (&s_commands_event); 229700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 229800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project onNewCommandConnect(); 229900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 230000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 230100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void freeDebugCallbackArgs(int number, char **args) { 230200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0; i < number; i++) { 230300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (args[i] != NULL) { 230400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(args[i]); 230500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 230600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 230700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(args); 230800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 230900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2310f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void debugCallback (int fd, short flags, void *param) { 231100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int acceptFD, option; 231200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct sockaddr_un peeraddr; 231300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project socklen_t socklen = sizeof (peeraddr); 231400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int data; 231500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project unsigned int qxdm_data[6]; 231600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const char *deactData[1] = {"1"}; 231700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char *actData[1]; 231800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_Dial dialData; 231900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int hangupData[1] = {1}; 232000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int number; 232100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char **args; 232200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 232300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project acceptFD = accept (fd, (sockaddr *) &peeraddr, &socklen); 232400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 232500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (acceptFD < 0) { 232600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("error accepting on debug port: %d\n", errno); 232700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 232800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 232900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 233000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (recv(acceptFD, &number, sizeof(int), 0) != sizeof(int)) { 233100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("error reading on socket: number of Args: \n"); 233200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 233300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 233400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project args = (char **) malloc(sizeof(char*) * number); 233500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 233600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project for (int i = 0; i < number; i++) { 233700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int len; 233800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (recv(acceptFD, &len, sizeof(int), 0) != sizeof(int)) { 233900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("error reading on socket: Len of Args: \n"); 234000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project freeDebugCallbackArgs(i, args); 234100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 234200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 234300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // +1 for null-term 234400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project args[i] = (char *) malloc((sizeof(char) * len) + 1); 23457f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville if (recv(acceptFD, args[i], sizeof(char) * len, 0) 23461b5fd23e2bc82e5bed48125317cf2f9837cf6ae8Wink Saville != (int)sizeof(char) * len) { 234700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("error reading on socket: Args[%d] \n", i); 234800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project freeDebugCallbackArgs(i, args); 234900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 235000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 235100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project char * buf = args[i]; 235200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project buf[len] = 0; 235300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 235400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 235500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch (atoi(args[0])) { 235600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 0: 235700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI ("Connection on debug port: issuing reset."); 235800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_RESET_RADIO, NULL, 0); 235900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 236000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 1: 236100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI ("Connection on debug port: issuing radio power off."); 236200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project data = 0; 236300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_RADIO_POWER, &data, sizeof(int)); 236400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Close the socket 236500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project close(s_fdCommand); 236600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdCommand = -1; 236700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 236800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 2: 236900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI ("Debug port: issuing unsolicited network change."); 237000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_onUnsolicitedResponse(RIL_UNSOL_RESPONSE_NETWORK_STATE_CHANGED, 237100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project NULL, 0); 237200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 237300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 3: 237400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI ("Debug port: QXDM log enable."); 237500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[0] = 65536; 237600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[1] = 16; 237700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[2] = 1; 237800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[3] = 32; 237900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[4] = 0; 238000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[4] = 8; 23817f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville issueLocalRequest(RIL_REQUEST_OEM_HOOK_RAW, qxdm_data, 238200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6 * sizeof(int)); 238300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 238400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 4: 238500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI ("Debug port: QXDM log disable."); 238600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[0] = 65536; 238700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[1] = 16; 238800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[2] = 0; 238900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[3] = 32; 239000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[4] = 0; 239100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project qxdm_data[4] = 8; 239200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_OEM_HOOK_RAW, qxdm_data, 239300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 6 * sizeof(int)); 239400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 239500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 5: 239600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("Debug port: Radio On"); 239700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project data = 1; 239800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_RADIO_POWER, &data, sizeof(int)); 239900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sleep(2); 240000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Set network selection automatic. 240100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC, NULL, 0); 240200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 240300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 6: 2404f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGI("Debug port: Setup Data Call, Apn :%s\n", args[1]); 240500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project actData[0] = args[1]; 24067f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville issueLocalRequest(RIL_REQUEST_SETUP_DATA_CALL, &actData, 240700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sizeof(actData)); 240800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 240900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 7: 2410f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville LOGI("Debug port: Deactivate Data Call"); 24117f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville issueLocalRequest(RIL_REQUEST_DEACTIVATE_DATA_CALL, &deactData, 241200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sizeof(deactData)); 241300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 241400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 8: 241500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("Debug port: Dial Call"); 241600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project dialData.clir = 0; 241700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project dialData.address = args[1]; 241800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_DIAL, &dialData, sizeof(dialData)); 241900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 242000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 9: 242100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("Debug port: Answer Call"); 242200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project issueLocalRequest(RIL_REQUEST_ANSWER, NULL, 0); 242300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 242400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case 10: 242500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGI("Debug port: End Call"); 24267f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville issueLocalRequest(RIL_REQUEST_HANGUP, &hangupData, 242700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sizeof(hangupData)); 242800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 242900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: 243000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("Invalid request"); 243100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 243200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 243300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project freeDebugCallbackArgs(number, args); 243400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project close(acceptFD); 243500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 243600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 243700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2438f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Savillestatic void userTimerCallback (int fd, short flags, void *param) { 243900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project UserCallbackInfo *p_info; 244000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 244100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_info = (UserCallbackInfo *)param; 244200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 244300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_info->p_callback(p_info->userParam); 244400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 244500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 244600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // FIXME generalize this...there should be a cancel mechanism 244700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_last_wake_timeout_info != NULL && s_last_wake_timeout_info == p_info) { 244800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_last_wake_timeout_info = NULL; 244900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 245000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 245100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(p_info); 245200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 245300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 245400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 245500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void * 2456f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleeventLoop(void *param) { 245700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 245800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int filedes[2]; 245900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 246000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_init(); 246100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 246200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_lock(&s_startupMutex); 246300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 246400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_started = 1; 246500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_cond_broadcast(&s_startupCond); 246600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 246700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_unlock(&s_startupMutex); 246800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 246900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pipe(filedes); 247000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 247100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 247200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Error in pipe() errno:%d", errno); 247300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return NULL; 247400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 247500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 247600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdWakeupRead = filedes[0]; 247700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdWakeupWrite = filedes[1]; 247800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 247900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project fcntl(s_fdWakeupRead, F_SETFL, O_NONBLOCK); 248000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 248100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_set (&s_wakeupfd_event, s_fdWakeupRead, true, 248200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project processWakeupCallback, NULL); 248300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 248400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup (&s_wakeupfd_event); 248500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 248600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Only returns on error 248700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_loop(); 248800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("error in event_loop_base errno:%d", errno); 248900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 249000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return NULL; 249100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 249200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 24937f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void 2494f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_startEventLoop(void) { 249500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 249600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_attr_t attr; 24977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 249800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* spin up eventLoop thread and wait for it to get started */ 249900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_started = 0; 250000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_lock(&s_startupMutex); 250100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 250200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_attr_init (&attr); 25037f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); 250400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pthread_create(&s_tid_dispatch, &attr, eventLoop, NULL); 250500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 250600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project while (s_started == 0) { 250700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_cond_wait(&s_startupCond, &s_startupMutex); 250800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 250900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 251000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_unlock(&s_startupMutex); 251100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 251200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 251300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Failed to create dispatch thread errno:%d", errno); 251400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 251500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 251600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 251700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 251800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project// Used for testing purpose only. 251900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" void RIL_setcallbacks (const RIL_RadioFunctions *callbacks) { 252000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memcpy(&s_callbacks, callbacks, sizeof (RIL_RadioFunctions)); 252100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 252200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 25237f8568086f2ea14885b0091c793e14c2656f0da2Wink Savilleextern "C" void 2524f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_register (const RIL_RadioFunctions *callbacks) { 252500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 252600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int flags; 252700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 252874fa38884320698c1623764850e3131b9769dff0Wink Saville if (callbacks == NULL || ((callbacks->version != RIL_VERSION) 25293a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville && (callbacks->version != 2))) { // Remove when partners upgrade to version 3 253000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE( 253100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project "RIL_register: RIL_RadioFunctions * null or invalid version" 253200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project " (expected %d)", RIL_VERSION); 253300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 253400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 25353a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville if (callbacks->version < 3) { 25363a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville LOGE ("RIL_register: upgrade RIL to version 3 current version=%d", callbacks->version); 25373a4840bea36ce53bc0fb181811ebf9d1cd0aa261Wink Saville } 253800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 253900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_registerCalled > 0) { 254000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("RIL_register has been called more than once. " 254100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project "Subsequent call ignored"); 254200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 254300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 254400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 254500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memcpy(&s_callbacks, callbacks, sizeof (RIL_RadioFunctions)); 254600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 254700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_registerCalled = 1; 254800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 254900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Little self-check 255000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2551f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for (int i = 0; i < (int)NUM_ELEMS(s_commands); i++) { 255200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project assert(i == s_commands[i].requestNumber); 255300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 255400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2555f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville for (int i = 0; i < (int)NUM_ELEMS(s_unsolResponses); i++) { 25567f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville assert(i + RIL_UNSOL_RESPONSE_BASE 255700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project == s_unsolResponses[i].requestNumber); 255800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 255900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 256000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // New rild impl calls RIL_startEventLoop() first 256100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // old standalone impl wants it here. 256200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 256300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_started == 0) { 256400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RIL_startEventLoop(); 256500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 256600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 256700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // start listen socket 256800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 256900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if 0 25707f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville ret = socket_local_server (SOCKET_NAME_RIL, 257100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ANDROID_SOCKET_NAMESPACE_ABSTRACT, SOCK_STREAM); 257200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 257300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 257400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Unable to bind socket errno:%d", errno); 257500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project exit (-1); 257600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 257700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdListen = ret; 257800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 257900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#else 258000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdListen = android_get_control_socket(SOCKET_NAME_RIL); 258100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_fdListen < 0) { 258200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Failed to get socket '" SOCKET_NAME_RIL "'"); 258300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project exit(-1); 258400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 258500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 258600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = listen(s_fdListen, 4); 258700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 258800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 258900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Failed to listen on control socket '%d': %s", 259000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdListen, strerror(errno)); 259100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project exit(-1); 259200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 259300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 259400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 259500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 259600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* note: non-persistent so we can accept only one connection at a time */ 25977f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville ril_event_set (&s_listen_event, s_fdListen, false, 259800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project listenCallback, NULL); 259900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 260000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup (&s_listen_event); 260100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 260200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#if 1 260300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // start debug interface socket 260400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 260500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdDebug = android_get_control_socket(SOCKET_NAME_RIL_DEBUG); 260600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_fdDebug < 0) { 260700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Failed to get socket '" SOCKET_NAME_RIL_DEBUG "' errno:%d", errno); 260800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project exit(-1); 260900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 261000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 261100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = listen(s_fdDebug, 4); 261200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 261300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret < 0) { 261400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("Failed to listen on ril debug socket '%d': %s", 261500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_fdDebug, strerror(errno)); 261600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project exit(-1); 261700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 261800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 261900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_set (&s_debug_event, s_fdDebug, true, 262000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project debugCallback, NULL); 262100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 262200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project rilEventAddWakeup (&s_debug_event); 262300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project#endif 262400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 262500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 262600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 262700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic int 2628f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillecheckAndDequeueRequestInfo(struct RequestInfo *pRI) { 262900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret = 0; 26307f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 263100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (pRI == NULL) { 263200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return 0; 263300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 263400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 263500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_lock(&s_pendingRequestsMutex); 263600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 26377f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville for(RequestInfo **ppCur = &s_pendingRequests 26387f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville ; *ppCur != NULL 263900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ; ppCur = &((*ppCur)->p_next) 264000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ) { 264100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (pRI == *ppCur) { 264200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = 1; 264300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 264400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project *ppCur = (*ppCur)->p_next; 264500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 264600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 264700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 264800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 264900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pthread_mutex_unlock(&s_pendingRequestsMutex); 265000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 265100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return ret; 265200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 265300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 265400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 265500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" void 2656f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleRIL_onRequestComplete(RIL_Token t, RIL_Errno e, void *response, size_t responselen) { 265700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project RequestInfo *pRI; 265800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 265900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t errorOffset; 266000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 266100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI = (RequestInfo *)t; 266200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 266300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (!checkAndDequeueRequestInfo(pRI)) { 266400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE ("RIL_onRequestComplete: invalid RIL_Token"); 266500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 266600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 266700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 266800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (pRI->local > 0) { 266900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Locally issued command...void only! 267000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // response does not go back up the command socket 267100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGD("C[locl]< %s", requestToString(pRI->pCI->requestNumber)); 267200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 267300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto done; 267400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 267500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 267600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("[%04d]< %s", 267700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project pRI->token, requestToString(pRI->pCI->requestNumber)); 267800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 267900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (pRI->cancelled == 0) { 268000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project Parcel p; 268100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 268200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (RESPONSE_SOLICITED); 268300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (pRI->token); 268400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project errorOffset = p.dataPosition(); 268500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 268600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (e); 268700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 2688b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang if (response != NULL) { 2689b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang // there is a response payload, no matter success or not. 269000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = pRI->pCI->responseFunction(p, response, responselen); 269100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 269200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* if an error occurred, rewind and mark it */ 269300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret != 0) { 269400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.setDataPosition(errorOffset); 269500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (ret); 269600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 2697b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang } 2698b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang 2699b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang if (e != RIL_E_SUCCESS) { 2700b2a6184ec942c4c1728cbac723db90fbed4f85c5johnwang appendPrintBuf("%s fails by %s", printBuf, failCauseToString(e)); 270100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 270200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 270300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_fdCommand < 0) { 270400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGD ("RIL onRequestComplete: Command channel closed"); 270500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 270600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project sendResponse(p); 270700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 270800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 270900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectdone: 271000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free(pRI); 271100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 271200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 271300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 271400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 2715f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillegrabPartialWakeLock() { 271600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project acquire_wake_lock(PARTIAL_WAKE_LOCK, ANDROID_WAKE_LOCK_NAME); 271700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 271800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 271900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 2720f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillereleaseWakeLock() { 272100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project release_wake_lock(ANDROID_WAKE_LOCK_NAME); 272200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 272300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 272400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/** 272500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project * Timer callback to put us back to sleep before the default timeout 272600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project */ 272700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic void 2728f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillewakeTimeoutCallback (void *param) { 272900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // We're using "param != NULL" as a cancellation mechanism 273000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (param == NULL) { 273100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project //LOGD("wakeTimeout: releasing wake lock"); 273200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 273300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project releaseWakeLock(); 273400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 273500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project //LOGD("wakeTimeout: releasing wake lock CANCELLED"); 273600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 273700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 273800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 273900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" 274000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectvoid RIL_onUnsolicitedResponse(int unsolResponse, void *data, 274100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project size_t datalen) 274200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{ 274300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int unsolResponseIndex; 274400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int ret; 274500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project int64_t timeReceived = 0; 274600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project bool shouldScheduleTimeout = false; 274700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 274800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_registerCalled == 0) { 274900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Ignore RIL_onUnsolicitedResponse before RIL_register 275000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGW("RIL_onUnsolicitedResponse called before RIL_register"); 275100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 275200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 27537f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville 275400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project unsolResponseIndex = unsolResponse - RIL_UNSOL_RESPONSE_BASE; 275500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 275600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if ((unsolResponseIndex < 0) 275700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project || (unsolResponseIndex >= (int32_t)NUM_ELEMS(s_unsolResponses))) { 275800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project LOGE("unsupported unsolicited response code %d", unsolResponse); 275900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 276000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 276100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 276200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Grab a wake lock if needed for this reponse, 276300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // as we exit we'll either release it immediately 276400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // or set a timer to release it later. 276500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch (s_unsolResponses[unsolResponseIndex].wakeType) { 276600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case WAKE_PARTIAL: 276700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project grabPartialWakeLock(); 276800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project shouldScheduleTimeout = true; 276900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 277000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 277100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case DONT_WAKE: 277200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: 277300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // No wake lock is grabed so don't set timeout 277400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project shouldScheduleTimeout = false; 277500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 277600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 277700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 277800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Mark the time this was received, doing this 277900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // after grabing the wakelock incase getting 278000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // the elapsedRealTime might cause us to goto 278100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // sleep. 278200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (unsolResponse == RIL_UNSOL_NITZ_TIME_RECEIVED) { 278300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project timeReceived = elapsedRealtime(); 278400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 278500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 278600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("[UNSL]< %s", requestToString(unsolResponse)); 278700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 278800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project Parcel p; 278900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 279000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (RESPONSE_UNSOLICITED); 279100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32 (unsolResponse); 279200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 279300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = s_unsolResponses[unsolResponseIndex] 279400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project .responseFunction(p, data, datalen); 279500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret != 0) { 279600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Problem with the response. Don't continue; 279700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project goto error_exit; 279800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 279900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 280000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // some things get more payload 280100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch(unsolResponse) { 280200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED: 280300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt32(s_callbacks.onStateRequest()); 280400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project appendPrintBuf("%s {%s}", printBuf, 280500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project radioStateToString(s_callbacks.onStateRequest())); 280600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 280700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 280800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 280900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_NITZ_TIME_RECEIVED: 281000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Store the time that this was received so the 281100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // handler of this message can account for 281200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // the time it takes to arrive and process. In 281300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // particular the system has been known to sleep 281400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // before this message can be processed. 281500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p.writeInt64(timeReceived); 281600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project break; 281700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 281800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 281900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ret = sendResponse(p); 282000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (ret != 0 && unsolResponse == RIL_UNSOL_NITZ_TIME_RECEIVED) { 282100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 282200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Unfortunately, NITZ time is not poll/update like everything 282300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // else in the system. So, if the upstream client isn't connected, 282400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // keep a copy of the last NITZ response (with receive time noted 282500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // above) around so we can deliver it when it is connected 282600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 282700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_lastNITZTimeData != NULL) { 282800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project free (s_lastNITZTimeData); 282900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_lastNITZTimeData = NULL; 283000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 283100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 283200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_lastNITZTimeData = malloc(p.dataSize()); 283300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_lastNITZTimeDataSize = p.dataSize(); 283400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memcpy(s_lastNITZTimeData, p.data(), p.dataSize()); 283500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 283600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 283700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // For now, we automatically go back to sleep after TIMEVAL_WAKE_TIMEOUT 283800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // FIXME The java code should handshake here to release wake lock 283900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 284000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (shouldScheduleTimeout) { 284100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Cancel the previous request 284200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (s_last_wake_timeout_info != NULL) { 284300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_last_wake_timeout_info->userParam = (void *)1; 284400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 284500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 284600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project s_last_wake_timeout_info 284700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project = internalRequestTimedCallback(wakeTimeoutCallback, NULL, 284800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project &TIMEVAL_WAKE_TIMEOUT); 284900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 285000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 285100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project // Normal exit 285200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return; 285300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 285400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projecterror_exit: 285500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (shouldScheduleTimeout) { 285600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project releaseWakeLock(); 285700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 285800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 285900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 28607f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville/** FIXME generalize this if you track UserCAllbackInfo, clear it 28617f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville when the callback occurs 286200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project*/ 286300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectstatic UserCallbackInfo * 28647f8568086f2ea14885b0091c793e14c2656f0da2Wink SavilleinternalRequestTimedCallback (RIL_TimedCallback callback, void *param, 286500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project const struct timeval *relativeTime) 286600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project{ 286700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project struct timeval myRelativeTime; 286800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project UserCallbackInfo *p_info; 286900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 287000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_info = (UserCallbackInfo *) malloc (sizeof(UserCallbackInfo)); 287100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 28727f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville p_info->p_callback = callback; 287300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project p_info->userParam = param; 287400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 287500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project if (relativeTime == NULL) { 287600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* treat null parameter as a 0 relative time */ 287700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memset (&myRelativeTime, 0, sizeof(myRelativeTime)); 287800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } else { 287900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project /* FIXME I think event_add's tv param is really const anyway */ 288000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project memcpy (&myRelativeTime, relativeTime, sizeof(myRelativeTime)); 288100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 288200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 288300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_event_set(&(p_info->event), -1, false, userTimerCallback, p_info); 288400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 288500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project ril_timer_add(&(p_info->event), &myRelativeTime); 288600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 288700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project triggerEvLoop(); 288800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project return p_info; 288900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 289000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 289100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 289200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectextern "C" void 28937f8568086f2ea14885b0091c793e14c2656f0da2Wink SavilleRIL_requestTimedCallback (RIL_TimedCallback callback, void *param, 2894f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville const struct timeval *relativeTime) { 289500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project internalRequestTimedCallback (callback, param, relativeTime); 289600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 289700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 289800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char * 2899f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillefailCauseToString(RIL_Errno e) { 290000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch(e) { 290100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_SUCCESS: return "E_SUCCESS"; 290200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_RADIO_NOT_AVAILABLE: return "E_RAIDO_NOT_AVAILABLE"; 290300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_GENERIC_FAILURE: return "E_GENERIC_FAILURE"; 290400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_PASSWORD_INCORRECT: return "E_PASSWORD_INCORRECT"; 290500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_SIM_PIN2: return "E_SIM_PIN2"; 290600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_SIM_PUK2: return "E_SIM_PUK2"; 290700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_REQUEST_NOT_SUPPORTED: return "E_REQUEST_NOT_SUPPORTED"; 290800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_CANCELLED: return "E_CANCELLED"; 290900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_OP_NOT_ALLOWED_DURING_VOICE_CALL: return "E_OP_NOT_ALLOWED_DURING_VOICE_CALL"; 291000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW: return "E_OP_NOT_ALLOWED_BEFORE_REG_TO_NW"; 291100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_E_SMS_SEND_FAIL_RETRY: return "E_SMS_SEND_FAIL_RETRY"; 2912f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_E_SIM_ABSENT:return "E_SIM_ABSENT"; 29137553447d44bb3f494b00d573215d81398f61cfcdJohn Wang case RIL_E_ILLEGAL_SIM_OR_ME:return "E_ILLEGAL_SIM_OR_ME"; 29147f8568086f2ea14885b0091c793e14c2656f0da2Wink Saville#ifdef FEATURE_MULTIMODE_ANDROID 2915f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_E_SUBSCRIPTION_NOT_AVAILABLE:return "E_SUBSCRIPTION_NOT_AVAILABLE"; 2916f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_E_MODE_NOT_SUPPORTED:return "E_MODE_NOT_SUPPORTED"; 2917f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville#endif 291800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: return "<unknown error>"; 291900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 292000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 292100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 292200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char * 2923f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavilleradioStateToString(RIL_RadioState s) { 292400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch(s) { 292500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RADIO_STATE_OFF: return "RADIO_OFF"; 292600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RADIO_STATE_UNAVAILABLE: return "RADIO_UNAVAILABLE"; 292700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RADIO_STATE_SIM_NOT_READY: return "RADIO_SIM_NOT_READY"; 292800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RADIO_STATE_SIM_LOCKED_OR_ABSENT: return "RADIO_SIM_LOCKED_OR_ABSENT"; 292900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RADIO_STATE_SIM_READY: return "RADIO_SIM_READY"; 2930f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RADIO_STATE_RUIM_NOT_READY:return"RADIO_RUIM_NOT_READY"; 2931f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RADIO_STATE_RUIM_READY:return"RADIO_RUIM_READY"; 2932f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RADIO_STATE_RUIM_LOCKED_OR_ABSENT:return"RADIO_RUIM_LOCKED_OR_ABSENT"; 2933f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RADIO_STATE_NV_NOT_READY:return"RADIO_NV_NOT_READY"; 2934f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RADIO_STATE_NV_READY:return"RADIO_NV_READY"; 293500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: return "<unknown state>"; 293600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 293700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 293800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 293900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char * 2940f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillecallStateToString(RIL_CallState s) { 294100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch(s) { 294200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_ACTIVE : return "ACTIVE"; 294300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_HOLDING: return "HOLDING"; 294400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_DIALING: return "DIALING"; 294500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_ALERTING: return "ALERTING"; 294600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_INCOMING: return "INCOMING"; 294700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_CALL_WAITING: return "WAITING"; 294800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: return "<unknown state>"; 294900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 295000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 295100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 295200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Projectconst char * 2953f4c4d36c410a3501d282dd7de1c7c3350734f27eWink SavillerequestToString(int request) { 295400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project/* 295500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cat libs/telephony/ril_commands.h \ 295600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | egrep "^ *{RIL_" \ 295700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | sed -re 's/\{RIL_([^,]+),[^,]+,([^}]+).+/case RIL_\1: return "\1";/' 295800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 295900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 296000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project cat libs/telephony/ril_unsol_commands.h \ 296100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | egrep "^ *{RIL_" \ 296200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project | sed -re 's/\{RIL_([^,]+),([^}]+).+/case RIL_\1: return "\1";/' 296300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 296400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project*/ 296500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project switch(request) { 296600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_SIM_STATUS: return "GET_SIM_STATUS"; 296700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ENTER_SIM_PIN: return "ENTER_SIM_PIN"; 296800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ENTER_SIM_PUK: return "ENTER_SIM_PUK"; 296900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ENTER_SIM_PIN2: return "ENTER_SIM_PIN2"; 297000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ENTER_SIM_PUK2: return "ENTER_SIM_PUK2"; 297100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_CHANGE_SIM_PIN: return "CHANGE_SIM_PIN"; 297200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_CHANGE_SIM_PIN2: return "CHANGE_SIM_PIN2"; 297300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION: return "ENTER_NETWORK_DEPERSONALIZATION"; 297400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_CURRENT_CALLS: return "GET_CURRENT_CALLS"; 297500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_DIAL: return "DIAL"; 297600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_IMSI: return "GET_IMSI"; 297700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_HANGUP: return "HANGUP"; 297800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND: return "HANGUP_WAITING_OR_BACKGROUND"; 297900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND: return "HANGUP_FOREGROUND_RESUME_BACKGROUND"; 298000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE: return "SWITCH_WAITING_OR_HOLDING_AND_ACTIVE"; 298100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_CONFERENCE: return "CONFERENCE"; 298200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_UDUB: return "UDUB"; 298300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_LAST_CALL_FAIL_CAUSE: return "LAST_CALL_FAIL_CAUSE"; 298400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SIGNAL_STRENGTH: return "SIGNAL_STRENGTH"; 298500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_REGISTRATION_STATE: return "REGISTRATION_STATE"; 298600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GPRS_REGISTRATION_STATE: return "GPRS_REGISTRATION_STATE"; 298700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_OPERATOR: return "OPERATOR"; 298800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_RADIO_POWER: return "RADIO_POWER"; 298900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_DTMF: return "DTMF"; 299000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SEND_SMS: return "SEND_SMS"; 299100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SEND_SMS_EXPECT_MORE: return "SEND_SMS_EXPECT_MORE"; 2992f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_SETUP_DATA_CALL: return "SETUP_DATA_CALL"; 299300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SIM_IO: return "SIM_IO"; 299400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SEND_USSD: return "SEND_USSD"; 299500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_CANCEL_USSD: return "CANCEL_USSD"; 299600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_CLIR: return "GET_CLIR"; 299700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_CLIR: return "SET_CLIR"; 299800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_CALL_FORWARD_STATUS: return "QUERY_CALL_FORWARD_STATUS"; 299900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_CALL_FORWARD: return "SET_CALL_FORWARD"; 300000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_CALL_WAITING: return "QUERY_CALL_WAITING"; 300100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_CALL_WAITING: return "SET_CALL_WAITING"; 300200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SMS_ACKNOWLEDGE: return "SMS_ACKNOWLEDGE"; 300300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_IMEI: return "GET_IMEI"; 300400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_IMEISV: return "GET_IMEISV"; 300500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_ANSWER: return "ANSWER"; 3006f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_DEACTIVATE_DATA_CALL: return "DEACTIVATE_DATA_CALL"; 300700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_FACILITY_LOCK: return "QUERY_FACILITY_LOCK"; 300800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_FACILITY_LOCK: return "SET_FACILITY_LOCK"; 300900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_CHANGE_BARRING_PASSWORD: return "CHANGE_BARRING_PASSWORD"; 301000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE: return "QUERY_NETWORK_SELECTION_MODE"; 301100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC: return "SET_NETWORK_SELECTION_AUTOMATIC"; 301200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL: return "SET_NETWORK_SELECTION_MANUAL"; 301300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_AVAILABLE_NETWORKS : return "QUERY_AVAILABLE_NETWORKS "; 301400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_DTMF_START: return "DTMF_START"; 301500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_DTMF_STOP: return "DTMF_STOP"; 301600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_BASEBAND_VERSION: return "BASEBAND_VERSION"; 301700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SEPARATE_CONNECTION: return "SEPARATE_CONNECTION"; 301800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE: return "SET_PREFERRED_NETWORK_TYPE"; 301900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE: return "GET_PREFERRED_NETWORK_TYPE"; 302000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_NEIGHBORING_CELL_IDS: return "GET_NEIGHBORING_CELL_IDS"; 302100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_MUTE: return "SET_MUTE"; 302200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_GET_MUTE: return "GET_MUTE"; 302300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_QUERY_CLIP: return "QUERY_CLIP"; 3024f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE: return "LAST_DATA_CALL_FAIL_CAUSE"; 3025f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_DATA_CALL_LIST: return "DATA_CALL_LIST"; 302600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_RESET_RADIO: return "RESET_RADIO"; 302700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_OEM_HOOK_RAW: return "OEM_HOOK_RAW"; 302800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_OEM_HOOK_STRINGS: return "OEM_HOOK_STRINGS"; 3029f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_SET_BAND_MODE: return "SET_BAND_MODE"; 3030f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE: return "QUERY_AVAILABLE_BAND_MODE"; 303100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_STK_GET_PROFILE: return "STK_GET_PROFILE"; 303200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_STK_SET_PROFILE: return "STK_SET_PROFILE"; 303300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND: return "STK_SEND_ENVELOPE_COMMAND"; 303400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE: return "STK_SEND_TERMINAL_RESPONSE"; 303500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM: return "STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM"; 303600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SCREEN_STATE: return "SCREEN_STATE"; 303700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_EXPLICIT_CALL_TRANSFER: return "EXPLICIT_CALL_TRANSFER"; 303800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_REQUEST_SET_LOCATION_UPDATES: return "SET_LOCATION_UPDATES"; 3039f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SET_SUBSCRIPTION:return"CDMA_SET_SUBSCRIPTION"; 3040f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE:return"CDMA_SET_ROAMING_PREFERENCE"; 3041f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE:return"CDMA_QUERY_ROAMING_PREFERENCE"; 3042f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_SET_TTY_MODE:return"SET_TTY_MODE"; 3043f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_QUERY_TTY_MODE:return"QUERY_TTY_MODE"; 3044f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE"; 3045f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE"; 3046f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_FLASH:return"CDMA_FLASH"; 3047f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_BURST_DTMF:return"CDMA_BURST_DTMF"; 3048f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SEND_SMS:return"CDMA_SEND_SMS"; 3049f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE:return"CDMA_SMS_ACKNOWLEDGE"; 3050a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG:return"GSM_GET_BROADCAST_SMS_CONFIG"; 3051a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG:return"GSM_SET_BROADCAST_SMS_CONFIG"; 3052a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG:return "CDMA_GET_BROADCAST_SMS_CONFIG"; 3053a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG:return "CDMA_SET_BROADCAST_SMS_CONFIG"; 3054a592eebc476a3d234f47f93e58252f8c822fc772Wink Saville case RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION:return "CDMA_SMS_BROADCAST_ACTIVATION"; 305503c1edf23e76a83b95ac6847e333cb1329bbfa1dNaveen Kalla case RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY: return"CDMA_VALIDATE_AND_WRITE_AKEY"; 3056f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_SUBSCRIPTION: return"CDMA_SUBSCRIPTION"; 3057f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM: return "CDMA_WRITE_SMS_TO_RUIM"; 3058f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM: return "CDMA_DELETE_SMS_ON_RUIM"; 3059f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_REQUEST_DEVICE_IDENTITY: return "DEVICE_IDENTITY"; 3060000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh case RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE: return "EXIT_EMERGENCY_CALLBACK_MODE"; 3061000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh case RIL_REQUEST_GET_SMSC_ADDRESS: return "GET_SMSC_ADDRESS"; 3062000a9fe96fdf9111387d2bc389d2f6bb3e627d0fjsh case RIL_REQUEST_SET_SMSC_ADDRESS: return "SET_SMSC_ADDRESS"; 306309a68ba315ca3d6b092fd8078cc42b93b7934a1ajsh case RIL_REQUEST_REPORT_SMS_MEMORY_STATUS: return "REPORT_SMS_MEMORY_STATUS"; 306400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED: return "UNSOL_RESPONSE_RADIO_STATE_CHANGED"; 306500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED: return "UNSOL_RESPONSE_CALL_STATE_CHANGED"; 306600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_NETWORK_STATE_CHANGED: return "UNSOL_RESPONSE_NETWORK_STATE_CHANGED"; 306700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_NEW_SMS: return "UNSOL_RESPONSE_NEW_SMS"; 306800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT: return "UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT"; 306900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM: return "UNSOL_RESPONSE_NEW_SMS_ON_SIM"; 307000f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_ON_USSD: return "UNSOL_ON_USSD"; 307100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_ON_USSD_REQUEST: return "UNSOL_ON_USSD_REQUEST(obsolete)"; 307200f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_NITZ_TIME_RECEIVED: return "UNSOL_NITZ_TIME_RECEIVED"; 307300f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_SIGNAL_STRENGTH: return "UNSOL_SIGNAL_STRENGTH"; 307400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_STK_SESSION_END: return "UNSOL_STK_SESSION_END"; 307500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_STK_PROACTIVE_COMMAND: return "UNSOL_STK_PROACTIVE_COMMAND"; 307600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_STK_EVENT_NOTIFY: return "UNSOL_STK_EVENT_NOTIFY"; 307700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_STK_CALL_SETUP: return "UNSOL_STK_CALL_SETUP"; 307800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_SIM_SMS_STORAGE_FULL: return "UNSOL_SIM_SMS_STORAGE_FUL"; 307900f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_SIM_REFRESH: return "UNSOL_SIM_REFRESH"; 3080f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_UNSOL_DATA_CALL_LIST_CHANGED: return "UNSOL_DATA_CALL_LIST_CHANGED"; 308100f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project case RIL_UNSOL_CALL_RING: return "UNSOL_CALL_RING"; 3082f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED: return "UNSOL_RESPONSE_SIM_STATUS_CHANGED"; 3083f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_UNSOL_RESPONSE_CDMA_NEW_SMS: return "UNSOL_NEW_CDMA_SMS"; 3084f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS: return "UNSOL_NEW_BROADCAST_SMS"; 3085f4c4d36c410a3501d282dd7de1c7c3350734f27eWink Saville case RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL: return "UNSOL_CDMA_RUIM_SMS_STORAGE_FULL"; 30863d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_UNSOL_RESTRICTED_STATE_CHANGED: return "UNSOL_RESTRICTED_STATE_CHANGED"; 30873d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE: return "UNSOL_ENTER_EMERGENCY_CALLBACK_MODE"; 30883d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_UNSOL_CDMA_CALL_WAITING: return "UNSOL_CDMA_CALL_WAITING"; 30893d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_UNSOL_CDMA_OTA_PROVISION_STATUS: return "UNSOL_CDMA_OTA_PROVISION_STATUS"; 30903d54e74bc450bb40977e3ae6fab6185fe687bdaeWink Saville case RIL_UNSOL_CDMA_INFO_REC: return "UNSOL_CDMA_INFO_REC"; 3091af6ecbf0fa03379818038459ee1b61ea393ffd4fJaikumar Ganesh case RIL_UNSOL_OEM_HOOK_RAW: return "UNSOL_OEM_HOOK_RAW"; 30925d621da539abea83309d77317ede40126f47d5f0John Wang case RIL_UNSOL_RINGBACK_TONE: return "UNSOL_RINGBACK_TONE"; 30935909cf831f0d687e93164daaecc43a2ff792cc3aJohn Wang case RIL_UNSOL_RESEND_INCALL_MUTE: return "UNSOL_RESEND_INCALL_MUTE"; 309400f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project default: return "<unknown request>"; 309500f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project } 309600f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} 309700f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project 309800f06fc3fdb05d4276e76091cacb42b6f6862222The Android Open Source Project} /* namespace android */ 3099