MC8332GpsTask.c 14 KB

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