blob: dae9b5c7a7450e90fad23aa1e0a1fdda3975c370 [file] [log] [blame]
ll7683a722023-01-19 11:14:23 +08001#include <stdio.h>
2#include <sys/types.h>
3#include <sys/socket.h>
4#include <arpa/inet.h>
5#include <string.h>
6#include <unistd.h>
7#include <binder/Parcel.h>
8#include <log/log.h>
9#include <cutils/jstring.h>
10#include <pthread.h>
11#include <list>
12#include <vendor-ril/telephony/ril.h>
13#include <vendor-ril/telephony/mtk_ril_sp.h>
14#include "lynq_sms.h"
15#include "lynq_module_common.h"
16#include "lynq_module_socket.h"
17#include "liblog/lynq_deflog.h"
18#include "lynq_shm.h"
19
20#define LYNQ_SERVICE_PORT 8088
21#define LYNQ_ADDRESS "127.0.0.1"
lh0e551da2023-03-28 09:50:20 +080022#define LYNQ_URC_SERVICE_PORT 8086
lh2974e4a2024-02-21 00:14:24 -080023#ifdef GSW_RIL_CFG
24#define LYNQ_URC_ADDRESS "127.255.255.255" /*hong.liu change broadcast addr on 2024.2.18*/
25#else
lh0e551da2023-03-28 09:50:20 +080026#define LYNQ_URC_ADDRESS "0.0.0.0"
lh2974e4a2024-02-21 00:14:24 -080027#endif
ll7683a722023-01-19 11:14:23 +080028#define LYNQ_REQUEST_PARAM_BUF 8192
29#define LYNQ_REC_BUF 8192
30
31#define USER_LOG_TAG "LYNQ_NETWORK"
32
33typedef struct{
34 int uToken;
35 int request;
36 int paramLen;
37 char param[LYNQ_REQUEST_PARAM_BUF];
38}lynq_client_t;
39
40typedef struct{
41 int resp_type;
42 int token;
43 int request;
44 int slot_id;
45 int error;
46}lynq_resp_t;
47
48typedef struct{
49 int resp_type;
50 int urcid;
51}lynq_head_t;
52
53lynq_client_t client_t;
54lynq_resp_t response;
55
56int module_len_rc_addr_serv;
lh0e551da2023-03-28 09:50:20 +080057int module_len_urc_addr_serv;
ll7683a722023-01-19 11:14:23 +080058struct sockaddr_in module_rc_addr_serv;
lh0e551da2023-03-28 09:50:20 +080059struct sockaddr_in module_urc_addr_serv;
ll7683a722023-01-19 11:14:23 +080060static int module_rc_sock_fd = -1;
lh0e551da2023-03-28 09:50:20 +080061static int module_urc_sock_fd = -1;
ll7683a722023-01-19 11:14:23 +080062int module_urc_status = 1;
63int module_rc_status = 1;
64pthread_t module_urc_tid = -1;
65pthread_t module_rc_tid = -1;
66static pthread_mutex_t s_urc_mutex = PTHREAD_MUTEX_INITIALIZER;
67
68/*hq add for set waiting time 2022/09/13 begin*/
69static pthread_mutex_t s_sendto_mutex = PTHREAD_MUTEX_INITIALIZER;
70static pthread_mutex_t s_RecvMsgBlockMutex = PTHREAD_MUTEX_INITIALIZER;
71static pthread_cond_t s_WaitRecvMsgCond = PTHREAD_COND_INITIALIZER;
72#define BLOCK_RECV_MSG_LOCK() pthread_mutex_lock(&s_RecvMsgBlockMutex)
73#define BLOCK_RECV_MSG_UNLOCK() pthread_mutex_unlock(&s_RecvMsgBlockMutex)
74#define BLOCK_WAIT_RECV_MSG_TIME_OUT(a) pthread_cond_timedwait(&s_WaitRecvMsgCond, &s_RecvMsgBlockMutex,(a))
75#define BLOCK_WAKEUP_RECV_MSG() pthread_cond_broadcast(&s_WaitRecvMsgCond)
76static std::list<Parcel*> s_recv_parcel_list;
77const int waitResponse(int token,int time_out);
78/*hq add for set waiting time 2022/09/13 end*/
79
80/*hq add for urc process asynchronous 2022/12/26 begin*/
81static pthread_mutex_t s_ProcessUrcMsgBlockMutex = PTHREAD_MUTEX_INITIALIZER;
82static pthread_cond_t s_WaitProcessUrcMsgCond = PTHREAD_COND_INITIALIZER;
83
84#define BLOCK_PROCESS_URC_MSG_INIT() pthread_mutex_init(&s_ProcessUrcMsgBlockMutex,NULL)
85#define BLOCK_PROCESS_URC_MSG_LOCK() pthread_mutex_lock(&s_ProcessUrcMsgBlockMutex)
86#define BLOCK_PROCESS_URC_MSG_UNLOCK() pthread_mutex_unlock(&s_ProcessUrcMsgBlockMutex)
87#define BLOCK_WAIT_PROCESS_URC_MSG() pthread_cond_wait(&s_WaitProcessUrcMsgCond, &s_ProcessUrcMsgBlockMutex)
88#define BLOCK_WAKEUP_PROCESS_URC_MSG() pthread_cond_broadcast(&s_WaitProcessUrcMsgCond)
89static std::list<Parcel*> s_recv_urc_parcel_list;
90void *thread_urc_process(void *p);
91pthread_t module_urc_process_tid = -1;
92int module_urc_process_status = 1;
93/*hq add for urc process asynchronous 2022/12/26 end*/
94
95int g_module_Global_uToken = 0;
96int g_wait_time=5;
97
98/*inner test*/
99static int s_inner_test=0;
100
101/**@brief just for inner test
102* @param test_mode [IN]: test mode
103* 0:success
104* other:failure
105*/
106void lynq_set_test_mode(const int test_mode)
107{
108 if(test_mode<0)
109 {
110 g_wait_time = -test_mode;
111 }
112 else if(test_mode==9999)
113 {
114 LYERRLOG("%s inner test para %d %d",__FUNCTION__,s_inner_test,g_wait_time);
115 }
116 else
117 {
118 s_inner_test = test_mode;
119 }
120}
121
122void cleanup_RecvMsgBlock_mutex(void *arg)
123{
124 BLOCK_RECV_MSG_UNLOCK();
125}
126
127/**@brief wait response with expected token and write msg to parcel in some time
128* @param p [IN]: pointer the parcel
129* @param token [IN]: the expected token for the response msg
130* @param time_out [IN]: timeout.
131* @return
132* 0:success
133* other:failure
134*/
135const int waitResponse(Parcel*& p, int token,int time_out)
136{
137 int waitToken = token;
138 int wakeup_token=-1;
139 int resp_type;
140 struct timeval now;
141 struct timespec timeout;
142 int ret;
143 std::list<Parcel*>::iterator iter;
144 int cnt=0;
145
146 gettimeofday(&now,NULL);
147 timeout.tv_sec = now.tv_sec+time_out; //timeout is 1min
148 timeout.tv_nsec = now.tv_usec*1000;
149
150 LYINFLOG("%s wait token is %d, wait time is %d",__FUNCTION__,waitToken,time_out);
151
152 BLOCK_RECV_MSG_LOCK();
153 pthread_cleanup_push(cleanup_RecvMsgBlock_mutex, NULL); // thread cleanup handler
154 while(module_rc_status){
155 cnt++;
156 for(iter=s_recv_parcel_list.begin();iter!=s_recv_parcel_list.end();++iter)
157 {
158 (*iter)->setDataPosition(0);
159 (*iter)->readInt32(&resp_type);
160 (*iter)->readInt32(&wakeup_token);
161 if(wakeup_token==waitToken)
162 {
163 LYINFLOG("%s get waitToken",__FUNCTION__);
164 p=(*iter);
165 p->setDataPosition(0);
166 s_recv_parcel_list.erase(iter);
167 goto waitResponse_end;
168 }
169 }
170 LYINFLOG("%s no wait Token in msg list, list size is %d",__FUNCTION__,s_recv_parcel_list.size());
171 ret=BLOCK_WAIT_RECV_MSG_TIME_OUT(&timeout);
172 if(ret!=0)
173 {
174 LYERRLOG("%s no expected token %d after %d second",__FUNCTION__,waitToken,time_out);
175 break;
176 }
177 }
178waitResponse_end:
179 LYINFLOG("%s wait token is %d wakeup_token is %d, cnt is %d",__FUNCTION__,waitToken,wakeup_token,cnt);
180 pthread_cleanup_pop(0);
181 BLOCK_RECV_MSG_UNLOCK();
182 return wakeup_token==waitToken ? 0:LYNQ_E_TIME_OUT;
183}
184
185/**@brief print solicied response msg's head information
186* @param head [IN]: head information
187* @return none
188*/
189void PrintHeader(lynq_resp_t& head)
190{
191 LYINFLOG("resp_type=%d,token=%d,request=%d,slot_id=%d,error_code=%d",head.resp_type,head.token,head.request,head.slot_id,head.error);
192}
193
194/**@brief get solicied response msg's head
195* @param head [OUT]: head information
196* @return
197* 0:success
198* other:failure
199*/
200int GetHeader(Parcel* &p, lynq_resp_t& head)
201{
202 LYINFLOG("get header");
203 if(p->dataAvail() > 0)
204 {
205 p->readInt32(&(head.resp_type));
206 p->readInt32(&(head.token));
207 p->readInt32(&(head.request));
208 p->readInt32(&(head.slot_id));
209 p->readInt32(&(head.error));
210 PrintHeader(head);
211 return RESULT_OK;
212 }
213 else
214 {
215 return RESULT_ERROR;
216 }
217}
218
219/**@brief send msg to service and get response from service
220* @param request_id [IN]: request id
221* @param time_out [IN]: wait time uplimit
222* @param p [IN]: point to response msg's parcel
223* @param argc [IN]: how many parameters in parameter string
224* @param format [IN]: parameter string's format
225* @param ... [IN]: the specific parameter
226* @return
227* 0:success
228* other:failure
229*/
230int lynq_send_common_request(Parcel*& p, int time_out, int request_id, int argc, const char* format,...)
231{
232 lynq_client_t client;
233 int ret;
234 int send_num;
235
236 client.uToken = g_module_Global_uToken;
237 g_module_Global_uToken=(g_module_Global_uToken+1)%10000;/*0-10000*/
238 client.request = request_id;
239 client.paramLen = argc;
240 bzero(client.param,LYNQ_REQUEST_PARAM_BUF);
241 if(argc!=0)
242 {
243 va_list args;
244 va_start(args, format);
245 vsnprintf(client.param, LYNQ_REQUEST_PARAM_BUF, format, args);
246 va_end(args);
247 }
248 LYINFLOG("uToken=%d,request=%d,paralen=%d,param=%s",client.uToken,client.request,client.paramLen,client.param);
249 pthread_mutex_lock(&s_sendto_mutex);
250 if(s_inner_test==1)
251 {
252 send_num = 1;
253 }
254 else
255 {
256 send_num = sendto(module_rc_sock_fd,&client,sizeof(client),0,(struct sockaddr *)&module_rc_addr_serv,module_len_rc_addr_serv);
257 }
258 if(s_inner_test>=1000)
259 {
260 time_out = s_inner_test-1000;
261 }
262 pthread_mutex_unlock(&s_sendto_mutex);
263
264 if(send_num <= 0)
265 {
266 LYERRLOG("send request fail, send num is %d", send_num);
267 return LYNQ_E_SEND_REQUEST_FAIL;
268 }
269 ret = waitResponse(p, client.uToken,time_out);
270
271 if(ret==0)
272 {
273 lynq_resp_t head;
274 ret=GetHeader(p,head);
275 if(ret!=0)
276 {
277 LYERRLOG("%s %d get head error %d",__FUNCTION__,client.uToken,ret);
278 delete p;
279 return LYNQ_E_GET_HEAD_ERROR;
280 }
281 if(head.error!=0)
282 {
283 LYERRLOG("%s %d mdm return head error %d",__FUNCTION__,client.uToken,head.error);
284 delete p;
285 return head.error;
286 }
287 LYERRLOG("%s %d suc",__FUNCTION__,client.uToken);
288 return RESULT_OK;
289 }
290
291 LYERRLOG("%s %d fail, ret is %d",__FUNCTION__,client.uToken,ret);
292
293 return ret;
294}
295
296/*hq add for urc broadcase optimisson 2023/01/03 begin*/
297#define SHM_BUFFER_INDEX_OFFSET 1
298#define SHM_BUFFER_SIZE_OFFSET 16
299#define SHM_BUFFER_INDEX_MASK 0x0000007F
300#define SHM_BUFFER_SIZE_MASK 0x0000FFFF
301
302bool urc_data_is_in_shm_data(int responseType,int& level, int& index, int& size)
303{
304 int shm_index=((responseType>>SHM_BUFFER_INDEX_OFFSET)&SHM_BUFFER_INDEX_MASK);
305 if (shm_index>0)
306 {
307 index=shm_index-1;
308 size=((responseType>>SHM_BUFFER_SIZE_OFFSET)&SHM_BUFFER_SIZE_MASK);
309 if(size>=sizeof(int32_t)*3 && get_shem_buffer_level(size,&level))
310 {
311 LYINFLOG("urc_data_is_in_shm_data level is %d, index is %d size is %d",level,index,size);
312 return true;
313 }
314 }
315 LYINFLOG("urc_data_is_in_shm_data return false, responseType is %d",responseType);
316 return false;
317}
318/*hq add for urc broadcase optimisson 2023/01/03 end*/
319
320void *thread_urc_recv(void *p)
321{
322 Parcel *urc_p =NULL;
323 char urc_data[LYNQ_REC_BUF];
324 int res = 0;
325 lynq_head_t* phead;
326
327 LYINFLOG("urc recv thread is running");
328 while(module_urc_status)
329 {
330 bzero(urc_data,LYNQ_REC_BUF);
lh0e551da2023-03-28 09:50:20 +0800331 res = recvfrom(module_urc_sock_fd,urc_data,sizeof(urc_data),0,(struct sockaddr *)&module_urc_addr_serv,(socklen_t*)&module_len_urc_addr_serv);
ll7683a722023-01-19 11:14:23 +0800332 if(res<sizeof(int32_t)*2)
333 {
334 LYERRLOG("thread_urc_recv step2 fail: res is %d",res);
335 continue;
336 }
337 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
338 phead=(lynq_head_t*) urc_data;
339 if(is_support_urc(phead->urcid)==false)
340 {
341 continue;
342 }
343 urc_p = new Parcel();
344 if(urc_p == NULL)
345 {
346 LYERRLOG("new parcel failure!!!");
347 continue;
348 }
349 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
350 int level,index,size;
351 if(urc_data_is_in_shm_data(phead->resp_type,level,index,size))
352 {
353 LYINFLOG("__FUNCTION__ %s __LINE__ %d,use share memory\n", __FUNCTION__, __LINE__);
354 urc_p->setData((uint8_t *)get_shem_buffer(level,index),size); // p.setData((uint8_t *) buffer, buflen);
355 }
356 else if(res>=sizeof(int32_t)*3)
357 {
358 urc_p->setData((uint8_t *)urc_data,res); // p.setData((uint8_t *) buffer, buflen);
359 }
360 else
361 {
362 LYERRLOG("res %d error!!!", res);
363 delete urc_p;
364 urc_p = NULL;
365 continue;
366 }
367 urc_p->setDataPosition(0);
368 if(urc_p->dataAvail()>0)
369 {
370 BLOCK_PROCESS_URC_MSG_LOCK();
371 s_recv_urc_parcel_list.push_back(urc_p);
372 BLOCK_WAKEUP_PROCESS_URC_MSG();
373 BLOCK_PROCESS_URC_MSG_UNLOCK();
374 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
375 }
376 else
377 {
378 delete urc_p;
379 urc_p = NULL;
380 }
381 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
382 }
383 LYINFLOG("urc recv thread ended");
384 return NULL;
385}
386
387void cleanup_urc_process_mutex(void *arg)
388{
389 BLOCK_PROCESS_URC_MSG_UNLOCK();
390}
391
392void *thread_urc_process(void *p)
393{
394 Parcel *urc_p =NULL;
395 std::list<Parcel*>::iterator iter;
396
397 LYINFLOG("urc process thread is running");
398 pthread_cleanup_push(cleanup_urc_process_mutex, NULL); // thread cleanup handler
399 while(module_urc_process_status)
400 {
401 BLOCK_PROCESS_URC_MSG_LOCK();
402 while(s_recv_urc_parcel_list.empty())
403 {
404 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
405 BLOCK_WAIT_PROCESS_URC_MSG();
406 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
407 }
408 iter=s_recv_urc_parcel_list.begin();
409 urc_p=(*iter);
410 s_recv_urc_parcel_list.erase(iter);
411 BLOCK_PROCESS_URC_MSG_UNLOCK();
412 urc_p->setDataPosition(0);
413 if(urc_p->dataAvail()>0)
414 {
415 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
416 pthread_mutex_lock(&s_urc_mutex);
417 urc_msg_process(urc_p);
418 pthread_mutex_unlock(&s_urc_mutex);
419 LYINFLOG("__FUNCTION__ %s __LINE__ %d\n", __FUNCTION__, __LINE__);
420 }
421 delete urc_p;
422 urc_p = NULL;
423 }
424 pthread_cleanup_pop(0);
425 LYINFLOG("urc process thread ended");
426 return NULL;
427}
428
429void lynq_close_urc_rev_thread()
430{
431 int ret;
432
433 BLOCK_PROCESS_URC_MSG_LOCK(); //just cancel urc process tid when recv from
434 module_urc_status = 0;
435 if(module_urc_tid!=-1)
436 {
437 ret = pthread_cancel(module_urc_tid);
438 LYINFLOG("pthread cancel urc rev ret = %d",ret);
439 }
440 BLOCK_PROCESS_URC_MSG_UNLOCK();
441 if(module_urc_tid != -1)
442 {
443 ret = pthread_join(module_urc_tid,NULL);
444 LYINFLOG("pthread join urc tid ret = %d",ret);
445 module_urc_tid =-1;
446 }
447}
448
449void lynq_close_urc_process_thread()
450{
451 int ret;
452 BLOCK_PROCESS_URC_MSG_LOCK(); //just cancel urc process tid when not process urc msg in list
453 pthread_mutex_lock(&s_urc_mutex); //just cancel urc process tid when not process urg msg avoid mutual lock for tid may call pthread_cond_wait
454 module_urc_process_status = 0;
455 if(module_urc_process_tid!=-1)
456 {
457 ret = pthread_cancel(module_urc_process_tid);
458 LYINFLOG("pthread cancel urc process ret = %d",ret);
459 }
460 pthread_mutex_unlock(&s_urc_mutex);
461 BLOCK_PROCESS_URC_MSG_UNLOCK();
462 if(module_urc_process_tid != -1)
463 {
464 ret = pthread_join(module_urc_process_tid,NULL);
465 LYINFLOG("pthread join urc process tid ret = %d",ret);
466 module_urc_process_tid =-1;
467 }
468}
469
470int lynq_setup_urc_socket()
471{
lh0e551da2023-03-28 09:50:20 +0800472 int on = 1;
473 int ret = 0;
474 module_len_urc_addr_serv = sizeof(sockaddr_in);
475 module_urc_sock_fd = socket(AF_INET, SOCK_DGRAM, 0);
476 if (module_urc_sock_fd <0){
477 LYERRLOG("urc socket error");
478 return RESULT_ERROR;
479 }
480 module_urc_addr_serv.sin_family = AF_INET;
481 module_urc_addr_serv.sin_port = htons(LYNQ_URC_SERVICE_PORT);
482 module_urc_addr_serv.sin_addr.s_addr = inet_addr(LYNQ_URC_ADDRESS);
483 /* Set socket to allow reuse of address and port, SO_REUSEADDR value is 2*/
484 ret = setsockopt(module_urc_sock_fd,SOL_SOCKET,SO_REUSEADDR,&on,sizeof on);
485 if(ret <0)
486 {
487 LYERRLOG("urc socket set error");
488 close(module_urc_sock_fd);
489 module_urc_sock_fd =-1;
490 return RESULT_ERROR;
491 }
492 ret = bind(module_urc_sock_fd ,(struct sockaddr*)&module_urc_addr_serv, sizeof(module_urc_addr_serv));
493 if(ret <0)
494 {
495 LYERRLOG("urc socket bind error");
496 close(module_urc_sock_fd);
497 module_urc_sock_fd =-1;
498 return RESULT_ERROR;
499 }
500 return RESULT_OK;
ll7683a722023-01-19 11:14:23 +0800501}
502
503void lynq_close_urc_socket()
504{
lh0e551da2023-03-28 09:50:20 +0800505 if (module_urc_sock_fd >= 0)
506 {
507 close(module_urc_sock_fd);
508 module_urc_sock_fd =-1;
509 }
ll7683a722023-01-19 11:14:23 +0800510}
511
512int lynq_start_all_urc_socket_thread()
513{
514
515 if(ril_init_mem()!=0)
516 {
517 LYERRLOG("ril_init_mem fail");
518 return RESULT_ERROR;
519 }
520
521 int ret= lynq_setup_urc_socket();
522 if(ret!=RESULT_OK)
523 {
524 LYERRLOG("sms lynq_setup_urc_socket fail");
525 ril_deinit_mem();
526 return RESULT_ERROR;
527 }
528
529 BLOCK_PROCESS_URC_MSG_INIT();
530 BLOCK_PROCESS_URC_MSG_LOCK();
531 std::list<Parcel*>::iterator iter;
532 for(iter=s_recv_urc_parcel_list.begin();iter!=s_recv_urc_parcel_list.end();++iter)
533 {
534 delete (*iter);
535 }
536 s_recv_urc_parcel_list.clear();
537 BLOCK_PROCESS_URC_MSG_UNLOCK();
538
539 pthread_mutex_init(&s_urc_mutex, NULL);
540
541 module_urc_status = 1;
542 // pthread_attr_init(&attr);
543 // pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
544 ret = pthread_create(&module_urc_tid,/*&attr*/NULL,thread_urc_recv,NULL);
545 if(ret <0)
546 {
547 LYERRLOG("urc recv pthread create error");
548 module_urc_status = 0;
549 lynq_close_urc_socket();
550 ril_deinit_mem();
551 return RESULT_ERROR;
552 }
553
554 module_urc_process_status = 1;
555 ret = pthread_create(&module_urc_process_tid,/*&attr*/NULL,thread_urc_process,NULL);
556 if(ret <0)
557 {
558 LYERRLOG("urc process pthread create error");
559 module_urc_process_status = 0;
560 lynq_close_urc_socket();
561 lynq_close_urc_rev_thread();
562 ril_deinit_mem();
563 return RESULT_ERROR;
564 }
565
566 LYINFLOG("urc start success");
567
568 return RESULT_OK;
569}
570
571void lynq_close_all_urc_socket_thread()
572{
573
574 lynq_close_urc_rev_thread();
575 lynq_close_urc_socket();
576 lynq_close_urc_process_thread();
577
578 BLOCK_PROCESS_URC_MSG_LOCK();
579 std::list<Parcel*>::iterator iter;
580 for(iter=s_recv_urc_parcel_list.begin();iter!=s_recv_urc_parcel_list.end();++iter)
581 {
582 delete (*iter);
583 }
584 s_recv_urc_parcel_list.clear();
585 BLOCK_PROCESS_URC_MSG_UNLOCK();
586
587 ril_deinit_mem();
588}
589
590bool is_support_request(int req_id)
591{
592 switch(req_id)
593 {
594 case RIL_REQUEST_SEND_SMS:
595 case RIL_REQUEST_SET_SMSC_ADDRESS:
596 case RIL_REQUEST_GET_SMSC_ADDRESS:
597 case LYNQ_REQUEST_READ_SMS_FROM_MEMORY:
598 case LYNQ_REQUEST_DELETE_SMS_FROM_MEMORY:
599 case LYNQ_REQUEST_LIST_SMS_FROM_MEMORY:
600 return true;
601 default:
602 return false;
603 }
604}
605
606/**@ a thread just for recv\buffer solicited msg's response and notice waiting thread
607* @param p [IN]: no meaning
608* @return
609* always null
610*/
611void *thread_rc_recv(void *p)
612{
613 Parcel* rc_p;
614 std::list<Parcel*>::iterator iter;
615 int resp_type = -1;
616 char rc_data[LYNQ_REC_BUF];
617 int rc_len;
618 int null_cnt=0;
619 int wakeup_token;
620 int resquest;
621 LYINFLOG("rc thread is running");
622 while(module_rc_status)
623 {
624 bzero(rc_data,LYNQ_REC_BUF);
625 while(true)
626 {
627 rc_len = recvfrom(module_rc_sock_fd,rc_data,sizeof(rc_data),0,(struct sockaddr *)&module_rc_addr_serv,(socklen_t *)&module_len_rc_addr_serv);
628 if(rc_len<sizeof(int32_t)*2)
629 {
630 LYERRLOG("%s recv len %d less %d",__FUNCTION__, rc_len,sizeof(int)*2);
631 continue;
632 }
633 rc_p= new Parcel;
634 if(rc_p==NULL)
635 {
636 null_cnt++;
637 LYERRLOG("%s rc_p is NULL, cnt is %d",__FUNCTION__, null_cnt);
638 if(null_cnt>20)
639 {
640 goto rc_recv_end;
641 }
642 continue;
643 }
644 else
645 {
646 null_cnt=0;
647 }
648
649 rc_p->setData((uint8_t *)rc_data,rc_len); // p.setData((uint8_t *) buffer, buflen);
650 rc_p->setDataPosition(0);
651 if(rc_p->dataAvail()>0)
652 {
653 rc_p->readInt32(&resp_type);
654 rc_p->readInt32(&wakeup_token);
655 rc_p->readInt32(&resquest);
656 if(!is_support_request(resquest))
657 {
658 continue;
659 }
660 BLOCK_RECV_MSG_LOCK();
661 s_recv_parcel_list.push_back(rc_p);
662 LYINFLOG("%s wakeup token is %d, list size is %d!",__FUNCTION__,wakeup_token,s_recv_parcel_list.size());
663 if(s_recv_parcel_list.size()>20) //max 20
664 {
665 iter=s_recv_parcel_list.begin();
666 (*iter)->setDataPosition(0);
667 (*iter)->readInt32(&resp_type);
668 (*iter)->readInt32(&wakeup_token);
669 delete (*(s_recv_parcel_list.begin()));
670 LYERRLOG("%s wakeup token %d is deleted!",__FUNCTION__,wakeup_token);
671 s_recv_parcel_list.erase(iter);
672 }
673 BLOCK_WAKEUP_RECV_MSG();
674 BLOCK_RECV_MSG_UNLOCK();
675 break;
676 }
677 else
678 {
679 LYERRLOG("%s rc_p data Avail %d not greater than 0",__FUNCTION__, rc_p->dataAvail());
680 delete rc_p;
681 }
682 }
683 }
684
685rc_recv_end:
686 LYINFLOG("rc thread ended");
687 return NULL;
688}
689
690int lynq_start_all_rc_socket_thread()
691{
692 module_rc_sock_fd = socket(AF_INET, SOCK_DGRAM, 0);
693 if(module_rc_sock_fd < 0)
694 {
695 LYERRLOG("socket open error");
696 return -1;
697 }
698
lh8d290112023-10-22 20:53:06 -0700699 struct sockaddr_in liblynq_data_socket;
700 bzero(&liblynq_data_socket, sizeof(liblynq_data_socket));
701 //set this lib socket config
702 liblynq_data_socket.sin_family = AF_INET;
703 liblynq_data_socket.sin_addr.s_addr = inet_addr(LYNQ_ADDRESS);
704 int ret = bind(module_rc_sock_fd, (struct sockaddr *)&liblynq_data_socket, sizeof(liblynq_data_socket));
705 if (-1 == ret)
706 {
707 LYERRLOG("liblynq_data_socket bind fail,errno:%d",errno);
708 return -1;
709 }
710
ll7683a722023-01-19 11:14:23 +0800711 LYINFLOG("module_rc_sock_fd = %d",module_rc_sock_fd);
712
713 memset(&module_rc_addr_serv, 0, sizeof(module_rc_addr_serv));
714 module_rc_addr_serv.sin_family = AF_INET;
715 module_rc_addr_serv.sin_addr.s_addr = inet_addr(LYNQ_ADDRESS);
716 module_rc_addr_serv.sin_port = htons(LYNQ_SERVICE_PORT);
717 module_len_rc_addr_serv = sizeof(module_rc_addr_serv);
718
719 BLOCK_RECV_MSG_LOCK();
720 std::list<Parcel*>::iterator iter;
721 for(iter=s_recv_parcel_list.begin();iter!=s_recv_parcel_list.end();++iter)
722 {
723 delete (*iter);
724 }
725 s_recv_parcel_list.clear();
726 BLOCK_RECV_MSG_UNLOCK();
727
728// pthread_attr_t attr;
ll7683a722023-01-19 11:14:23 +0800729
730 pthread_mutex_init(&s_sendto_mutex, NULL);
731 pthread_mutex_init(&s_RecvMsgBlockMutex, NULL);
732
733 module_rc_status = 1;
734// pthread_attr_init(&attr);
735// pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
736 ret = pthread_create(&module_rc_tid,/*&attr*/NULL,thread_rc_recv,NULL);
737 if(ret <0)
738 {
739 LYERRLOG("rc pthread create error");
740 module_rc_status =0;
741 close(module_rc_sock_fd);
742 module_rc_sock_fd =-1;
743 return ret;
744 }
745
746 LYINFLOG("rc start success");
747
748 return RESULT_OK;
749}
750
751void lynq_close_all_rc_socket_thread()
752{
753 int ret;
754 BLOCK_RECV_MSG_LOCK();
755 module_rc_status = 0;
756 BLOCK_WAKEUP_RECV_MSG();
757 if(module_rc_tid != -1)
758 {
759 ret = pthread_cancel(module_rc_tid);
760 LYINFLOG("pthread cancel rc ret = %d",ret);
761 }
762 BLOCK_RECV_MSG_UNLOCK();
763 if(module_rc_tid != -1)
764 {
765 ret = pthread_join(module_rc_tid,NULL);
766 module_rc_tid =-1;
767 LYINFLOG("pthread join rc tid ret = %d",ret);
768
769 }
770
771 if (module_rc_sock_fd > 0)
772 {
773 close(module_rc_sock_fd);
774 module_rc_sock_fd =-1;
775 }
776
777 BLOCK_RECV_MSG_LOCK();
778 std::list<Parcel*>::iterator iter;
779 for(iter=s_recv_parcel_list.begin();iter!=s_recv_parcel_list.end();++iter)
780 {
781 delete (*iter);
782 }
783 s_recv_parcel_list.clear();
784 BLOCK_RECV_MSG_UNLOCK();
785}
786
787const char * requestToString(int request)
788{
789 /*
790 cat libs/telephony/ril_commands.h \
791 | egrep "^ *{RIL_" \
792 | sed -re 's/\{RIL_([^,]+),[^,]+,([^}]+).+/case RIL_\1: return "\1";/'
793
794
795 cat libs/telephony/ril_unsol_commands.h \
796 | egrep "^ *{RIL_" \
797 | sed -re 's/\{RIL_([^,]+),([^}]+).+/case RIL_\1: return "\1";/'
798
799 */
800 switch(request) {
801 case RIL_REQUEST_GET_SIM_STATUS: return "GET_SIM_STATUS";
802 case RIL_REQUEST_ENTER_SIM_PIN: return "ENTER_SIM_PIN";
803 case RIL_REQUEST_ENTER_SIM_PUK: return "ENTER_SIM_PUK";
804 case RIL_REQUEST_ENTER_SIM_PIN2: return "ENTER_SIM_PIN2";
805 case RIL_REQUEST_ENTER_SIM_PUK2: return "ENTER_SIM_PUK2";
806 case RIL_REQUEST_CHANGE_SIM_PIN: return "CHANGE_SIM_PIN";
807 case RIL_REQUEST_CHANGE_SIM_PIN2: return "CHANGE_SIM_PIN2";
808 case RIL_REQUEST_ENTER_NETWORK_DEPERSONALIZATION: return "ENTER_NETWORK_DEPERSONALIZATION";
809 case RIL_REQUEST_GET_CURRENT_CALLS: return "GET_CURRENT_CALLS";
810 case RIL_REQUEST_DIAL: return "DIAL";
811 case RIL_REQUEST_GET_IMSI: return "GET_IMSI";
812 case RIL_REQUEST_HANGUP: return "HANGUP";
813 case RIL_REQUEST_HANGUP_WAITING_OR_BACKGROUND: return "HANGUP_WAITING_OR_BACKGROUND";
814 case RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND: return "HANGUP_FOREGROUND_RESUME_BACKGROUND";
815 case RIL_REQUEST_SWITCH_WAITING_OR_HOLDING_AND_ACTIVE: return "SWITCH_WAITING_OR_HOLDING_AND_ACTIVE";
816 case RIL_REQUEST_CONFERENCE: return "CONFERENCE";
817 case RIL_REQUEST_UDUB: return "UDUB";
818 case RIL_REQUEST_LAST_CALL_FAIL_CAUSE: return "LAST_CALL_FAIL_CAUSE";
819 case RIL_REQUEST_SIGNAL_STRENGTH: return "SIGNAL_STRENGTH";
820 case RIL_REQUEST_VOICE_REGISTRATION_STATE: return "VOICE_REGISTRATION_STATE";
821 case RIL_REQUEST_DATA_REGISTRATION_STATE: return "DATA_REGISTRATION_STATE";
822 case RIL_REQUEST_OPERATOR: return "OPERATOR";
823 case RIL_REQUEST_RADIO_POWER: return "RADIO_POWER";
824 case RIL_REQUEST_DTMF: return "DTMF";
825 case RIL_REQUEST_SEND_SMS: return "SEND_SMS";
826 case RIL_REQUEST_SEND_SMS_EXPECT_MORE: return "SEND_SMS_EXPECT_MORE";
827 case RIL_REQUEST_SETUP_DATA_CALL: return "SETUP_DATA_CALL";
828 case RIL_REQUEST_SIM_IO: return "SIM_IO";
829 case RIL_REQUEST_SEND_USSD: return "SEND_USSD";
830 case RIL_REQUEST_CANCEL_USSD: return "CANCEL_USSD";
831 case RIL_REQUEST_GET_CLIR: return "GET_CLIR";
832 case RIL_REQUEST_SET_CLIR: return "SET_CLIR";
833 case RIL_REQUEST_QUERY_CALL_FORWARD_STATUS: return "QUERY_CALL_FORWARD_STATUS";
834 case RIL_REQUEST_SET_CALL_FORWARD: return "SET_CALL_FORWARD";
835 case RIL_REQUEST_QUERY_CALL_WAITING: return "QUERY_CALL_WAITING";
836 case RIL_REQUEST_SET_CALL_WAITING: return "SET_CALL_WAITING";
837 case RIL_REQUEST_SMS_ACKNOWLEDGE: return "SMS_ACKNOWLEDGE";
838 case RIL_REQUEST_GET_IMEI: return "GET_IMEI";
839 case RIL_REQUEST_GET_IMEISV: return "GET_IMEISV";
840 case RIL_REQUEST_ANSWER: return "ANSWER";
841 case RIL_REQUEST_DEACTIVATE_DATA_CALL: return "DEACTIVATE_DATA_CALL";
842 case RIL_REQUEST_QUERY_FACILITY_LOCK: return "QUERY_FACILITY_LOCK";
843 case RIL_REQUEST_SET_FACILITY_LOCK: return "SET_FACILITY_LOCK";
844 case RIL_REQUEST_CHANGE_BARRING_PASSWORD: return "CHANGE_BARRING_PASSWORD";
845 case RIL_REQUEST_QUERY_NETWORK_SELECTION_MODE: return "QUERY_NETWORK_SELECTION_MODE";
846 case RIL_REQUEST_SET_NETWORK_SELECTION_AUTOMATIC: return "SET_NETWORK_SELECTION_AUTOMATIC";
847 case RIL_REQUEST_SET_NETWORK_SELECTION_MANUAL: return "SET_NETWORK_SELECTION_MANUAL";
848 case RIL_REQUEST_QUERY_AVAILABLE_NETWORKS : return "QUERY_AVAILABLE_NETWORKS ";
849 case RIL_REQUEST_DTMF_START: return "DTMF_START";
850 case RIL_REQUEST_DTMF_STOP: return "DTMF_STOP";
851 case RIL_REQUEST_BASEBAND_VERSION: return "BASEBAND_VERSION";
852 case RIL_REQUEST_SEPARATE_CONNECTION: return "SEPARATE_CONNECTION";
853 case RIL_REQUEST_SET_PREFERRED_NETWORK_TYPE: return "SET_PREFERRED_NETWORK_TYPE";
854 case RIL_REQUEST_GET_PREFERRED_NETWORK_TYPE: return "GET_PREFERRED_NETWORK_TYPE";
855 case RIL_REQUEST_GET_NEIGHBORING_CELL_IDS: return "GET_NEIGHBORING_CELL_IDS";
856 case RIL_REQUEST_SET_MUTE: return "SET_MUTE";
857 case RIL_REQUEST_GET_MUTE: return "GET_MUTE";
858 case RIL_REQUEST_QUERY_CLIP: return "QUERY_CLIP";
859 case RIL_REQUEST_LAST_DATA_CALL_FAIL_CAUSE: return "LAST_DATA_CALL_FAIL_CAUSE";
860 case RIL_REQUEST_DATA_CALL_LIST: return "DATA_CALL_LIST";
861 case RIL_REQUEST_RESET_RADIO: return "RESET_RADIO";
862 case RIL_REQUEST_OEM_HOOK_RAW: return "OEM_HOOK_RAW";
863 case RIL_REQUEST_OEM_HOOK_STRINGS: return "OEM_HOOK_STRINGS";
864 case RIL_REQUEST_SET_BAND_MODE: return "SET_BAND_MODE";
865 case RIL_REQUEST_QUERY_AVAILABLE_BAND_MODE: return "QUERY_AVAILABLE_BAND_MODE";
866 case RIL_REQUEST_STK_GET_PROFILE: return "STK_GET_PROFILE";
867 case RIL_REQUEST_STK_SET_PROFILE: return "STK_SET_PROFILE";
868 case RIL_REQUEST_STK_SEND_ENVELOPE_COMMAND: return "STK_SEND_ENVELOPE_COMMAND";
869 case RIL_REQUEST_STK_SEND_TERMINAL_RESPONSE: return "STK_SEND_TERMINAL_RESPONSE";
870 case RIL_REQUEST_STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM: return "STK_HANDLE_CALL_SETUP_REQUESTED_FROM_SIM";
871 case RIL_REQUEST_SCREEN_STATE: return "SCREEN_STATE";
872 case RIL_REQUEST_EXPLICIT_CALL_TRANSFER: return "EXPLICIT_CALL_TRANSFER";
873 case RIL_REQUEST_SET_LOCATION_UPDATES: return "SET_LOCATION_UPDATES";
874 case RIL_REQUEST_CDMA_SET_SUBSCRIPTION_SOURCE:return"CDMA_SET_SUBSCRIPTION_SOURCE";
875 case RIL_REQUEST_CDMA_SET_ROAMING_PREFERENCE:return"CDMA_SET_ROAMING_PREFERENCE";
876 case RIL_REQUEST_CDMA_QUERY_ROAMING_PREFERENCE:return"CDMA_QUERY_ROAMING_PREFERENCE";
877 case RIL_REQUEST_SET_TTY_MODE:return"SET_TTY_MODE";
878 case RIL_REQUEST_QUERY_TTY_MODE:return"QUERY_TTY_MODE";
879 case RIL_REQUEST_CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_SET_PREFERRED_VOICE_PRIVACY_MODE";
880 case RIL_REQUEST_CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE:return"CDMA_QUERY_PREFERRED_VOICE_PRIVACY_MODE";
881 case RIL_REQUEST_CDMA_FLASH:return"CDMA_FLASH";
882 case RIL_REQUEST_CDMA_BURST_DTMF:return"CDMA_BURST_DTMF";
883 case RIL_REQUEST_CDMA_SEND_SMS:return"CDMA_SEND_SMS";
884 case RIL_REQUEST_CDMA_SMS_ACKNOWLEDGE:return"CDMA_SMS_ACKNOWLEDGE";
885 case RIL_REQUEST_GSM_GET_BROADCAST_SMS_CONFIG:return"GSM_GET_BROADCAST_SMS_CONFIG";
886 case RIL_REQUEST_GSM_SET_BROADCAST_SMS_CONFIG:return"GSM_SET_BROADCAST_SMS_CONFIG";
887 case RIL_REQUEST_GSM_SMS_BROADCAST_ACTIVATION:return "GSM_SMS_BROADCAST_ACTIVATION";
888 case RIL_REQUEST_CDMA_GET_BROADCAST_SMS_CONFIG:return "CDMA_GET_BROADCAST_SMS_CONFIG";
889 case RIL_REQUEST_CDMA_SET_BROADCAST_SMS_CONFIG:return "CDMA_SET_BROADCAST_SMS_CONFIG";
890 case RIL_REQUEST_CDMA_SMS_BROADCAST_ACTIVATION:return "CDMA_SMS_BROADCAST_ACTIVATION";
891 case RIL_REQUEST_CDMA_VALIDATE_AND_WRITE_AKEY: return"CDMA_VALIDATE_AND_WRITE_AKEY";
892 case RIL_REQUEST_CDMA_SUBSCRIPTION: return"CDMA_SUBSCRIPTION";
893 case RIL_REQUEST_CDMA_WRITE_SMS_TO_RUIM: return "CDMA_WRITE_SMS_TO_RUIM";
894 case RIL_REQUEST_CDMA_DELETE_SMS_ON_RUIM: return "CDMA_DELETE_SMS_ON_RUIM";
895 case RIL_REQUEST_DEVICE_IDENTITY: return "DEVICE_IDENTITY";
896 case RIL_REQUEST_EXIT_EMERGENCY_CALLBACK_MODE: return "EXIT_EMERGENCY_CALLBACK_MODE";
897 case RIL_REQUEST_GET_SMSC_ADDRESS: return "GET_SMSC_ADDRESS";
898 case RIL_REQUEST_SET_SMSC_ADDRESS: return "SET_SMSC_ADDRESS";
899 case RIL_REQUEST_REPORT_SMS_MEMORY_STATUS: return "REPORT_SMS_MEMORY_STATUS";
900 case RIL_REQUEST_REPORT_STK_SERVICE_IS_RUNNING: return "REPORT_STK_SERVICE_IS_RUNNING";
901 case RIL_REQUEST_CDMA_GET_SUBSCRIPTION_SOURCE: return "CDMA_GET_SUBSCRIPTION_SOURCE";
902 case RIL_REQUEST_ISIM_AUTHENTICATION: return "ISIM_AUTHENTICATION";
903 case RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU: return "RIL_REQUEST_ACKNOWLEDGE_INCOMING_GSM_SMS_WITH_PDU";
904 case RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS: return "RIL_REQUEST_STK_SEND_ENVELOPE_WITH_STATUS";
905 case RIL_REQUEST_VOICE_RADIO_TECH: return "VOICE_RADIO_TECH";
906 case RIL_REQUEST_GET_CELL_INFO_LIST: return"GET_CELL_INFO_LIST";
907 case RIL_REQUEST_SET_UNSOL_CELL_INFO_LIST_RATE: return"SET_UNSOL_CELL_INFO_LIST_RATE";
908 case RIL_REQUEST_SET_INITIAL_ATTACH_APN: return "RIL_REQUEST_SET_INITIAL_ATTACH_APN";
909 case RIL_REQUEST_IMS_REGISTRATION_STATE: return "IMS_REGISTRATION_STATE";
910 case RIL_REQUEST_IMS_SEND_SMS: return "IMS_SEND_SMS";
911 case RIL_REQUEST_SIM_TRANSMIT_APDU_BASIC: return "SIM_TRANSMIT_APDU_BASIC";
912 case RIL_REQUEST_SIM_OPEN_CHANNEL: return "SIM_OPEN_CHANNEL";
913 case RIL_REQUEST_SIM_CLOSE_CHANNEL: return "SIM_CLOSE_CHANNEL";
914 case RIL_REQUEST_SIM_TRANSMIT_APDU_CHANNEL: return "SIM_TRANSMIT_APDU_CHANNEL";
915 case RIL_REQUEST_GET_RADIO_CAPABILITY: return "RIL_REQUEST_GET_RADIO_CAPABILITY";
916 case RIL_REQUEST_SET_RADIO_CAPABILITY: return "RIL_REQUEST_SET_RADIO_CAPABILITY";
917 case RIL_REQUEST_SET_UICC_SUBSCRIPTION: return "SET_UICC_SUBSCRIPTION";
918 case RIL_REQUEST_ALLOW_DATA: return "ALLOW_DATA";
919 case RIL_REQUEST_GET_HARDWARE_CONFIG: return "GET_HARDWARE_CONFIG";
920 case RIL_REQUEST_SIM_AUTHENTICATION: return "SIM_AUTHENTICATION";
921 case RIL_REQUEST_GET_DC_RT_INFO: return "GET_DC_RT_INFO";
922 case RIL_REQUEST_SET_DC_RT_INFO_RATE: return "SET_DC_RT_INFO_RATE";
923 case RIL_REQUEST_SET_DATA_PROFILE: return "SET_DATA_PROFILE";
924 case RIL_UNSOL_RESPONSE_RADIO_STATE_CHANGED: return "UNSOL_RESPONSE_RADIO_STATE_CHANGED";
925 case RIL_UNSOL_RESPONSE_CALL_STATE_CHANGED: return "UNSOL_RESPONSE_CALL_STATE_CHANGED";
926 case RIL_UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED: return "UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED";
927 case RIL_UNSOL_RESPONSE_PS_NETWORK_STATE_CHANGED: return "UNSOL_RESPONSE_VOICE_NETWORK_STATE_CHANGED";
928 case RIL_UNSOL_RESPONSE_NEW_SMS: return "UNSOL_RESPONSE_NEW_SMS";
929 case RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT: return "UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT";
930 case RIL_UNSOL_RESPONSE_NEW_SMS_ON_SIM: return "UNSOL_RESPONSE_NEW_SMS_ON_SIM";
931 case RIL_UNSOL_ON_USSD: return "UNSOL_ON_USSD";
932 case RIL_UNSOL_ON_USSD_REQUEST: return "UNSOL_ON_USSD_REQUEST(obsolete)";
933 case RIL_UNSOL_NITZ_TIME_RECEIVED: return "UNSOL_NITZ_TIME_RECEIVED";
934 case RIL_UNSOL_SIGNAL_STRENGTH: return "UNSOL_SIGNAL_STRENGTH";
935 case RIL_UNSOL_STK_SESSION_END: return "UNSOL_STK_SESSION_END";
936 case RIL_UNSOL_STK_PROACTIVE_COMMAND: return "UNSOL_STK_PROACTIVE_COMMAND";
937 case RIL_UNSOL_STK_EVENT_NOTIFY: return "UNSOL_STK_EVENT_NOTIFY";
938 case RIL_UNSOL_STK_CALL_SETUP: return "UNSOL_STK_CALL_SETUP";
939 case RIL_UNSOL_SIM_SMS_STORAGE_FULL: return "UNSOL_SIM_SMS_STORAGE_FUL";
940 case RIL_UNSOL_SIM_REFRESH: return "UNSOL_SIM_REFRESH";
941 case RIL_UNSOL_DATA_CALL_LIST_CHANGED: return "UNSOL_DATA_CALL_LIST_CHANGED";
942 case RIL_UNSOL_CALL_RING: return "UNSOL_CALL_RING";
943 case RIL_UNSOL_RESPONSE_SIM_STATUS_CHANGED: return "UNSOL_RESPONSE_SIM_STATUS_CHANGED";
944 case RIL_UNSOL_RESPONSE_CDMA_NEW_SMS: return "UNSOL_NEW_CDMA_SMS";
945 case RIL_UNSOL_RESPONSE_NEW_BROADCAST_SMS: return "UNSOL_NEW_BROADCAST_SMS";
946 case RIL_UNSOL_CDMA_RUIM_SMS_STORAGE_FULL: return "UNSOL_CDMA_RUIM_SMS_STORAGE_FULL";
947 case RIL_UNSOL_RESTRICTED_STATE_CHANGED: return "UNSOL_RESTRICTED_STATE_CHANGED";
948 case RIL_UNSOL_ENTER_EMERGENCY_CALLBACK_MODE: return "UNSOL_ENTER_EMERGENCY_CALLBACK_MODE";
949 case RIL_UNSOL_CDMA_CALL_WAITING: return "UNSOL_CDMA_CALL_WAITING";
950 case RIL_UNSOL_CDMA_OTA_PROVISION_STATUS: return "UNSOL_CDMA_OTA_PROVISION_STATUS";
951 case RIL_UNSOL_CDMA_INFO_REC: return "UNSOL_CDMA_INFO_REC";
952 case RIL_UNSOL_OEM_HOOK_RAW: return "UNSOL_OEM_HOOK_RAW";
953 case RIL_UNSOL_RINGBACK_TONE: return "UNSOL_RINGBACK_TONE";
954 case RIL_UNSOL_RESEND_INCALL_MUTE: return "UNSOL_RESEND_INCALL_MUTE";
955 case RIL_UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED: return "UNSOL_CDMA_SUBSCRIPTION_SOURCE_CHANGED";
956 case RIL_UNSOL_CDMA_PRL_CHANGED: return "UNSOL_CDMA_PRL_CHANGED";
957 case RIL_UNSOL_EXIT_EMERGENCY_CALLBACK_MODE: return "UNSOL_EXIT_EMERGENCY_CALLBACK_MODE";
958 case RIL_UNSOL_RIL_CONNECTED: return "UNSOL_RIL_CONNECTED";
959 case RIL_UNSOL_VOICE_RADIO_TECH_CHANGED: return "UNSOL_VOICE_RADIO_TECH_CHANGED";
960 case RIL_UNSOL_CELL_INFO_LIST: return "UNSOL_CELL_INFO_LIST";
961 case RIL_UNSOL_RESPONSE_IMS_NETWORK_STATE_CHANGED: return "RESPONSE_IMS_NETWORK_STATE_CHANGED";
962 case RIL_UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED: return "UNSOL_UICC_SUBSCRIPTION_STATUS_CHANGED";
963 case RIL_UNSOL_SRVCC_STATE_NOTIFY: return "UNSOL_SRVCC_STATE_NOTIFY";
964 case RIL_UNSOL_HARDWARE_CONFIG_CHANGED: return "HARDWARE_CONFIG_CHANGED";
965 case RIL_UNSOL_DC_RT_INFO_CHANGED: return "UNSOL_DC_RT_INFO_CHANGED";
966 case RIL_REQUEST_SHUTDOWN: return "SHUTDOWN";
967 case RIL_UNSOL_RADIO_CAPABILITY: return "RIL_UNSOL_RADIO_CAPABILITY";
968 case RIL_REQUEST_SET_TRM: return "RIL_REQUEST_SET_TRM";
969 case RIL_REQUEST_SET_IMS_ENABLE:return "RIL_REQUEST_SET_IMS_ENABLE";
970 case RIL_REQUEST_SET_AUDIO_PATH: return "SET_AUDIO_PATH";
971 case RIL_REQUEST_HANGUP_ALL: return "HANGUP_ALL";
972 case RIL_REQUEST_FORCE_RELEASE_CALL: return "FORCE_RELEASE_CALL";
973 case RIL_REQUEST_EMERGENCY_DIAL: return "RIL_REQUEST_EMERGENCY_DIAL";
974 case RIL_REQUEST_SET_ECC_SERVICE_CATEGORY: return "RIL_REQUEST_SET_ECC_SERVICE_CATEGORY";
975 case RIL_REQUEST_SET_ECC_LIST: return "RIL_REQUEST_SET_ECC_LIST";
976 case RIL_REQUEST_AT_COMMAND_WITH_PROXY: return "AT_COMMAND_WITH_PROXY";
977 case RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION: return "RIL_REQUEST_SET_SUPP_SVC_NOTIFICATION";
978 case RIL_REQUEST_SET_CLIP: return "RIL_REQUEST_SET_CLIP";
979 case RIL_REQUEST_GET_COLP: return "RIL_REQUEST_GET_COLP";
980 case RIL_REQUEST_SET_COLP: return "RIL_REQUEST_SET_COLP";
981 case RIL_REQUEST_GET_COLR: return "RIL_REQUEST_GET_COLR";
982 case RIL_REQUEST_ADD_IMS_CONFERENCE_CALL_MEMBER: return "ADD_IMS_CONFERENCE_CALL_MEMBER";
983 case RIL_REQUEST_REMOVE_IMS_CONFERENCE_CALL_MEMBER: return "REMOVE_IMS_CONFERENCE_CALL_MEMBER";
984 case RIL_REQUEST_CONFERENCE_DIAL: return "CONFERENCE_DIAL";
985 case RIL_REQUEST_DIAL_WITH_SIP_URI: return "DIAL_WITH_SIP_URI";
986 case RIL_REQUEST_HOLD_CALL: return "HOLD_CALL";
987 case RIL_REQUEST_RESUME_CALL: return "RESUME_CALL";
988 case RIL_UNSOL_ECONF_SRVCC_INDICATION : return "ECONF_SRVCC_INDICATION";
989 case RIL_UNSOL_ECONF_RESULT_INDICATION : return "ECONF_RESULT_INDICATION";
990 case RIL_UNSOL_MAL_AT_INFO : return "UNSOL_MAL_AT_INFO";
991 case RIL_REQUEST_MODEM_POWEROFF: return "MODEM_POWEROFF";
992 case RIL_REQUEST_MODEM_POWERON: return "MODEM_POWERON";
993 case RIL_REQUEST_WRITE_SMS_TO_SIM: return "WRITE_SMS_TO_SIM";
994 case RIL_REQUEST_QUERY_ICCID: return "RIL_REQUEST_QUERY_ICCID";
995 case RIL_UNSOL_TX_POWER: return "RIL_UNSOL_TX_POWER";
996 case RIL_UNSOL_NETWORK_INFO: return "RIL_UNSOL_NETWORK_INFO";
997 case RIL_REQUEST_DELETE_SMS_ON_SIM: return "DELETE_SMS_ON_SIM";
998 case RIL_REQUEST_SET_IMSCFG: return "RIL_REQUEST_SET_IMSCFG";
999#ifdef ECALL_SUPPORT
1000 case RIL_REQUEST_ECALL_FAST_MAKE_ECALL: return "ECALL_FAST_MAKE_ECALL";
1001 case RIL_REQUEST_ECALL_SET_IVS: return "RIL_REQUEST_ECALL_SET_IVS";
1002 case RIL_REQUEST_ECALL_SET_PSAP: return "RIL_REQUEST_ECALL_SET_PSAP";
1003 case RIL_REQUEST_ECALL_MAKE_ECALL: return "RIL_REQUEST_ECALL_MAKE_ECALL";
1004 case RIL_REQUEST_ECALL_IVS_PUSH_MSD: return "RIL_REQUEST_ECALL_IVS_PUSH_MSD";
1005 case RIL_REQUEST_ECALL_PSAP_PULL_MSD: return "RIL_REQUEST_ECALL_PSAP_PULL_MSD";
1006 case RIL_UNSOL_ECALL_MSDHACK : return "ECALL_MSDHACK";
1007 case RIL_REQUEST_ECALL_SET_MSD: return "RIL_REQUEST_ECALL_SET_MSD";
1008 case RIL_REQUEST_ECALL_CTRL_SEQUENCE: return "ECALL_SET_CTRL_SEQUENCE";
1009 case RIL_UNSOL_ECALL_INDICATIONS : return "ECALL_INDICATIONS";
1010 case RIL_REQUEST_ECALL_RESET_IVS: return "RIL_REQUEST_ECALL_RESET_IVS";
1011 case RIL_REQUEST_ECALL_SET_PRI: return "RIL_REQUEST_ECALL_SET_PRI";
1012 case RIL_REQUEST_ECALL_SET_TEST_NUM: return "RIL_REQUEST_ECALL_SET_TEST_NUM";
1013 case RIL_REQUEST_ECALL_SET_RECONF_NUM: return "RIL_REQUEST_ECALL_SET_RECONF_NUM";
1014 case RIL_REQUEST_SYNC_DATA_SETTINGS_TO_MD: return "RIL_REQUEST_SYNC_DATA_SETTINGS_TO_MD";
1015 case RIL_REQUEST_ECALL_SET_NAD_DEREGISTRATION_TIME: return "RIL_REQUEST_ECALL_SET_NAD_DEREGISTRATION_TIME";
1016 case RIL_REQUEST_ECALL_SET_REGISTRATION_STATE: return "RIL_REQUEST_ECALL_SET_REGISTRATION_STATE";
1017#endif /*ECALL_SUPPORT*/
1018#ifdef KEEP_ALIVE
1019 case RIL_REQUEST_START_KEEPALIVE_PRO: return "RIL_REQUEST_START_KEEPALIVE_PRO";
1020 case RIL_REQUEST_STOP_KEEPALIVE_PRO: return "RIL_REQUEST_STOP_KEEPALIVE_PRO";
1021 case RIL_UNSOL_KEEPALIVE_STATUS_PRO: return "RIL_UNSOL_KEEPALIVE_STATUS_PRO";
1022#endif /*KEEP_ALIVE*/
1023 case RIL_REQUEST_SEND_USSI: return "SEND_USSI";
1024 case RIL_REQUEST_CANCEL_USSI: return "CANCEL_USSI";
1025 case RIL_REQUEST_GET_SMS_SIM_MEM_STATUS: return "GET_SMS_SIM_MEM_STATUS";
1026 case RIL_UNSOL_SIP_CALL_PROGRESS_INDICATOR: return "RIL_UNSOL_SIP_CALL_PROGRESS_INDICATOR";
1027 case RIL_REQUEST_REPORT_AIRPLANE_MODE: return "RIL_REQUEST_REPORT_AIRPLANE_MODE";
1028 case RIL_REQUEST_SET_ECC_NUM: return "RIL_REQUEST_SET_ECC_NUM";
1029 case RIL_REQUEST_GET_ECC_NUM: return "RIL_REQUEST_GET_ECC_NUM";
1030 case RIL_UNSOL_ECC_NUM: return "RIL_UNSOL_ECC_NUM";
1031 case RIL_REQUEST_QUERY_AVAILABLE_NETWORKS_WITH_ACT: return "RIL_REQUEST_QUERY_AVAILABLE_NETWORKS_WITH_ACT";
1032 case RIL_REQUEST_GSM_GET_BROADCAST_LANGUAGE: return "RIL_REQUEST_GSM_GET_BROADCAST_LANGUAGE";
1033 case RIL_REQUEST_GSM_SET_BROADCAST_LANGUAGE: return "RIL_REQUEST_GSM_SET_BROADCAST_LANGUAGE";
1034 case RIL_UNSOL_CALL_INFO_INDICATION: return "RIL_UNSOL_CALL_INFO_INDICATION";
1035 case RIL_REQUEST_MODIFY_APN: return "RIL_REQUEST_MODIFY_APN";
1036 case RIL_REQUEST_RESET_APN: return "RIL_REQUEST_RESET_APN";
1037 case RIL_REQUEST_QUERY_SIM_RETRY_COUNT: return "RIL_REQUEST_QUERY_SIM_RETRY_COUNT";
1038 case RIL_REQUEST_QUERY_EID: return "RIL_REQUEST_QUERY_EID";
1039 case LYNQ_REQUEST_SET_DTMF_VOLUME: return "RIL_REQUEST_SET_DTMF_VOLUME";
1040 case LYNQ_REQUEST_SET_SPEECH_VOLUME: return "RIL_REQUEST_SET_SPEECH_VOLUME";
1041 case LYNQ_REQUEST_GET_SPEECH_VOLUME: return "RIL_REQUEST_GET_SPEECH_VOLUME";
1042 case LYNQ_REQUEST_RECORD: return "RIL_REQUEST_RECORD";
1043 /*warren add for t800 ril service 2022/1/22 start*/
1044 case LYNQ_REQUEST_WRITE_SMS_TO_MEMORY: return "LYNQ_REQUEST_WRITE_SMS_TO_MEMORY";
1045 case LYNQ_REQUEST_READ_SMS_FROM_MEMORY: return "LYNQ_REQUEST_READ_SMS_FROM_MEMORY";
1046 case LYNQ_REQUEST_DELETE_SMS_FROM_MEMORY: return "LYNQ_REQUEST_DELETE_SMS_FROM_MEMORY";
1047 case LYNQ_REQUEST_LIST_SMS_FROM_MEMORY: return "LYNQ_REQUEST_LIST_SMS_FROM_MEMORY";
1048 case LYNQ_REQUEST_SET_DEFAULT_SIM_ALL:return "SET_DEFAULT_SIM_ALL";
1049 case LYNQ_REQUEST_CHANGE_SCREEN_STATE:return "LYNQ_REQUEST_CHANGE_SCREEN_STATE";/*jb.qi add for two sim sleep 2022/9/19*/
1050 case LYNQ_REQUEST_CHANGE_RADIO:return "LYNQ_REQUEST_CHANGE_RADIO";/*lei add for factory test of sleep 2022/9/19*/
1051 /*warren add for t800 ril service 2022/1/22 end*/
1052 default: return "<unknown request>";
1053 }
1054}
1055
1056