MC8332GpsTask.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519
  1. /********************************************************************************
  2. * File Name: MC8332GpsTask.h
  3. * Function Describe: Header file for MC8332GpsTask.c
  4. * Explain:
  5. * Writer:
  6. * Date: 2016-3-11
  7. *******************************************************************************/
  8. #include "includes.h"
  9. unsigned int Mododrex_Net;
  10. unsigned int netshowvalue;
  11. //FOTA_UPDATE fota_update;
  12. void MC8332_GPS_RecvHandle(unsigned char *pMsg,unsigned short tempLen)
  13. {
  14. char buf[20];
  15. char buf2[50];
  16. char result[10];
  17. unsigned short cmd,ackCmd,smsLen;
  18. unsigned char Result,i,buBiaoResponsed;
  19. short targetIndex;
  20. SUTDS ds;
  21. ////////////////////////////////////////////
  22. // char buftest[100];
  23. // char buf22[3];
  24. // for(i=0;i<25;i++)
  25. // {
  26. // sprintf(buf22, "%02x", pMsg[i]);
  27. // strcat(buftest, buf22);
  28. // }
  29. // strcat(buftest, "\r\n");
  30. // SlwTrace(INF, buftest);
  31. ////////////////////////////////////////////
  32. //////////处理布标类型指令
  33. cmd = (pMsg[1]<<8) | (pMsg[2]&0xff);
  34. buBiaoResponsed=1;
  35. snprintf(buf2, sizeof(buf2), "\r\ncmd=%04x", cmd);
  36. SlwTrace(INF, buf2,1);
  37. switch(cmd)
  38. {//布标命令返回
  39. case TS_TERMINAL_REGISTRATION_REPLY://终端注册应答
  40. //7E 8100 000A 000166000016 0250 0100 00 20161118165030 E07E 成功
  41. //7E 8100 0003 000166000016 0251 0100 01 A07E 已注册
  42. Result = pMsg[15];
  43. snprintf(buf2, sizeof(buf2), "\r\nresult=%02x", Result);
  44. SlwTrace(INF, buf2,1);
  45. switch(Result)
  46. {
  47. case 0://00注册成功
  48. if(0 != memcmp(newPara.authPara.authCode, pMsg+16, 7)){
  49. memcpy(newPara.authPara.authCode, pMsg+16,7);
  50. //save sys
  51. ModifyConfigureFile(0);
  52. }
  53. snprintf(result, sizeof(result), "Ok");
  54. break;
  55. case 1://01 车辆已注册
  56. snprintf(result, sizeof(result), "Car Exist");break;
  57. case 2://02 无此车辆
  58. snprintf(result, sizeof(Result), "No car");break;
  59. case 3://03 终端已经被注册
  60. snprintf(result, sizeof(result), "Device Exist");break;
  61. case 4://04 数据库无此终端
  62. snprintf(result, sizeof(result), "No Record");break;
  63. default://无效值
  64. //统称失败
  65. snprintf(result, sizeof(result), "Faile");
  66. break;
  67. }
  68. snprintf(buf2, sizeof(buf2), "\r\n[Register]%d %s", Result,result);
  69. SlwTrace(INF, buf2,1);
  70. //注册应答后直接进行一次鉴权
  71. Authentication();
  72. break;
  73. case TS_TEXT_INFORMATION_ISSUED://文本下发
  74. //7E83000005000166000009000001 31323334ED7E
  75. smsLen = pMsg[3];
  76. smsLen <<= 8;
  77. smsLen &= 0xff00;
  78. smsLen |= pMsg[4];
  79. smsLen -= 1;//去掉后面较验码
  80. if(SMS_SIGNAL_LEN <= smsLen)
  81. smsLen = SMS_SIGNAL_LEN;
  82. memset(sutMess.GBKMess1, 0, sizeof(sutMess.GBKMess1));
  83. memcpy(sutMess.GBKMess1, pMsg+14, smsLen);
  84. sutMess.len = smsLen;
  85. //////////////////////////
  86. sutFeed.feedID=TS_SETTING_TERMINAL_PARAMETERS;
  87. ds.Data.ucData.b1=pMsg[11];
  88. ds.Data.ucData.b2=pMsg[12];
  89. sutFeed.feedliushuiID=ds.Data.usData;
  90. sutFeed.result=2;
  91. //////////////////////////
  92. if(sutMess.len > 0)
  93. SetGotNewMessage();
  94. break;
  95. case TS_PLATFORM_UNIVERSAL_ANSWER://通用平台应答
  96. //7E8001000500016600001602400000010201B57E
  97. //buf[0]=0x7e;
  98. //if(-1 != (targetIndex=FindTargetIndex((char *)pMsg, '\r', buf, 1,2)))
  99. targetIndex = tempLen;//这个长度是去掉了两个7E的长度
  100. {
  101. ackCmd=(pMsg[targetIndex-3]<<8) | (pMsg[targetIndex-2]&0xff);
  102. Result = pMsg[targetIndex-1];
  103. snprintf(buf2, sizeof(buf2), "\r\nLen=%d,ackCmd=%04x,result=%02x", tempLen,ackCmd,Result);
  104. SlwTrace(INF, buf2,1);
  105. switch(ackCmd)
  106. {
  107. case TS_TERMINAL_AUTHENTICATION://终端鉴权应答
  108. if(Result == 0)
  109. {//鉴权成功
  110. sutGpsInfo.isGpsAuthOk=1;
  111. snprintf(buf2, sizeof(buf2), "\r\n[ATH]Ok");
  112. enableDataSend();
  113. //TSGpsServerConect();//鉴权成功后发一包终端应答包即可以支持文本接收了
  114. }else
  115. {
  116. sutGpsInfo.isGpsAuthOk=0;
  117. snprintf(buf2, sizeof(buf2), "\r\n[ATH]Faile");
  118. }
  119. SlwTrace(INF, buf2,1);
  120. break;
  121. case TS_LOCATION_INFORMATION_REPORTING://位置包应答
  122. SlwTrace(INF, "\r\nLocation ACK",1);
  123. break;
  124. case TS_TERMINAL_HEARTBEAT://心跳应答
  125. SlwTrace(INF, "\r\nHearTick ACK",1);
  126. break;
  127. case TS_SEND_SOS_SMS://SOS应答
  128. SlwTrace(INF, "\r\nSOS ACK",1);
  129. sutPocStatus.SOS_Flag++;
  130. break;
  131. }
  132. }
  133. break;
  134. case TS_TERMINAL_REQTIME://时间ACK
  135. //7e0f020007001899000022003a e20704130e2f02 427e
  136. SlwTrace(INF, "\r\nTimeAck",1);
  137. ds.Data.ucData.b1=pMsg[13];
  138. ds.Data.ucData.b2=pMsg[14];
  139. g_usModeYTime=ds.Data.usData-2000;
  140. g_usModemTime=pMsg[15];
  141. g_usModeDTime=pMsg[16];
  142. g_usModeHTime=pMsg[17];
  143. g_usModeMTime=pMsg[18];
  144. g_usModeSTime=pMsg[19];
  145. SetTime(g_usModeHTime, g_usModeMTime, g_usModeSTime);//保存下来,以便下次启动,没登陆前可以使用本地时间显示
  146. break;
  147. default:
  148. buBiaoResponsed=0;
  149. break;
  150. }
  151. if(buBiaoResponsed)
  152. g_ucModemSentTcpCt=0;
  153. /////////////处理其它类型指令
  154. }
  155. void AtHandle(char *pMsg)
  156. {
  157. int csq;
  158. short targetIndex;
  159. unsigned char tempSocket,i,temp;
  160. unsigned short tempLen;
  161. char buf[80]="\r\n";
  162. char bufTemp[3];
  163. char buf3[40];//////////////////////////
  164. STATUE ipStatus;
  165. // if(0==ModemStrCmp(pMsg,"+POC:UPDATE"))
  166. //{
  167. // fota_update.NewPocFlag=1;
  168. //}else if(0==ModemStrCmp(pMsg,"+POC:DONE"))
  169. //{
  170. // fota_update.NewPocOver=1;
  171. //}
  172. if(0==ModemStrCmp(pMsg,"^SYSINFO:"))
  173. {
  174. if(pMsg[15]!=','){
  175. netshowvalue=atoi(&pMsg[15]);
  176. }else{
  177. netshowvalue=atoi(&pMsg[16]);
  178. }
  179. }
  180. if(0==ModemStrCmp(pMsg,"+CCSQ:"))
  181. {
  182. UpdateCsqValue(GetCCSQ(pMsg));
  183. }else if(0==ModemStrCmp(pMsg,"+CSQ:"))
  184. {
  185. UpdateCsqValue(GetCSQ(pMsg));
  186. }else if(0==ModemStrCmp(pMsg,"+MODODREX:")){
  187. Mododrex_Net=atoi(&pMsg[11]);
  188. snprintf(buf3,sizeof(buf3),"Mododrex_Netvalue=%d\r\n",Mododrex_Net);
  189. SlwTrace(INF, buf3,1);
  190. }else if(0==ModemStrCmp(pMsg,"+POC_PPP:")){
  191. sutGpsStatus.PPPStatus=GetPPPStatus(pMsg);
  192. if(sutGpsStatus.PPPStatus == CLOSE){
  193. sutGpsStatus.IPStatus=0;
  194. ColonyParaReset();
  195. }
  196. }else if(0==ModemStrCmp(pMsg,"+TCPSTATUS:"))
  197. {//查询指令返回状态
  198. IPStatusAna((char *)pMsg, &tempSocket,&ipStatus);
  199. switch(tempSocket)
  200. {
  201. case GPS_DATA_SOCKET:
  202. sutGpsStatus.IPStatus = ipStatus;
  203. if(sutGpsStatus.IPStatus == CLOSE) sutGpsInfo.isGpsAuthOk=0;//鉴权清掉,再次连接后要重新鉴权
  204. break;
  205. case COLONY_SER_SOCKET:
  206. ColonyTcpStatus(ipStatus);
  207. break;
  208. }
  209. }else if(0==ModemStrCmp(pMsg,"+TCPRECV:")){//+TCPRECV:0,2,31
  210. if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ":", 1,1)))
  211. {
  212. tempSocket = atoi(&pMsg[targetIndex]);//找到socket
  213. if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ",",1,1)))
  214. {
  215. tempLen = atoi(&pMsg[targetIndex]);
  216. if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ",",1,2)))
  217. {
  218. switch(tempSocket)
  219. {
  220. case GPS_DATA_SOCKET:
  221. //走布标判断
  222. if(pMsg[targetIndex] == 0x7e && pMsg[targetIndex+tempLen-1] == 0x7e)
  223. {//是布标协议,进行转义
  224. tempLen=reduce((unsigned char *)&pMsg[targetIndex+1], tempLen-1);
  225. MC8332_GPS_RecvHandle((unsigned char *)&pMsg[targetIndex],tempLen);
  226. }else
  227. {
  228. SlwTrace(INF, "Unknown Protocol",1);
  229. }
  230. break;
  231. case COLONY_SER_SOCKET:
  232. SlwTrace(INF,"colony coming..........",1);
  233. Colony_RecvHandle(&pMsg[targetIndex],tempLen);
  234. break;
  235. }
  236. }
  237. }
  238. }
  239. }else if(0==ModemStrCmp(pMsg,"+TCPOPEN:"))//连接指令返回状态
  240. { //+TCPOPEN:OK
  241. //+TCPOPEN:Already connected
  242. #if 0 //这条指令不具备socket号回来,不处理,直接通过查询方式来检测连接结果
  243. if((pMsg[9] == 'O' && pMsg[10] == 'K') ||
  244. (pMsg[9] == 'A' && pMsg[14] == 'd' && pMsg[23] =='t'))
  245. {
  246. if(tcpControl == 0)
  247. {
  248. HgsConnetStatus=1;
  249. HigosSendFlag=0;
  250. }else if(tcpControl== 1)
  251. {
  252. sutGpsStatus.IPStatus = OPEN;
  253. }else if(tcpControl == 2)
  254. {
  255. #if(USE_CONFIG_FUN==1)
  256. sutConfig.g_ubConfigTcpStatus=1;
  257. #endif
  258. }
  259. }
  260. #endif
  261. }else if(0==ModemStrCmp(pMsg, "+TCPCLOSE:OK"))
  262. {
  263. }else if(0==ModemStrCmp(pMsg, "+TCPCLOSE:"))
  264. {//主动关掉或者服务器关掉都是这样
  265. tempSocket=pMsg[10]-0x30;
  266. switch(tempSocket)
  267. {
  268. case GPS_DATA_SOCKET:
  269. sutGpsStatus.IPStatus=CLOSE;
  270. break;
  271. case COLONY_SER_SOCKET:
  272. ColonyParaReset();
  273. break;
  274. }
  275. }else if(0==ModemStrCmp(pMsg, "+CCLK:"))
  276. {//+CCLK: "17/09/28,04:48:35"
  277. //+CCLK: "80/01/06,00:10:44"
  278. //+CCLK: "17/10/19,07:22:35"
  279. g_usModeYTime=atoi(&pMsg[8]);
  280. g_usModemTime=atoi(&pMsg[11]);
  281. g_usModeDTime=atoi(&pMsg[14]);
  282. g_usModeHTime=atoi(&pMsg[17])+8;
  283. if(g_usModeHTime >= 24) g_usModeHTime -= 24;
  284. g_usModeMTime=atoi(&pMsg[20]);
  285. g_usModeSTime=atoi(&pMsg[23]);
  286. SetTime(g_usModeHTime, g_usModeMTime, g_usModeSTime);//保存下来,以便下次启动,没登陆前可以使用本地时间显示
  287. SlwTrace(INF, "UpdateTime",1);
  288. }else if(0==ModemStrCmp(pMsg, "^MODE:"))
  289. {//^MODE: 9 与下面位置不一,模块问题
  290. //^MODE:2 与上面位置不一,模块问题
  291. if(pMsg[6] == ' ') bufTemp[0]=pMsg[7];
  292. else bufTemp[0]=pMsg[6];
  293. snprintf(buf, sizeof(buf), "[Mode %c]", bufTemp[0]);
  294. switch(bufTemp[0])
  295. {
  296. case 0x30:strcat(buf, "No server");break;
  297. case 0x32:strcat(buf, "CDMA Mode");break;
  298. case 0x33:strcat(buf, "GSM");break;
  299. case 0x34:strcat(buf, "TD-SCDMA/EVDO");break;
  300. case 0x35:strcat(buf, "WCDMA");break;
  301. case 0x39:strcat(buf, "LTE");break;
  302. default:strcat(buf, "Unknow");break;
  303. }
  304. SlwTrace(INF, buf, 1);
  305. }else if(0==ModemStrCmp(pMsg, "^MSG:"))
  306. {
  307. if(0==ModemStrCmp(&pMsg[5], "Ready"))
  308. {//升级应用程序已开启
  309. UpdateStatus(MODEM_STATUS_READY);
  310. }else if(0==ModemStrCmp(&pMsg[5], "http:err"))
  311. {//指令执行失败
  312. UpdateStatus(MODEM_STATUS_CMD_VER_ERR);
  313. }else if(0==ModemStrCmp(&pMsg[5], "VerErr"))
  314. {//请求版本号有非数字数据
  315. UpdateStatus(MODEM_STATUS_CMD_VER_ERR);
  316. }else if(0==ModemStrCmp(&pMsg[5], "ver:err"))
  317. {//检查版本错误
  318. UpdateStatus(MODEM_STATUS_CMD_VER_ERR);
  319. }else if(0==ModemStrCmp(&pMsg[5], "nonewver"))
  320. {//没有更新版本
  321. UpdateStatus(MODEM_STATUS_NO_NEWVER);
  322. }else if(0==ModemStrCmp(&pMsg[5], "loading"))
  323. {//开始下载
  324. m_process=0;
  325. UpdateStatus(MODEM_STATUS_LOADING);
  326. }else if(0==ModemStrCmp(&pMsg[5], "HBD:"))
  327. {//正在下在百分比
  328. m_process=atoi(pMsg+9);
  329. UpdateStatus(MODEM_STATUS_LOADING);
  330. }else if(0==ModemStrCmp(&pMsg[5], "Done"))
  331. {//下载完成
  332. UpdateStatus(MODEM_STATUS_DONE);
  333. }else if(0==ModemStrCmp(&pMsg[5], "Installed"))
  334. {//升级完成
  335. UpdateStatus(MODEM_STATUS_INSTALLED);
  336. }else if(0==ModemStrCmp(&pMsg[5], "wget:"))
  337. {
  338. UpdateStatus(MODEM_STATUS_SER_ERR);
  339. }
  340. }else if(0==ModemStrCmp(pMsg, "+POC:START"))
  341. {
  342. sutPocStatus.modemRstFlag=1;
  343. sutPocStatus.ModemInactiveCt=0;//当模块重启后重新计数串口通讯异常计数器
  344. }
  345. else if(0==ModemStrCmp(pMsg, "+GGIP:"))
  346. { //GSPIP返回
  347. GetDomainIp(&pMsg[6],'g');
  348. }else if(0==ModemStrCmp(pMsg, "+GPIP:"))
  349. {
  350. GetDomainIp(&pMsg[6],'p');
  351. }else if(0==ModemStrCmp(pMsg, "+FOTA:")){
  352. FotaStatusProcess(pMsg+6);
  353. }else if(0==ModemStrCmp(pMsg, "+POC:WAKEUP")){
  354. enableDataSend();
  355. }else if(0==ModemStrCmp(pMsg, "+UDP:")){
  356. GetPwrMode(pMsg+5);
  357. }
  358. }
  359. static char csqSendFlag=1;
  360. void UpdateCsqValue(int csq)
  361. {
  362. static int tCsq[2];
  363. char validCsq=0,validcsq=0;
  364. if(csq == 99 ||
  365. (csq >=0 && csq <=31))
  366. {
  367. tCsq[csqSendFlag]=csq;
  368. }
  369. if(csqSendFlag==1)
  370. {//收到了两组CSQ命令值,对比,如果都有效值,取大的值
  371. if(tCsq[0] >=0 && tCsq[0] <=31) validCsq=1;
  372. else if(tCsq[1] >=0 && tCsq[1] <=31) validcsq=1;
  373. else g_iCSQ=99;
  374. if(validCsq&&validcsq)
  375. {
  376. if(tCsq[0]>tCsq[1]) g_iCSQ=tCsq[0];
  377. else g_iCSQ=99;
  378. }else if(validCsq) g_iCSQ=tCsq[0];
  379. else if(validcsq) g_iCSQ=tCsq[1];
  380. tCsq[0]=99;
  381. tCsq[1]=99;
  382. }
  383. }
  384. void CloseGPSSocket(void)
  385. {
  386. char buf[20];
  387. snprintf(buf, sizeof(buf), "AT+TCPCLOSE=%d\r\n",GPS_DATA_SOCKET);
  388. ModemSendAT(buf);
  389. sutGpsStatus.IPStatus=CLOSE;
  390. }
  391. /************************************************
  392. 每10ms处理一次
  393. **************************************************/
  394. void GpsTaskTick(unsigned char reset)
  395. {
  396. static unsigned int sucSecCt=0;
  397. static unsigned char sucSteep=0;
  398. static unsigned char sucSynSentCt=0;
  399. unsigned char temp[4];
  400. char buf[55];
  401. int i;
  402. if(reset){
  403. sucSecCt=0;
  404. sucSteep=0;
  405. return;
  406. }
  407. //GPS Uart消息处理
  408. if(g_usUart3RecvLen)
  409. {
  410. process_nema((char *)RxBuffer3);
  411. g_usUart3RecvLen=0;
  412. }
  413. //===========以下控制每秒执行一次============
  414. if(os_time_get() < sucSecCt) return;
  415. sucSecCt=os_time_get()+100;
  416. //////////////////20170112////////////////////
  417. GpsCtrlSendPos();//里面涉及到鉴权,所以得跑起来
  418. //TCP发送防护,如果IPSTATUS一直等于SYN_SENT持续达10秒,则关闭TCP链路
  419. if(sutGpsStatus.IPStatus==SYN_SENT)
  420. {
  421. if(++sucSynSentCt>10){
  422. sucSynSentCt=0;
  423. g_ucModemSentTcpCt=0;
  424. CloseGPSSocket();
  425. g_ucModemSentTcpCt=0;
  426. sutGpsInfo.isServerLogin=0;
  427. }
  428. }else sucSynSentCt=0;
  429. //---以下控制---
  430. if(++sucSteep>4)sucSteep=0;
  431. //----
  432. if(sucSteep==0)
  433. {
  434. if(csqSendFlag==1)
  435. {//模块在电信卡的cdma和evdo下使用CCSQ
  436. //其它所有情况使用CSQ
  437. csqSendFlag=0;
  438. ModemSendAT("AT+CSQ\r\n");
  439. }else{
  440. csqSendFlag=1;
  441. ModemSendAT("AT+CCSQ\r\n");
  442. }
  443. snprintf(buf, sizeof(buf), "[ATH]%d,[GPS]%d,[BAT]%0.2f,[TICK]%d,%d,[CSQ]%d",
  444. sutGpsInfo.isGpsAuthOk,
  445. sutGpsInfo.isGpsValid,
  446. (double)g_iVbat/100,
  447. os_time_get(),
  448. sutGpsInfo.GPS_SecondCnt,
  449. g_iCSQ);
  450. SlwTrace(INF,buf,1);
  451. }
  452. else if(1==sucSteep)
  453. {
  454. ModemSendAT("AT+POC_PPP\r\n");
  455. }else if(2==sucSteep)
  456. {
  457. if(99==g_iCSQ)return;
  458. if(sutGpsStatus.PPPStatus==OPEN){
  459. snprintf(buf, sizeof(buf), "AT+TCPSTATUS=%d\r\n", GPS_DATA_SOCKET);
  460. ModemSendAT(buf);
  461. }else{
  462. SlwTrace(INF, "Wait POC_PPP",1);
  463. }
  464. }else if(3==sucSteep)
  465. {
  466. if(99==g_iCSQ) return;
  467. if(sutGpsInfo.isGpsWork==0)
  468. {
  469. if(sutGpsStatus.CheckCnt < 50)
  470. {
  471. if(++sutGpsStatus.CheckCnt >= 2)
  472. {
  473. sutGpsStatus.CheckCnt = NO_GPS_CHECK_TIMEOUT;//设置为此值时认为是没有GPS机型
  474. }
  475. }
  476. SlwTrace(INF,"GPS modem not work!",1);
  477. }
  478. if(sutGpsStatus.IPStatus!=OPEN && sutGpsStatus.PPPStatus==OPEN)
  479. {
  480. // if(tcpControl == 1)
  481. // {//当控制为GPS时才去连接
  482. sutGpsInfo.isServerLogin=0;
  483. snprintf(buf, sizeof(buf),"AT+TCPOPEN=%d,%s:%d\r\n",GPS_DATA_SOCKET,showGIP,newPara.gpsPort);
  484. SlwTrace(INF,buf,0);
  485. ModemSendAT(buf);
  486. //}
  487. }
  488. }else if(4==sucSteep)
  489. {
  490. if(99==g_iCSQ)return;
  491. if(sutGpsStatus.IPStatus==OPEN && 0==sutGpsInfo.isServerLogin)
  492. {
  493. sutGpsInfo.isServerLogin = OPEN;
  494. }
  495. }
  496. }