mainTask.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874
  1. #include "includes.h"
  2. unsigned char pocTimeOutTime=30;//默认30分钟
  3. unsigned char g_ucEnterGroupFlag=0;
  4. unsigned char g_ucTMMode=0;
  5. unsigned char modemPwrOffNow=0;
  6. unsigned char m_GroupSwitch=0;//表示是否曾经按过左边上下群组切换按键
  7. unsigned char m_GroupSwitchCnt=0;//按过的话,5秒内没按OK键则退出切换
  8. unsigned char g_usOptionCnt;
  9. unsigned char m_VoiceSwitch=0;//激活音量显示
  10. unsigned char m_VoiceSwitchCnt=0;//计时
  11. unsigned char m_VoiceStep;//步骤
  12. unsigned char g_uslockCnt;
  13. unsigned char g_uslockflag;
  14. unsigned char Ui_LockFlag; //用于 被锁界面可操作PTT
  15. unsigned char m_keyreturncnt;
  16. void KeyPress(void){
  17. char buf[30];
  18. if(sutUIstatus.Status==UIS_STANDBY && g_uslockflag==1)
  19. {
  20. if((g_ulKeyValue==KEY_INFO)||(g_ulKeyValue==KEY_PANEL_MENU)||(g_ulKeyValue==KEY_PANEL_UP)||(g_ulKeyValue==KEY_PANEL_DOWN)||(g_ulKeyValue==KEY_FUNC))
  21. {
  22. //Ui_LockFlag=1;
  23. return;
  24. }
  25. }
  26. switch(g_ulKeyValue){
  27. case KEY_PPT_MIC:
  28. case KEY_PPT:
  29. g_ucKeyMode=1;
  30. //sutPocStatus.PPTpress=1;
  31. if(g_ucTMMode==0){
  32. if(hgs_poc_type==POC_BND)ModemSendAt("AT+POC=ptt,1\r\n");
  33. else {
  34. //if(modemInitStatus==1)HeadsetProcess();
  35. //if(uTimerExpired(&HeadsetQudou))
  36. ModemSendAt("AT+POC=0B0000\r\n");
  37. }
  38. }
  39. SlwTrace(INF,"[KEY_PPT/KEY_PPT_MIC Press]",1);
  40. break;
  41. case KEY_INFO:
  42. g_ucKeyMode=0;
  43. SlwTrace(INF,"[KEY_UP Press]",1);
  44. break;
  45. case KEY_FUNC:
  46. g_ucKeyMode=0;
  47. SlwTrace(INF,"[KEY_DOWN Press]",1);
  48. break;
  49. case KEY_PANEL_OK:
  50. SlwTrace(INF,"[KEY_OK Press]",1);
  51. if(sutUIstatus.Status == UIS_STANDBY && m_GroupSwitch==0)
  52. UISetNextStatus(UIS_MENU_GROUP_SEL);
  53. break;
  54. case KEY_PANEL_MENU:
  55. SlwTrace(INF,"[KEY_PANEL_MENU Press]",1);
  56. if(m_GroupSwitch){//
  57. m_GroupSwitch=0;
  58. snprintf(buf, sizeof(buf),"AT+POC=090000%s\r\n",sutPocStatus.switchGroupID);
  59. ModemSendAt(buf);
  60. ShowButton(1,107,"菜单");
  61. SlwTrace(INF, buf,0);
  62. }
  63. break;
  64. case KEY_PANEL_EXIT:
  65. SlwTrace(INF,"[KEY_PANEL_EXIT Press]",1);
  66. if(++g_uslockCnt==2){
  67. if(g_uslockflag){
  68. g_uslockflag=0;
  69. }else g_uslockflag=1;
  70. if(g_uslockflag==1){
  71. GuiShowBmp(72,110,"lock.bmp");
  72. }else{
  73. printf("clear lock---\r\n");
  74. GuiClearRect(72,110,72+17,110+17);
  75. }
  76. }
  77. break;
  78. case KEY_PANEL_UP:
  79. SlwTrace(INF,"[KEY_PANEL_UP Press]",1);
  80. break;
  81. case KEY_PANEL_DOWN:
  82. SlwTrace(INF,"[KEY_PANEL_DOWN Press]",1);
  83. break;
  84. case KEY_EXIT_DOWN_GT:
  85. SlwTrace(INF,"[KEY_EXIT_DOWN_GT Press]",1);
  86. break;
  87. case KEY_P1_P3_UPDATE:
  88. SlwTrace(INF, "[KEY_P1_P3_UPDATE Press]",1);
  89. break;
  90. case KEY_UP_DOWN_IP:
  91. SlwTrace(INF, "[KEY_UP_DOWN_IP Press]",1);
  92. break;
  93. case KEY_OPTION:
  94. g_usOptionCnt++;
  95. // if(g_usOptionCnt ==3){
  96. // // ipSosStartNow();
  97. // //在待机界面按一下'S'键,网络允许情况下发SOS消息
  98. // if(sutGpsInfo.isGpsAuthOk==1 && sutUIstatus.Status==UIS_STANDBY && g_ucModemTaskEn==1){
  99. // buBiaoSosSendNow=1;
  100. // }
  101. // }
  102. //UISetNextStatus(UIS_STANDBY);
  103. SlwTrace(INF, "[KEY_OPTION Press]",1);
  104. break;
  105. }
  106. }
  107. void KeyFree(void){
  108. if(sutUIstatus.Status==UIS_STANDBY && g_uslockflag==1)
  109. {
  110. if((g_ulKeyValue==KEY_INFO)||(g_ulKeyValue==KEY_PANEL_MENU)||(g_ulKeyValue==KEY_PANEL_UP)||(g_ulKeyValue==KEY_PANEL_DOWN)||(g_ulKeyValue==KEY_FUNC))
  111. {
  112. Ui_LockFlag=1;
  113. return;
  114. }
  115. }
  116. switch(g_ulKeyValue){
  117. case KEY_PPT_MIC:
  118. case KEY_PPT:
  119. SlwTrace(INF,"[KEY_PPT/KEY_PPT_MIC Release]",1);
  120. g_ucKeyPPTPress=0;
  121. PttKeyFlag=0;
  122. //sutPocStatus.PPTpress=0;
  123. if(g_ucTMMode!=0) break;
  124. if(hgs_poc_type==POC_BND)ModemSendAt("AT+POC=ptt,0\r\n");
  125. else {
  126. //if(uTimerExpired(&HeadsetQudou))
  127. ModemSendAt("AT+POC=0C0000\r\n");
  128. }
  129. g_ucKeyMode=0;
  130. break;
  131. case KEY_INFO:
  132. SlwTrace(INF,"[KEY_UP Release]",1);
  133. g_ucKeyMode=0;
  134. break;
  135. case KEY_FUNC:
  136. SlwTrace(INF,"[KEY_DOWN Release]",1);
  137. g_ucKeyMode=0;
  138. break;
  139. case KEY_PANEL_OK:
  140. SlwTrace(INF,"[KEY_OK Release]",1);
  141. break;
  142. case KEY_PANEL_MENU:
  143. SlwTrace(INF,"[KEY_PANEL_MENU Release]",1);
  144. break;
  145. case KEY_PANEL_EXIT:
  146. SlwTrace(INF,"[KEY_PANEL_EXIT Release]",1);
  147. g_uslockCnt=0;
  148. break;
  149. case KEY_PANEL_UP:
  150. SlwTrace(INF,"[KEY_PANEL_UP Release]",1);
  151. if(sutUIstatus.Status == UIS_STANDBY)SwitchVoicePre(1);
  152. break;
  153. case KEY_PANEL_DOWN:
  154. SlwTrace(INF,"[KEY_PANEL_DOWN Release]",1);
  155. if(sutUIstatus.Status == UIS_STANDBY)SwitchVoicePre(0);
  156. break;
  157. case KEY_EXIT_DOWN_GT:
  158. SlwTrace(INF,"[KEY_EXIT_DOWN_GT Release]",1);
  159. g_ulKeyValue=0;
  160. break;
  161. case KEY_P1_P3_UPDATE:
  162. SlwTrace(INF, "[KEY_P1_P3_UPDATE Release]",1);
  163. break;
  164. case KEY_UP_DOWN_IP:
  165. SlwTrace(INF, "[KEY_UP_DOWN_IP Release]",1);
  166. g_ulKeyValue=0;
  167. break;
  168. case KEY_OPTION:
  169. SlwTrace(INF, "[KEY_OPTION Release]",1);
  170. if(sutUIstatus.Status==UIS_STANDBY){
  171. LCDBackLight(0);
  172. LcdOnTimeCt=newPara.lcdParaList[newPara.lcdParaDefaultIndex];
  173. }
  174. if(sutUIstatus.Status!=UIS_POWEROFF_WAIT&&sutUIstatus.Status != UIS_APN_DETAIL&&sutUIstatus.Status != UIS_MESSAGE_OPTION &&sutUIstatus.Status != UIS_STANDBY&&sutUIstatus.Status!=UIS_SET_APN&&sutUIstatus.Status!=UIS_MAIL_BOX)UISetNextStatus(UIS_STANDBY);
  175. g_usOptionCnt=0;
  176. break;
  177. }
  178. if(KEY_IDLE != g_ulKeyValue) g_ucKeyMode=0;
  179. }
  180. static int keyNum=0;
  181. char isKeyPress(void){
  182. if(keyNum) return keyNum--;
  183. else return 0;
  184. }
  185. void KeyProces(signed char KeyFlag,char type)
  186. {
  187. static char repress=0;//按键重复音
  188. if(1==KeyFlag){ //按键按下 //
  189. LCDBackLight(1);
  190. LcdOnTimeCt=0;
  191. repress++;
  192. if(g_ulKeyValue!=KEY_PPT&&(newPara.KeySound==1)){
  193. if(repress<2){
  194. if(TTSPlayTick<uSysTickGet()){
  195. //ModemSendAt("AT+TONE\r\n");
  196. SetBeep(1000,10);
  197. SpeakerEnable();
  198. uTimerCreate(UTIMER_BEEP,15);//20
  199. }
  200. }
  201. }
  202. if(!LastKeyLight&&g_ulKeyValue!=KEY_PPT_MIC&&g_ulKeyValue!=KEY_PPT)return;//熄屏操作
  203. keyNum++;
  204. KeyPress();
  205. m_keyreturncnt=10;
  206. }else if(KeyFlag==-1){ //按键释放
  207. repress=0;
  208. if(PttKeyFlag==1&&type){
  209. ModemSendAt("AT+POC=0C0000\r\n");//由于存在按键值和ADC两种键值,会相互修改,导致有时候无法触发PTT松开
  210. PttKeyFlag=0;
  211. }
  212. if(!LastKeyLight&&g_ulKeyValue!=KEY_PPT_MIC&&g_ulKeyValue!=KEY_PPT)return;
  213. KeyFree();
  214. m_keyreturncnt=10;
  215. }
  216. }
  217. void KeyHandler(void){
  218. signed char KeyFlag1=0;
  219. signed char KeyFlag2=0;
  220. KeyFlag1=GetKey();
  221. KeyFlag2=GetKeyVBAT();
  222. KeyProces(KeyFlag1,1);
  223. KeyProces(KeyFlag2,0);//电压键值
  224. }
  225. static void PcMsgHandle(char *msg){
  226. short CmdListNum=0,i,j;
  227. const char *pCmd;
  228. char *pMsg,flag;
  229. char buf[150];
  230. char strIP[40];
  231. char strAccount[20+20];
  232. char strPassword[20+20];
  233. int len;
  234. unsigned short Port;
  235. unsigned long PSN;
  236. char needsave=0;
  237. char needsaveExterPara=0;
  238. static char exaud=0;
  239. const char *CmdList[]={
  240. "TM", //Trace Modem
  241. "TG", //Trace GPS
  242. "SMP", //Set Modem Parameter
  243. "RMP", //Read Modem Parameter
  244. "SGP", //Set GPS Parameter
  245. "RGP",
  246. "SACC", //Set access point
  247. "RACC", //Read access point
  248. "APN", //SET APN
  249. "RAPN", //Read APN
  250. "RREC", //Read record info
  251. "VER", //Read Version
  252. "BAT", //Battery voltage
  253. "UPDATE",
  254. "EXAUD",
  255. "RDOMAIN",
  256. "SDOMAIN",
  257. "RPID",
  258. "SPID",
  259. ""
  260. };
  261. typedef enum{
  262. GT_TM,
  263. GT_TG,
  264. GT_SMP,
  265. GT_RMP,
  266. GT_SGP,
  267. GT_RGP,
  268. GT_SACC,
  269. GT_RACC,
  270. GT_APN,
  271. GT_RAPN,
  272. GT_RREC,
  273. GT_VER,
  274. GT_BAT,
  275. GT_UPDATE,
  276. GT_EXAUD,
  277. GT_RDOMAIN,
  278. GT_SDOMAIN,
  279. GT_RPID,
  280. GT_SPID,
  281. }GT_CMD_DEF;
  282. while(*CmdList[CmdListNum++]);//计算命令列表个数
  283. CmdListNum--;
  284. //查找与命令列表相同的命令位置
  285. for(i=0;i<CmdListNum;i++){
  286. pCmd=CmdList[i];
  287. pMsg=&msg[3];
  288. flag=0;
  289. j=0;
  290. while(*pCmd){
  291. if(*pCmd!=*pMsg){
  292. flag=1;
  293. break;
  294. }
  295. pCmd++;
  296. pMsg++;
  297. j++;
  298. }
  299. if(!flag){
  300. break;
  301. }
  302. }
  303. if(i==CmdListNum)return;
  304. switch(i){
  305. case GT_TM:SlwTrace(INF,"GT+TM:OK",1);
  306. SetLedStatus(RedBlueSlowFlash);
  307. ComSelect(COM_SEL_MODEM);
  308. g_ucTMMode=1;
  309. break;
  310. case GT_TG:SlwTrace(INF,"GT+TG:OK",1);
  311. SetLedStatus(RedBlueSlowFlash);
  312. GPSRestart();
  313. ComSelect(COM_SEL_GPS);
  314. break;
  315. case GT_SMP://"SMP" GT+SMP=IP=地址或域名;Port=端口号;PSN=终端序列号
  316. len=GetParaFromStr(msg,"IP",buf);
  317. if(len<1 || len>=40){
  318. SlwTrace(INF,"GT+SMP:FAIL[IP Invalid]",1);
  319. break;
  320. }
  321. strcpy(strIP,buf);
  322. len=GetParaFromStr(msg,"Port",buf);
  323. if(len==0)Port=0;
  324. else if(len>5){
  325. SlwTrace(INF,"GT+SMP:FAIL[Port Invalid]",1);
  326. break;
  327. }else{
  328. Port=atoi(buf);
  329. }
  330. len=GetParaFromStr(msg,"PSN",buf);
  331. if(len<1 || len>10){
  332. SlwTrace(INF,"GT+SMP:FAIL[PSN Invalid]",1);
  333. break;
  334. }else{
  335. PSN=atol(buf);
  336. }
  337. //PSN
  338. if(sutProductPara.PSN != PSN){
  339. sutProductPara.PSN=PSN;
  340. needsave=1;
  341. }
  342. if(newPara.serList.defaultuse != SER_US){
  343. newPara.serList.defaultuse=SER_US;
  344. needsaveExterPara=1;
  345. }
  346. if(0!= strcmp(newPara.serList.ur.pip, strIP)){//与资源文件的不一样,则需要更新
  347. strcpy(newPara.serList.ur.pip, strIP);
  348. needsaveExterPara=1;
  349. }
  350. snprintf(buf, sizeof(buf),"GT+SMP:IP=%s;Port=%u;PSN=%lu;",newPara.serList.ur.pip,Port,sutProductPara.PSN);
  351. SlwTrace(INF,buf,1);
  352. break;
  353. case GT_RMP://"RMP" GT+RMP<CR><LF> PSN=终端序列号;MEID=模块MEID号;CNUM=电信号;UIMID=电信UIMID;
  354. snprintf(buf, sizeof(buf),"GT+RMP:PSN=%lu;MEID=%s;CNUM=0000000000;UIMID=0000000000;IP=%s;",sutProductPara.PSN,DEV_HARDID,getPIPAddr());
  355. SlwTrace(INF,buf,1);
  356. break;
  357. case GT_SGP://"SGP" GT+SGP=IP=地址或域名;Port=端口号;
  358. len=GetParaFromStr(msg,"IP",buf);
  359. if(len<1 || len>=40){
  360. SlwTrace(INF,"GT+SGP:FAIL[IP Invalid]",1);
  361. break;
  362. }else strcpy(strIP,buf);
  363. len=GetParaFromStr(msg,"Port",buf);
  364. if(len==0)Port=0;
  365. else if(len>5){
  366. SlwTrace(INF,"GT+SGP:FAIL[Port Invalid]",1);
  367. break;
  368. }else{
  369. Port=atoi(buf);
  370. }
  371. if(newPara.serList.defaultuse != SER_US){
  372. newPara.serList.defaultuse = SER_US;
  373. needsaveExterPara=1;
  374. }
  375. if(0!=strcmp(newPara.serList.ur.gip, strIP) || Port != newPara.gpsPort){
  376. strcpy(newPara.serList.ur.gip,strIP);
  377. newPara.gpsPort=Port;
  378. needsaveExterPara=1;
  379. }
  380. //echo
  381. snprintf(buf, sizeof(buf),"GT+SGP:IP=%s;Port=%u;",newPara.serList.ur.gip,newPara.gpsPort);
  382. SlwTrace(INF,buf,1);
  383. break;
  384. case GT_RGP://RGP
  385. snprintf(buf, sizeof(buf),"GT+RGP:IP=%s;PORT=%d;",newPara.serList.ur.gip,newPara.gpsPort);
  386. SlwTrace(INF,buf,1);
  387. break;
  388. case GT_SACC://SACC
  389. len=GetParaFromStr(msg,"Accessp",buf);
  390. if(len<0 || len > (APN_SEGMENT_MAX_LEN-1))
  391. {
  392. SlwTrace(INF,"GT+SACC:FAIL[Accessp Invalid]",1);
  393. return;
  394. }
  395. if(len ==0) newPara.apnList.APN_Name[0]=0;
  396. else strcpy(newPara.apnList.APN_Name,buf);
  397. snprintf(buf, sizeof(buf),"GT+SACC:Accessp=%s;",newPara.apnList.APN_Name); //**********
  398. SlwTrace(INF,buf,1);
  399. needsaveExterPara=1;
  400. break;
  401. case GT_RACC://RACC
  402. snprintf(buf, sizeof(buf),"GT+RACC:Accessp=%s;",newPara.apnList.APN_Name);
  403. SlwTrace(INF,buf,1);
  404. break;
  405. case GT_APN://APN
  406. /*
  407. 设置格式:GT+APN=Account=用户名;Password=密码;<CR><LF>
  408. 成功返回:GT+APN:Account=用户名;Password=密码;<CR><LF>
  409. 失败返回:GT+APN:FAIL[失败原因]<CR><LF>
  410. */
  411. len=GetParaFromStr(msg,"Account",buf);
  412. if(len<1 || len > 30){
  413. SlwTrace(INF,"GT+APN:FAIL[Account Invalid]",1);
  414. return;
  415. }
  416. strcpy(strAccount,buf);
  417. len=GetParaFromStr(msg,"Password",buf);
  418. if(len<1 || len > 30){
  419. SlwTrace(INF,"GT+APN:FAIL[Password Invalid]",1);
  420. return;
  421. }
  422. strcpy(strPassword,buf);
  423. snprintf(buf, sizeof(buf),"GT+APN:Account=%s;Password=%s;",strAccount,strPassword);//******
  424. SlwTrace(INF,buf,1);//*********
  425. if(newSysiniIndex<0) break;
  426. if(0==strcmp(strAccount, newPara.apnList.apnList[3].account) &&
  427. 0==strcmp(strPassword, newPara.apnList.apnList[3].pass))
  428. break;
  429. strcpy(newPara.apnList.apnList[3].account, strAccount);
  430. strcpy(newPara.apnList.apnList[3].pass, strPassword);
  431. newPara.apnList.defaultuse=3;
  432. needsaveExterPara=1;
  433. break;
  434. case GT_RAPN://RAPN
  435. sprintf(buf,"GT+RAPN:Account=%s;Password=%s;",newPara.apnList.apnList[3].account,newPara.apnList.apnList[3].pass); //***********
  436. SlwTrace(INF,buf,1);
  437. break;
  438. case GT_RREC://RREC
  439. sFlash_Read(buf, RECORD_INFO_ADDRESS, 100);
  440. SlwTrace(INF, buf, 1);
  441. break;
  442. case GT_VER://"VER"
  443. snprintf(buf, sizeof(buf),"GT+VER:%s_V%d",sutProductPara.ProductName,sutProductPara.ProductVersion);
  444. SlwTrace(INF,buf,1);
  445. break;
  446. case GT_BAT://BAT
  447. snprintf(buf, sizeof(buf),"GT+BAT: %d V",g_iVbat);
  448. SlwTrace(INF,buf,1);
  449. case GT_UPDATE:
  450. SlwTrace(INF,"goto ModemUpdate",1);
  451. USBORTTL_LOW;//切换至USB口
  452. MODEM_UPDATE_HIGH;
  453. sutPocStatus.modemRstFlag=1; //复位模块
  454. break;
  455. case GT_EXAUD:
  456. if(exaud==0){
  457. exaud=1;
  458. SpeakerEnable();
  459. SlwTrace(INF,"enable spk",1);
  460. }else {
  461. SpeakerDisable();
  462. exaud=0;
  463. SlwTrace(INF,"disenable spk",1);
  464. }
  465. break;
  466. case GT_RDOMAIN:
  467. snprintf(buf,sizeof(buf),"GT+RDOMAIN:%s;PSN=%lu;",newPara.serList.ipFenFa,sutProductPara.PSN);
  468. SlwTrace(INF,buf,1);
  469. break;
  470. case GT_SDOMAIN:
  471. len=GetParaFromStr(msg,"SDOMAIN",buf);//buf=www.baidu.com ,return len
  472. if(len>40){
  473. SlwTrace(INF,"MAINIP LEN ERR",1);
  474. return;
  475. }
  476. if(newPara.serList.defaultuse != SER_IP){
  477. newPara.serList.defaultuse=SER_IP;
  478. needsaveExterPara=1;
  479. }
  480. memset(newPara.serList.ipFenFa,0,sizeof(newPara.serList.ipFenFa));
  481. strcpy(newPara.serList.ipFenFa,buf);
  482. len=GetParaFromStr(msg,"PSN",buf);
  483. if(len<1 || len>10){
  484. SlwTrace(INF,"GT+SMP:FAIL[PSN Invalid]",1);
  485. break;
  486. }else{
  487. PSN=atol(buf);
  488. }
  489. //PSN
  490. if(sutProductPara.PSN != PSN){
  491. sutProductPara.PSN=PSN;
  492. needsave=1;
  493. }
  494. snprintf(buf,sizeof(buf),"GT+SDOMAIN=%s;PSN=%lu;",newPara.serList.ipFenFa,sutProductPara.PSN);
  495. //Save para to flash
  496. needsaveExterPara=1;
  497. SlwTrace(INF,buf,1);
  498. break;
  499. case GT_RPID:
  500. snprintf(buf, sizeof(buf),"GT+RPID:PSN=%lu;",sutProductPara.PSN);
  501. SlwTrace(INF,buf,1);
  502. break;
  503. case GT_SPID:
  504. len=GetParaFromStr(msg,"PSN",buf);
  505. if(len<1 || len>10){
  506. SlwTrace(INF,"GT+SPID:FAIL[PSN Invalid]",1);
  507. break;
  508. }else{
  509. PSN=atol(buf);
  510. }
  511. //PSN
  512. if(sutProductPara.PSN != PSN){
  513. sutProductPara.PSN=PSN;
  514. needsave=1;
  515. }
  516. snprintf(buf, sizeof(buf),"GT+SPID:PSN=%lu;",sutProductPara.PSN);
  517. SlwTrace(INF,buf,1);
  518. break;
  519. default:
  520. break;
  521. }
  522. if(needsave!=0) SaveProductParaToFlash();
  523. if(needsaveExterPara!=0) ModifyConfigureFile(0);
  524. }
  525. void CommHandler(void){
  526. if(g_usUart1RecvLen){
  527. PcMsgHandle((char *)RxBuffer1);
  528. g_usUart1RecvLen=0;
  529. rx1_ct=0;
  530. }
  531. }
  532. void ResetModem(void)
  533. {
  534. Uart2Init();
  535. sutPocStatus.modemRstFlag=1;
  536. }
  537. /*************************************************************************************
  538. *FingerDaemonfinger
  539. *守护进程
  540. *用于防止通讯模块死机,或者与通讯模块通讯的串口异常而重新启动模块或通讯驱动。
  541. *用于防止GPS模块异常而重启GPS
  542. *此函数需要确保每秒调用一次
  543. 入口参数
  544. sutPocStatus.FirstLogined
  545. sutPocStatus.PocLostCt
  546. sutPocStatus.ModemPowerOn
  547. sutPocStatus.ModemInactiveCt
  548. g_iCSQ
  549. **************************************************************************************/
  550. void FingerDaemonfinger(void)
  551. {
  552. static unsigned char sucPocLostTimeoutCount=0;//
  553. //static unsigned char sucModemInactiveCount=0;
  554. unsigned short PocLostCtMax;
  555. IWDG_ReloadCounter();//喂狗
  556. if(g_ucEnterGTNow)return;//GT+TM 返回
  557. if(g_ucModemTaskEn==0||USBSeletCt>0)return;
  558. //如果曾经登陆过POC系统,然后离线,开始计数,直到再次登陆,如果一直不登陆超过一定时间,则重启模块和串口
  559. if(sutPocStatus.FirstLogined){
  560. if(sutPocStatus.Logined==0){
  561. PocLostCtMax=pocTimeOutTime*60;
  562. if(++sutPocStatus.PocLostCt>PocLostCtMax){
  563. sutPocStatus.PocLostCt=0;
  564. //长时间不登陆,重启模块及串口驱动部分
  565. SlwTrace(INF,"PocLostTimeout!Reset Modem!",1);
  566. ResetModem();
  567. }
  568. }else{
  569. sutPocStatus.PocLostCt=0;
  570. sucPocLostTimeoutCount=0;
  571. }
  572. }else{
  573. //一个小时未登录复位模块
  574. if(++sutPocStatus.PocLostCt>3600){
  575. sutPocStatus.PocLostCt=0;
  576. printf("Timeout Logintimeout----\r\n ");
  577. ResetModem();
  578. }
  579. }
  580. //如果模块已开机,长时间收不到串口消息,则重启模块及串口驱动部分
  581. if(sutPocStatus.ModemPowerOn==1){
  582. // if(sutPocStatus.ModemInactiveCt==0){//ModemInactiveCt必须在接收到Modem串口消息后才清零
  583. // //sucModemInactiveCount=0;
  584. // }
  585. if(++sutPocStatus.ModemInactiveCt>40){//等待时间
  586. sutPocStatus.ModemInactiveCt=1;
  587. //长时间收不到串口消息,重启模块及串口驱动
  588. SlwTrace(INF,"ModemRecvTimeout!Reset Modem!",1);
  589. ResetModem();
  590. }
  591. }
  592. //GPS守护
  593. if(sutGpsInfo.isGpsWork>0){
  594. if(++sutGpsInfo.GpsInactiveCt>10){
  595. sutGpsInfo.GpsInactiveCt=0;
  596. //复位GPS
  597. GPSRestart();
  598. Uart3Init();
  599. }
  600. }
  601. }
  602. void PowerCtrlInit(void)
  603. {
  604. GPIO_InitTypeDef GPIO_InitStructure;
  605. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC, ENABLE);
  606. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  607. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  608. GPIO_InitStructure.GPIO_Pin = PWR_EN_PIN;
  609. GPIO_Init(PWR_EN_PORT, &GPIO_InitStructure);
  610. PWR_EN_LOW; //HIGH
  611. }
  612. unsigned char g_ucEnterGTNow=0;
  613. void EnterGTMode(void)
  614. {
  615. unsigned char time=12;
  616. g_ucModemTaskEn=0;
  617. g_ucEnterGTNow=1;
  618. SpeakerEnable();
  619. SetBeepByNoOS(1000,10);
  620. SetBeepByNoOS(500,10);
  621. SetBeepByNoOS(1000,10);
  622. Uart1RxEnable(1);
  623. LedProcess(1);
  624. SetLedStatus(RedBlueFastFlash);
  625. SlwTrace(INF,"[EnterTxMode]",1);
  626. }
  627. void cmdShutDown(char type)
  628. {
  629. short cntDown;
  630. LCDBackLight(1);
  631. LcdOnTimeCt=0;
  632. SlwTrace(INF, "Try to PwrOff",1);
  633. ModemSendAt("AT$QCPWRDN\r\n");
  634. switch(type)
  635. {
  636. case 0:ShowMessageBox("正在关机");break;
  637. case 1:ShowMessageBox("低压关机");break;
  638. default:return;
  639. }
  640. for(cntDown=6;cntDown>=0;cntDown--)
  641. {
  642. IWDG_ReloadCounter();
  643. uTimerHardDly(100);
  644. }
  645. }
  646. char GetUniStringByID(char *HardIDString)
  647. {//输出15个字节的字符串
  648. unsigned char id[12];
  649. unsigned char string[16];
  650. long long temp;
  651. short i;
  652. unsigned char seed;
  653. if(HardIDString == '\0') return 0;
  654. GetSTM32ID(id);
  655. printf("STM32 ID==");
  656. for(i=0;i<12;i++)printf("%02x",id[i]);
  657. printf("\r\n");
  658. for(i=5;i>=0;i--){
  659. temp <<=8;
  660. temp |= id[i];
  661. }
  662. temp &= 0xffffffffffff;
  663. printf("temp=%015llu\r\n",temp);
  664. snprintf(string,sizeof(string),"%015llu",temp);
  665. for(i=0;i<15;i++) HardIDString[i]=string[i];
  666. HardIDString[15]='\0';
  667. //snprintf(HardIDString,16,"%015llu",temp);
  668. return 1;
  669. }
  670. void PowerOffProtetion(void)
  671. {
  672. if(modemPwrOffNow==0) return;
  673. // PWR_EN_HIGH;
  674. // LCDBackLight(1);
  675. // GPS_PWREN_LOW;
  676. // cmdShutDown(0);
  677. // PWR_EN_LOW;
  678. // while(1);
  679. }
  680. //长按 EXIT和下箭头3秒,只进入一次
  681. void GTMode_Detected(void)
  682. {
  683. static char GT_Flag=0;
  684. if(GT_Flag == 2) return;
  685. if(g_ulKeyValue == KEY_EXIT_DOWN_GT)
  686. {
  687. if(GT_Flag == 0)
  688. {
  689. g_ucUKC=0;
  690. GT_Flag ++;
  691. }else
  692. {
  693. if(g_ucUKC>=3){
  694. EnterGTMode();
  695. GT_Flag++;
  696. }
  697. }
  698. }else
  699. {
  700. if(GT_Flag == 1)
  701. GT_Flag = 0;
  702. }
  703. }
  704. /*****************************************************************************************
  705. *函数名:GetCheckCodeByPsnMEID
  706. *功能:根据PSN号和MEID码,生成伪随机码
  707. *入口:PSN--PSN码,无符号长整形,必须是大于150000000的数值,有可能是9位数也可能是10位数
  708. pMEID--MEID字串,长度14位或15位,第16字节必须为0。
  709. *出口:pCheckCode:--长度为6的字符串,第7字节为结束符0x00,因此必须留够7字节的空间!
  710. 返回:1--成功 0--因参数非法而失败
  711. ******************************************************************************************/
  712. const unsigned char sucRandTable[256]={
  713. 0x68,0x59,0x63,0x64,0xc8,0xcc,0xaa,0xa7,0xa2,0xab,0xa5,0x6e,0x6a,0x56,0x8a,0x57,
  714. 0xf4,0xbb,0xfe,0xfa,0x26,0x21,0x2d,0x29,0x0d,0x09,0x3e,0x3a,0x37,0x32,0x0a,0x07,
  715. 0xf7,0xf2,0xfb,0xf5,0xff,0xf6,0x1c,0x18,0x13,0x14,0xf1,0xfd,0xf9,0x0c,0x9f,0x08,
  716. 0x9a,0x97,0x92,0x9b,0x95,0x9f,0x12,0x1b,0x15,0x2c,0x28,0x23,0xf9,0x2a,0x27,0x22,
  717. 0x24,0x2e,0x67,0x25,0x2f,0x98,0xfc,0x75,0xf8,0xf3,0x3c,0x38,0x33,0x34,0x03,0x04,
  718. 0x05,0x0f,0x06,0x01,0x7a,0x77,0x72,0x62,0x6b,0x83,0x84,0x8e,0xc4,0xcb,0x87,0x82,
  719. 0x35,0x3f,0x36,0x4f,0x3d,0x39,0x9c,0x98,0x93,0x94,0x42,0x4f,0x46,0x41,0x81,0x8d,
  720. 0x4d,0x49,0x71,0x7d,0x79,0x96,0x91,0x9d,0x99,0xc3,0xc4,0x1d,0xce,0xca,0x7f,0x76,
  721. 0x7c,0x78,0x73,0x74,0x7e,0x7b,0x75,0x1e,0x1a,0x17,0x1f,0x16,0x11,0x1d,0x47,0x19,
  722. 0x5d,0xc7,0xc2,0xcb,0xc5,0xcf,0xd1,0xdd,0xd9,0x4c,0x48,0xc6,0xc1,0xcd,0x61,0xc9,
  723. 0xd7,0x8c,0xfd,0x88,0xa1,0xad,0xa9,0xb1,0xbd,0xb9,0x8b,0x85,0x8f,0x4b,0x45,0x86,
  724. 0xdc,0xd8,0xd3,0xd4,0xde,0xd2,0xdb,0xd5,0xdf,0xd6,0x43,0x44,0x4e,0x4a,0xe7,0x47,
  725. 0xac,0xa8,0xa3,0xa4,0xae,0xba,0x0d,0xb7,0xb2,0xaf,0xa6,0xe4,0xee,0xea,0xe7,0xe2,
  726. 0xe1,0xed,0x0f,0xe9,0x66,0x61,0x6d,0x69,0xbb,0xb5,0xbf,0xb6,0xec,0xe8,0x0b,0xe3,
  727. 0x52,0x5c,0x65,0x6f,0x58,0x53,0x54,0x0c,0x5e,0x5b,0x55,0x5f,0x31,0x2f,0x9a,0x0b,
  728. 0x0b,0x5a,0x2b,0x9e,0x02,0x89,0x59,0x3b,0x0e,0x51,0x6c,0xeb,0xda,0xe6,0x31,0xf6
  729. };
  730. int GetCheckCodeByPsnMEID(char *pCheckCode,unsigned long PSN,char *pMEID)
  731. {
  732. char aucPSN[12];
  733. char aucMEID[16];
  734. unsigned char key[10];
  735. unsigned char temp1,temp2;
  736. int MeidLen,PsnLen;
  737. int i,j;
  738. //PSN合法性检测
  739. if(PSN<150100000)return 0;
  740. //MEID合法性检测
  741. MeidLen=strlen(pMEID);
  742. //if(MeidLen!=14 && MeidLen!=15)return 0; //MEID号长度必须为14或15
  743. if(MeidLen!=14 && MeidLen!=15){
  744. snprintf(aucPSN, sizeof(aucMEID),"%015lu",pMEID); //不够15位前面补零
  745. }
  746. //PSN转字符串,不够10位的前面补'0'
  747. snprintf(aucPSN, sizeof(aucPSN),"%010lu",PSN);
  748. PsnLen=strlen(aucPSN);
  749. //取MEID的最后10个字符
  750. j=0;
  751. for(i=(MeidLen-10);i<MeidLen;i++){
  752. aucMEID[j]=pMEID[i];
  753. j++;
  754. }
  755. //所有字节进行相互异或运算,使每个字节的变化对整体结果都敏感
  756. temp1=0;
  757. temp2=0;
  758. for(i=0;i<10;i++){
  759. temp1^=(unsigned char)aucPSN[i];
  760. temp2^=(unsigned char)aucMEID[i];
  761. }
  762. temp1^=temp2;
  763. temp2=sucRandTable[temp1];
  764. //循环查表异或运算,生成key
  765. for(i=0;i<10;i++){
  766. temp1=aucPSN[i]^temp2;
  767. key[i]=aucMEID[i]^temp1;
  768. temp2=sucRandTable[temp1];
  769. }
  770. //取最后6个key,分别除10取余后再转Ascii,作为结果,结果为6个数字串,如"123456"
  771. j=0;
  772. for(i=4;i<10;i++){
  773. pCheckCode[j]=key[i]%10;
  774. pCheckCode[j]+=0x30;
  775. j++;
  776. }
  777. pCheckCode[6]=0; //结束符,方便调试打印和语音播报。
  778. return 1;
  779. }