MainTask.c 54 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027
  1. /********************************************************************************
  2. * File Name: MainTask.c
  3. * Function Describe:The main task for the system
  4. * Relate Module:
  5. * Explain: Hardware version is HS121
  6. * Writer: ShiLiangWen
  7. * Date: 2015.7.8
  8. *******************************************************************************/
  9. #define THIS_FILE_ID 8
  10. //---------------------------------------------------------------------------------
  11. #include "includes.h"
  12. #include "stm32f10x_it.h"
  13. //OS ID
  14. OS_TID idMainTask=0;
  15. U64 stkMainTask[MAIN_TASK_STK_SIZE];
  16. unsigned char modemInitReady=0;//0模块没开始初始化 1模块初始化成功 2模块初始化失败
  17. unsigned char modemPwrOffNow=0;
  18. unsigned char g_ucBackLightCnt;
  19. int g_iVbat=0;
  20. unsigned int g_LCDTemp = 0;
  21. unsigned char g_ucGtMode=0;
  22. char sysStartTTS[START_TTS_LENGTH];
  23. //SUT_MSG_QUEUE ModemMsgQueue;
  24. //char ModemMsgBuffer[512];
  25. void FingerDaemonfinger(void);
  26. unsigned char g_ucUpdataVer=0;
  27. unsigned char g_ucKeyDownPressFlag=0;
  28. unsigned char g_ucGroupSelect=0;
  29. unsigned char g_ucUserSelect=0;
  30. unsigned char g_ucGroup_User_Select=0;
  31. unsigned char g_ucFun1KeyPressCt=0;//Fun1Key持续按下计数器,松开后清零
  32. unsigned char g_ucFun2KeyPressCt=0;//Fun2Key持续按下计数器,松开后清零
  33. int g_iFun1KeyEncodeCt=0; //Fun1Key按下时旋转Encode次数计数器,正数为顺时针,负数为逆时针,松开后清零
  34. int g_iFun2KeyEncodeCt=0; //Fun2Key按下时旋转Encode次数计数器,正数为顺时针,负数为逆时针,松开后清零
  35. unsigned int g_uikey_up_stat =0; //快捷键,用于进入GT模式 按下KEY_UP再按下OK
  36. unsigned char g_ucEnterGroupFlag=0;
  37. unsigned char pocTimeOutTime=30;//默认30分钟
  38. //======================================
  39. void ReportVbatCsqGps(void);
  40. void EncodeKeyProcess(void);
  41. void iap_jump_app_s(void);
  42. int GetCheckCodeByPsnMEID(char *pCheckCode,unsigned long PSN,char *pMEID);
  43. void ReportCheckCode(void);
  44. //-----
  45. #ifdef USE_RUNNING_MAKE
  46. void RunningMake(unsigned short FileID,unsigned long line)
  47. {
  48. g_usFileID=FileID;
  49. g_ulFileLine=line;
  50. }
  51. #endif
  52. unsigned short g_usFileID=0;
  53. unsigned long g_ulFileLine=0;
  54. // unsigned char m_GroupSelect=0;//用于使用左边上下键去选择群组时使用 wjl
  55. unsigned char m_GroupSwitch=0;//表示是否曾经按过左边上下群组切换按键
  56. unsigned char m_GroupSwitchCnt=0;//按过的话,5秒内没按OK键则退出切换
  57. /***********************************************
  58. 强制复位
  59. ************************************************/
  60. void SystemReset(void)
  61. {
  62. //IWDG_Configuration();
  63. while(1);
  64. }
  65. void PowerCtrlInit(void)
  66. {
  67. GPIO_InitTypeDef GPIO_InitStructure;
  68. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC, ENABLE);
  69. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  70. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  71. GPIO_InitStructure.GPIO_Pin = PWR_EN_PIN;
  72. GPIO_Init(PWR_EN_PORT, &GPIO_InitStructure);
  73. PWR_EN_LOW;
  74. }
  75. /*************************************************************************
  76. 拷贝数据,并判断与原数据是否相同
  77. 相同返回0
  78. 不同返回1
  79. **************************************************************************/
  80. unsigned char CopyData(unsigned char *pDst,unsigned char *pSrc,unsigned char len)
  81. {
  82. unsigned char i;
  83. unsigned char flag=0;
  84. for(i=0;i<len;i++){
  85. if(*pDst!=*pSrc){
  86. flag=1;
  87. *pDst=*pSrc;
  88. }
  89. pDst++;
  90. pSrc++;
  91. }
  92. return flag;
  93. }
  94. /********************************************************************
  95. *开关机键检测
  96. *********************************************************************/
  97. int OnOffCheck(void)
  98. {
  99. static unsigned char sucCt=0;
  100. unsigned long k;
  101. k=ONOFF_CK_PORT->IDR;
  102. if((k&ONOFF_CK_PIN)==ONOFF_CK_PIN){
  103. if(sucCt<5)sucCt++;
  104. else return 1;
  105. }else{
  106. sucCt=0;
  107. }
  108. return 0;
  109. }
  110. void GPIO_Config_ALL_AIN(void);
  111. /**********************************************************************
  112. *系统关机
  113. ***********************************************************************/
  114. void SysShutDown(void)
  115. {
  116. GPIO_InitTypeDef GPIO_InitStructure;
  117. unsigned long k;
  118. int len;
  119. GPS_PWREN_LOW;
  120. MODEM_LED1_HIGH;
  121. MODEM_LED2_HIGH;
  122. ModemSendAT("AT+ZPWROFF\r\n");
  123. SlwTrace(INF,"Set modem OnOff down!",1);
  124. ModemSendAT("AT+ZPWROFF\r\n");
  125. //os_dly_wait(50);
  126. SlwTrace(INF,"Set system power off!",1);
  127. //SlwTraceWaitCompleted();
  128. MODEM_LED1_LOW;
  129. MODEM_LED2_LOW;
  130. //-------
  131. k=ONOFF_CK_PORT->IDR;
  132. if((k&ONOFF_CK_PIN)==0){
  133. SlwTrace(INF,"Reset system!",1);
  134. //SlwTraceWaitCompleted();
  135. SystemReset();
  136. }else{
  137. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;
  138. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  139. GPIO_InitStructure.GPIO_Pin = PWR_EN_PIN;
  140. GPIO_Init(PWR_EN_PORT, &GPIO_InitStructure);
  141. while(1);
  142. }
  143. }
  144. //从source查找长度为targetLen目标的target,找到后返回目标段后一字节的索引,没找到返回-1,source结束为sourceEndIndicator
  145. //witchOne: 找第几个目标
  146. short FindTargetIndex(char *source, char sourceEndIndicator, char *target, unsigned char targetLen,unsigned char witchOne)
  147. {
  148. unsigned short targetIndex;
  149. unsigned char targetNum;
  150. targetIndex=0;
  151. targetNum=0;
  152. while(*source != sourceEndIndicator)
  153. {
  154. if(0==memcmp(source, target, targetLen))
  155. {//找到了
  156. targetNum++;
  157. if(targetNum == witchOne)
  158. return (targetIndex+targetLen);
  159. }
  160. source++;
  161. targetIndex++;
  162. }
  163. return -1;
  164. }
  165. unsigned char AscToHex(unsigned char aHex)
  166. {
  167. if((aHex>=0)&&(aHex<=9))
  168. aHex += 0x30;
  169. else if((aHex>=10)&&(aHex<=15))//A-F
  170. //aHex += 0x37;
  171. aHex += 0x57;
  172. else aHex = 0xff;
  173. return aHex;
  174. }
  175. void AscStrToHexStr(char *AscStr, char *HexStr)
  176. {
  177. char *pAscStr=AscStr;
  178. unsigned char d,h,l;
  179. while(0!=(d=(unsigned char)*pAscStr++)){
  180. l=d&0x0f;
  181. h=d>>4;
  182. *HexStr++=AscToHex(h);
  183. *HexStr++=AscToHex(l);
  184. }
  185. *HexStr=0;
  186. }
  187. unsigned char apnUpdateFlag=0;
  188. void PcMsgHandle(char *msg)
  189. {
  190. const char *CmdList[]={
  191. "TM", //Trace Modem
  192. "TG", //Trace GPS
  193. "DM", //Download Modem
  194. "FOTA", //Fota Modem
  195. "STP", //Set Test Parameter
  196. "SMP", //Set Modem Parameter
  197. "SGP", //Set GPS Parameter
  198. "RMP", //Read Modem Parameter
  199. "PST", //PST Mode for modem
  200. "VER", //Read Version
  201. "BAT", //Battery voltage
  202. "APN", //SET APN
  203. "RAPN", //Read APN
  204. "BEEP", //Beep test
  205. // "POC",
  206. // "TIME",
  207. // "SELECT",
  208. // "SREG", //部标注册
  209. // "STMOD",
  210. // "STID",
  211. // "RREG",
  212. // "RTMOD",
  213. // "RTID",
  214. // "SPlate",
  215. // "RPlate",
  216. // "SCOLOR",
  217. // "RCOLOR",
  218. // "SIM",
  219. "RGP",
  220. "RMIP", //Read Manager/Load IP
  221. "SMIP", //Set Manager/Load IP
  222. "RCIP", //Read ConfigIP
  223. "SCIP", //Set ConfigIP
  224. "SACC", //Set access point
  225. "RACC", //Read access point
  226. "RREC", //Read record info
  227. "RFIP", //read fota IP
  228. "SFIP" //set fota ip
  229. "" //必须以空字串为结束
  230. };
  231. int h,m,s;
  232. unsigned short Port;
  233. unsigned short Select;
  234. unsigned long PSN;
  235. char buf[150];
  236. char buf1[300];
  237. char strIP[40];
  238. char strAccount[20+20];
  239. char strPassword[20+20];
  240. unsigned short PID;//省域ID 16byte
  241. unsigned short CID; //市域ID16byte
  242. char Mfactur[10]; //制造商
  243. char TMod[42]; //终端型号 不足补0x00
  244. char TID[28]; //终端ID 不足补0x00 本来7个字节 为了跟星安一致 取4个字节8
  245. unsigned char PColor; //车牌颜色 未上牌取值为0
  246. char Plate[16]; // 车牌8
  247. char SIM[12];
  248. int i,j,len;
  249. char flag;
  250. const char *pCmd;
  251. char *pMsg;
  252. int CmdListNum=0;
  253. RunMake(THIS_FILE_ID);
  254. while(*CmdList[CmdListNum++]);//计算命令列表个数
  255. CmdListNum--;
  256. RunMake(THIS_FILE_ID);
  257. //查找与命令列表相同的命令位置
  258. for(i=0;i<CmdListNum;i++){
  259. pCmd=CmdList[i];
  260. pMsg=&msg[3];
  261. flag=0;
  262. j=0;
  263. while(*pCmd){
  264. if(*pCmd!=*pMsg){
  265. flag=1;
  266. break;
  267. }
  268. pCmd++;
  269. pMsg++;
  270. j++;
  271. }
  272. if(!flag){
  273. break;
  274. }
  275. }
  276. RunMake(THIS_FILE_ID);
  277. if(i==CmdListNum)return;
  278. //处理命令
  279. switch(i)
  280. {
  281. case 0://"TM"
  282. //idNetTask
  283. SetLedStatus(RedBlueSlowFlash);
  284. // g_ucNetTaskDisable=0xff;
  285. SlwTrace(INF,"GT+TM:OK",1);
  286. //SlwTraceWaitCompleted();
  287. ComSelect(COM_SEL_MODEM);
  288. g_ucGtMode=1;
  289. // MODEM_LED1_HIGH;
  290. // MODEM_LED2_LOW;
  291. // while(1){
  292. // IWDG_ReloadCounter();//喂狗
  293. // if(OnOffCheck()){
  294. // PWR_EN_LOW;
  295. // }
  296. // //OSTimeDlyHMSM(0, 0, 0, 1);
  297. // }
  298. break;
  299. case 1://"TG"
  300. SetLedStatus(RedBlueSlowFlash);
  301. SlwTrace(INF,"GT+TG:OK",1);
  302. //SlwTraceWaitCompleted();
  303. GPSInit();
  304. ComSelect(COM_SEL_GPS);
  305. break;
  306. case 2://"DM"
  307. SetLedStatus(RedBlueSlowFlash);
  308. //g_ucNetTaskDisable=0xff;
  309. SlwTrace(INF,"GT+DM:OK",1);
  310. //SlwTraceWaitCompleted();
  311. //OSTimeDlyHMSM(0, 0, 1, 0);
  312. ComSelect(COM_SEL_MODEM);
  313. MODEM_LED1_LOW;
  314. MODEM_LED2_HIGH;
  315. GPS_PWREN_LOW;
  316. ModemSetDtrLow();
  317. ModemSetRingLow();
  318. MODEM_PWRKEY_HIGH;
  319. MODEM_RESET_HIGH;
  320. //OSTimeDlyHMSM(0, 0, 1, 0);
  321. MODEM_RESET_LOW;
  322. while(1){
  323. IWDG_ReloadCounter();//喂狗
  324. if(OnOffCheck()){
  325. PWR_EN_LOW;
  326. }
  327. }
  328. break;
  329. case 3://"FOTA"
  330. SetLedStatus(RedBlueSlowFlash);
  331. if(msg[8]=='M' && msg[9]=='C' && msg[10]=='U' ){//GT+FOTA=MCU
  332. //g_ucNetTaskDisable=0xff;
  333. SlwTrace(INF,"GT+FOTA:MCU",1);
  334. //SlwTraceWaitCompleted();
  335. sutProductPara.IapFlag=0x55;
  336. SaveProductParaToFlash("COM-FOTA");
  337. while(1);
  338. }else if(msg[8]=='M' && msg[9]=='O' && msg[10]=='D' && msg[11]=='E' && msg[12]=='M' ){//GT+FOTA=MODEM 对讲版本
  339. //g_ucNetTaskDisable=0xff;
  340. SlwTrace(INF,"GT+FOTA:MODEM",1);
  341. //SlwTraceWaitCompleted();
  342. //OSTimeDlyHMSM(0, 0, 0, 100);
  343. ModemSendAT("at+poc=10000018\r\n");
  344. while(1){
  345. IWDG_ReloadCounter();//喂狗
  346. if(OnOffCheck()){
  347. PWR_EN_LOW;
  348. }
  349. }
  350. }
  351. break;
  352. case 4://"STP" GT+STP=IP=地址或域名;Port=端口号; Account=账号;Password=密码;
  353. //g_ucNetTaskDisable=0xff;
  354. //OSTimeDlyHMSM(0, 0, 0, 100);
  355. len=GetParaFromStr(msg,"IP",buf);
  356. if(len<1 || len>=40){
  357. SlwTrace(INF,"GT+STP:FAIL[IP Invalid]",1);
  358. break;
  359. }else strcpy(strIP,buf);
  360. len=GetParaFromStr(msg,"Port",buf);
  361. if(len==0)Port=0;
  362. else if(len>5){
  363. SlwTrace(INF,"GT+STP:FAIL[Port Invalid]",1);
  364. break;
  365. }else{
  366. Port=atoi(buf);
  367. }
  368. len=GetParaFromStr(msg,"Account",buf);
  369. if(len<1 || len>=20){
  370. SlwTrace(INF,"GT+STP:FAIL[Account Invalid]",1);
  371. break;
  372. }else strcpy(strAccount,buf);
  373. len=GetParaFromStr(msg,"Password",buf);
  374. if(len<1 || len>=20){
  375. SlwTrace(INF,"GT+STP:FAIL[Password Invalid]",1);
  376. break;
  377. }else strcpy(strPassword,buf);
  378. //send to modem
  379. snprintf(buf, sizeof(buf),"id=%s;ip=%s;pwd=%s;",strAccount,strIP,strPassword);
  380. AscStrToHexStr(buf,buf1);
  381. ModemSendAT("AT+POC=120000");
  382. ModemSendAT(buf1);
  383. ModemSendAT("\r\n");
  384. //send to pc
  385. snprintf(buf, sizeof(buf),"GT+STP:IP=%s;Port=%u;Account=%s;Password=%s",strIP,Port,strAccount,strPassword);
  386. SlwTrace(INF,buf,1);
  387. break;
  388. case 5://"SMP" GT+SMP=IP=地址或域名;Port=端口号;PSN=终端序列号
  389. len=GetParaFromStr(msg,"IP",buf);
  390. if(len<1 || len>=40){
  391. SlwTrace(INF,"GT+SMP:FAIL[IP Invalid]",1);
  392. break;
  393. }
  394. strcpy(strIP,buf);
  395. len=GetParaFromStr(msg,"Port",buf);
  396. if(len==0)Port=0;
  397. else if(len>5){
  398. SlwTrace(INF,"GT+SMP:FAIL[Port Invalid]",1);
  399. break;
  400. }else{
  401. Port=atoi(buf);
  402. }
  403. len=GetParaFromStr(msg,"PSN",buf);
  404. if(len<1 || len>10){
  405. SlwTrace(INF,"GT+SMP:FAIL[PSN Invalid]",1);
  406. break;
  407. }else{
  408. PSN=atol(buf);
  409. }
  410. //PSN
  411. sutProductPara.PSN=PSN;
  412. strcpy(sutProductPara.PIP,strIP);
  413. sutProductPara.PocPort=Port;
  414. //send to modem
  415. if(strlen(sutProductPara.IMEI)<14){
  416. SlwTrace(INF,"GT+SMP:FAIL[MEID Invalid]",1);
  417. break;
  418. }
  419. snprintf(buf, sizeof(buf),"id=%lu;ip=%s;pwd=%s;",sutProductPara.PSN,strIP,sutProductPara.IMEI);
  420. AscStrToHexStr(buf,buf1);
  421. ModemSendAT("AT+POC=010000");
  422. ModemSendAT(buf1);
  423. ModemSendAT("\r\n");
  424. //save para
  425. SaveProductParaToFlash("COM-SMP");
  426. snprintf(buf, sizeof(buf),"GT+SMP:IP=%s;Port=%u;PSN=%lu",sutProductPara.PIP,sutProductPara.PocPort,sutProductPara.PSN);
  427. SlwTrace(INF,buf,1);
  428. break;
  429. case 6://"SGP" GT+SGP=IP=地址或域名;Port=端口号;
  430. len=GetParaFromStr(msg,"IP",buf);
  431. if(len<1 || len>=40){
  432. SlwTrace(INF,"GT+SGP:FAIL[IP Invalid]",1);
  433. break;
  434. }else strcpy(strIP,buf);
  435. len=GetParaFromStr(msg,"Port",buf);
  436. if(len==0)Port=0;
  437. else if(len>5){
  438. SlwTrace(INF,"GT+SGP:FAIL[Port Invalid]",1);
  439. break;
  440. }else{
  441. Port=atoi(buf);
  442. }
  443. strcpy(sutProductPara.GIP,strIP);
  444. sutProductPara.GpsPort=Port;
  445. //Save para to flash
  446. SaveProductParaToFlash("COM-SGP");
  447. //echo
  448. snprintf(buf, sizeof(buf),"GT+SGP:IP=%s;Port=%u;",sutProductPara.GIP,sutProductPara.GpsPort);
  449. SlwTrace(INF,buf,1);
  450. break;
  451. case 7://"RMP" GT+RMP<CR><LF> PSN=终端序列号;MEID=模块MEID号;CNUM=电信号;UIMID=电信UIMID;
  452. snprintf(buf, sizeof(buf),"GT+RMP:PSN=%lu;MEID=%s;CNUM=0000000000;UIMID=0000000000;IP=%s",sutProductPara.PSN,sutProductPara.IMEI,sutProductPara.PIP);
  453. SlwTrace(INF,buf,1);
  454. break;
  455. case 8://"PST"
  456. SetLedStatus(RedBlueSlowFlash);
  457. //g_ucNetTaskDisable=0xff;
  458. SlwTrace(INF,"GT+PST:OK",1);
  459. //SlwTraceWaitCompleted();
  460. os_dly_wait(1);
  461. ComSelect(COM_SEL_MODEM);
  462. ModemSetDtrLow();
  463. MODEM_PWRKEY_LOW;
  464. MODEM_RESET_HIGH;
  465. os_dly_wait(5);
  466. MODEM_RESET_LOW;
  467. while(1){
  468. IWDG_ReloadCounter();//喂狗
  469. if(OnOffCheck()){
  470. PWR_EN_LOW;
  471. }
  472. }
  473. break;
  474. case 9://"VER"
  475. snprintf(buf, sizeof(buf),"GT+VER:%s_V%d",sutProductPara.ProductName,sutProductPara.ProductVersion);
  476. SlwTrace(INF,buf,1);
  477. break;
  478. case 10://BAT
  479. snprintf(buf, sizeof(buf),"GT+BAT: %d V",g_iVbat);
  480. SlwTrace(INF,buf,1);
  481. // SlwTrace(INF, msg,1);
  482. // cntMeiTiao=atoi(&msg[7]);
  483. // SpeakerEnable();
  484. // //SetBeepByNoOS(878, 100);
  485. // SetBeep(878, 3000);
  486. break;
  487. case 11://APN
  488. /*
  489. 设置格式:GT+APN=Account=用户名;Password=密码;<CR><LF>
  490. 成功返回:GT+APN:Account=用户名;Password=密码;<CR><LF>
  491. 失败返回:GT+APN:FAIL[失败原因]<CR><LF>
  492. */
  493. len=GetParaFromStr(msg,"Account",buf);
  494. if(len<1 || len > 30){
  495. SlwTrace(INF,"GT+APN:FAIL[Account Invalid]",1);
  496. return;
  497. }
  498. strcpy(strAccount,buf);
  499. len=GetParaFromStr(msg,"Password",buf);
  500. if(len<1 || len > 30){
  501. SlwTrace(INF,"GT+APN:FAIL[Password Invalid]",1);
  502. return;
  503. }
  504. if(sutProductPara.APNIndex==3 && validApnNum != 1)
  505. {
  506. strcpy(sutProductPara.APNName,strAccount);
  507. strcpy(sutProductPara.APNPass,buf);
  508. SaveProductParaToFlash("COM-APN");
  509. }
  510. snprintf(buf1, sizeof(buf1),"GT+APN:Account=%s;Password=%s;",strAccount,buf);
  511. SlwTrace(INF,buf1,1);
  512. if(ApnFileIndex==-1 || HgsApnLen==0) break;
  513. if(0==strcmp(strAccount, showApnTable[6]) &&
  514. 0==strcmp(buf, showApnTable[7]))
  515. break;
  516. strcpy(showApnTable[6],strAccount);
  517. strcpy(showApnTable[7],buf);
  518. apnUpdateFlag=1;
  519. break;
  520. case 12://RAPN
  521. if(validApnNum==1){
  522. i=0;j=1;
  523. }
  524. else{//有多个时,只能读取可配置的那个
  525. i=6;j=7;
  526. }
  527. sprintf(buf1,"GT+RAPN:Account=%s;Password=%s;",showApnTable[i],showApnTable[j]);
  528. SlwTrace(INF,buf1,1);
  529. break;
  530. case 13://BEEP
  531. len=GetParaFromStr(msg,"F",buf);
  532. if(len)i=atoi(buf);
  533. else i=878;
  534. len=GetParaFromStr(msg,"T",buf);
  535. if(len)Port=atoi(buf);
  536. else Port=8;//80
  537. SpeakerEnable();
  538. SetBeep(i,Port);
  539. snprintf(buf, sizeof(buf),"BEEP=%dHz,%dms",i,Port*10);
  540. SlwTrace(INF,buf,1);
  541. break;
  542. case 14://RGP
  543. snprintf(buf, sizeof(buf),"GT+RGP:IP=%s;PORT=%d;",sutProductPara.GIP,sutProductPara.GpsPort);
  544. SlwTrace(INF,buf,1);
  545. break;
  546. case 15://RMIP
  547. snprintf(buf, sizeof(buf),"GT+RMIP:IP=%d.%d.%d.%d;PORT=%d;",sutProductPara.ManagerIP[0],sutProductPara.ManagerIP[1],sutProductPara.ManagerIP[2],sutProductPara.ManagerIP[3],sutProductPara.ManagerPort);
  548. SlwTrace(INF,buf,1);
  549. break;
  550. case 16://SMIP
  551. len=GetParaFromStr(msg,"IP",buf);
  552. if(len<1 || len>=40){
  553. SlwTrace(INF,"GT+SMIP:FAIL[IP Invalid]",1);
  554. break;
  555. }else strcpy(strIP,buf);
  556. len=GetParaFromStr(msg,"Port",buf);
  557. if(len==0)Port=0;
  558. else if(len>5){
  559. SlwTrace(INF,"GT+SMIP:FAIL[Port Invalid]",1);
  560. break;
  561. }else Port=atoi(buf);
  562. GetStringIP2Bytes(sutProductPara.ManagerIP, strIP);
  563. sutProductPara.ManagerPort=Port;
  564. //Save para to flash
  565. SaveProductParaToFlash("COM-SMIP");
  566. //echo
  567. snprintf(buf, sizeof(buf),"GT+SMIP:IP=%d.%d.%d.%d;Port=%u;",sutProductPara.ManagerIP[0],
  568. sutProductPara.ManagerIP[1],
  569. sutProductPara.ManagerIP[2],
  570. sutProductPara.ManagerIP[3],
  571. sutProductPara.ManagerPort);
  572. SlwTrace(INF,buf,1);
  573. break;
  574. case 17://RCIP
  575. snprintf(buf, sizeof(buf),"GT+RCIP:IP=%d.%d.%d.%d;PORT=%d;",sutProductPara.ConfigSerIP[0],
  576. sutProductPara.ConfigSerIP[1],
  577. sutProductPara.ConfigSerIP[2],
  578. sutProductPara.ConfigSerIP[3],
  579. sutProductPara.ConfigSerPort);
  580. SlwTrace(INF,buf,1);
  581. break;
  582. case 18://SCIP
  583. len=GetParaFromStr(msg,"IP",buf);
  584. if(len<1 || len>=40){
  585. SlwTrace(INF,"GT+SCIP:FAIL[IP Invalid]",1);
  586. break;
  587. }else strcpy(strIP,buf);
  588. len=GetParaFromStr(msg,"Port",buf);
  589. if(len==0)Port=0;
  590. else if(len>5){
  591. SlwTrace(INF,"GT+SCIP:FAIL[Port Invalid]",1);
  592. break;
  593. }else Port=atoi(buf);
  594. GetStringIP2Bytes(sutProductPara.ConfigSerIP, strIP);
  595. sutProductPara.ConfigSerPort=Port;
  596. //Save para to flash
  597. SaveProductParaToFlash("COM-SCIP");
  598. //echo
  599. snprintf(buf, sizeof(buf),"GT+SCIP:IP=%d.%d.%d.%d;Port=%u;",sutProductPara.ConfigSerIP[0],
  600. sutProductPara.ConfigSerIP[1],
  601. sutProductPara.ConfigSerIP[2],
  602. sutProductPara.ConfigSerIP[3],
  603. sutProductPara.ConfigSerPort);
  604. SlwTrace(INF,buf,1);
  605. break;
  606. case 19://SACC
  607. len=GetParaFromStr(msg,"Accessp",buf);
  608. if(len<0 || len > APN_LEN)
  609. {
  610. SlwTrace(INF,"GT+SACC:FAIL[Accessp Invalid]",1);
  611. return;
  612. }
  613. if(len ==0) sutProductPara.APNApn[0]=0;
  614. else strcpy(sutProductPara.APNApn,buf);
  615. SaveProductParaToFlash("COM-SACC");
  616. snprintf(buf1, sizeof(buf1),"GT+SACC:Accessp=%s;",sutProductPara.APNApn);
  617. SlwTrace(INF,buf1,1);
  618. break;
  619. case 20://RACC
  620. snprintf(buf, sizeof(buf),"GT+RACC:Accessp=%s;",sutProductPara.APNApn);
  621. SlwTrace(INF,buf,1);
  622. break;
  623. case 21://RREC
  624. sFlash_Read(buf1, RECORD_INFO_ADDRESS, 100);
  625. SlwTrace(INF, buf1, 1);
  626. break;
  627. case 22://RFIP
  628. snprintf(buf, sizeof(buf),"GT+RFIP:IP=%d.%d.%d.%d;PORT=%d;",sutProductPara.MFotaIP[0],
  629. sutProductPara.MFotaIP[1],
  630. sutProductPara.MFotaIP[2],
  631. sutProductPara.MFotaIP[3],
  632. sutProductPara.MFotaPort);
  633. SlwTrace(INF,buf,1);
  634. break;
  635. case 23://SCIP
  636. len=GetParaFromStr(msg,"IP",buf);
  637. if(len<1 || len>=40){
  638. SlwTrace(INF,"GT+SFIP:FAIL[IP Invalid]",1);
  639. break;
  640. }else strcpy(strIP,buf);
  641. len=GetParaFromStr(msg,"Port",buf);
  642. if(len==0)Port=0;
  643. else if(len>5){
  644. SlwTrace(INF,"GT+SFIP:FAIL[Port Invalid]",1);
  645. break;
  646. }else Port=atoi(buf);
  647. GetStringIP2Bytes(sutProductPara.MFotaIP, strIP);
  648. sutProductPara.MFotaPort=Port;
  649. //Save para to flash
  650. SaveProductParaToFlash("COM-SFIP");
  651. //echo
  652. snprintf(buf, sizeof(buf),"GT+SFIP:IP=%d.%d.%d.%d;Port=%u;",sutProductPara.MFotaIP[0],
  653. sutProductPara.MFotaIP[1],
  654. sutProductPara.MFotaIP[2],
  655. sutProductPara.MFotaIP[3],
  656. sutProductPara.MFotaPort);
  657. SlwTrace(INF,buf,1);
  658. break;
  659. }
  660. RunMake(THIS_FILE_ID);
  661. }
  662. /*********************************************
  663. ************************************************/
  664. void TSMakeSendStrData(void){
  665. int i;
  666. static int Temp1[7];
  667. static int Table1[20]={0};
  668. //static int Table[20]={0};
  669. static int Temp[8];
  670. unsigned char SendBuf[100];
  671. unsigned short PacketLen,data1,data2,data3,data4;
  672. char buf1[300];
  673. // char str1[4];
  674. // int strData[4];
  675. // sprintf(str1,"%x",sutProductPara.proID);
  676. //发现Regist.proID 和egist.CityID输出的是他的BCD码
  677. //for (i=0;i<6;i+=2) {
  678. // Hexstr[i]='0'|(Bcdstr[i/2]>>4);
  679. // Hexstr[i+1]='0'|(Bcdstr[i/2]&0x0F);
  680. // }
  681. // BcdToHex(xx,xx);
  682. // Regist.proID =((sutProductPara.proID>>8)&0xff);
  683. // Regist.proID =(sutProductPara.proID&0xff);
  684. // Regist.proID=(sutProductPara.proID/16*10)+(sutProductPara.proID%16);//BCD转16进制
  685. Regist.proID=(sutProductPara.proID/10*16)+(sutProductPara.proID%10);//16进制转BCD
  686. // Regist.proID='0'|(sutProductPara.proID>>4);//
  687. // Regist.proID='0'|(sutProductPara.proID&0x0F);
  688. // sprintf(buf1,"proID=%d;\r\n",Regist.proID);
  689. // SlwTrace(INF,buf1);
  690. data1=sutProductPara.CityID/100;
  691. data3=(data1/10*16)+(data1%10);
  692. data2=sutProductPara.CityID%100;
  693. data4=(data2/10*16)+(data2%10);
  694. Regist.CityID = ((data4>>24)&0xffff);
  695. Regist.CityID = ((data4>>16)&0xffff);
  696. Regist.CityID = ((data3>>8)&0xffff);
  697. Regist.CityID = (data3&0xffff);
  698. for(i = 0; i < 5; i++){
  699. Regist.Manufacturers[i] = sutProductPara.Manufacturers[i];
  700. }
  701. for(i = 0; i < 20; i++){
  702. sscanf(sutProductPara.TerMod+2*i,"%2x",&Table1[i]);
  703. Regist.TerMod[i]= Table1[i];
  704. }
  705. // for(i=0;i<14;i+=2)
  706. // {
  707. // Regist.TerID[i/2]=(sutProductPara.TerID[i]<<4)|(sutProductPara.TerID[i+1]&0x0F);
  708. // }
  709. for(i = 0; i < 7; i++){
  710. sscanf(sutProductPara.TerID+2*i,"%2x",&Temp1[i]);
  711. Regist.TerID[i]= Temp1[i];
  712. }
  713. // sprintf(buf1,"TerID=%s;\r\n",sutProductPara.TerID);
  714. // SlwTrace(INF,buf1);
  715. Regist.PlateColor=sutProductPara.PlateColor;//
  716. for(i = 0; i < 8; i++){//16
  717. sscanf(sutProductPara.Plate+2*i,"%2x",&Temp[i]);
  718. Regist.Plate[i] = Temp[i];
  719. }
  720. PacketLen=TSGpsPacket(SendBuf,sutProductPara.PSN,TS_TERMINAL_REGISTRATION,(unsigned char *)&Regist,sizeof(REGISTRATION));
  721. MC8332ModemSendTcpData(0,SendBuf,PacketLen);
  722. }
  723. void SwitchGroupCtrl(void)
  724. {
  725. if(m_GroupSwitch)
  726. {
  727. if(++m_GroupSwitchCnt >=5)
  728. {
  729. //MeSpeak(ENCODE_GBK, "CDCBB3F6", 0);
  730. if(sutUIstatus.Status == UIS_STANDBY)
  731. ShowButton(1,107,"菜单");
  732. m_GroupSwitch=0;
  733. SlwTrace(INF, "QuitGroupSel",1);
  734. }
  735. }
  736. }
  737. void SwitchGroupPre(void)
  738. {
  739. //让菜单变成:确定
  740. ShowButton(1,107,"确定");
  741. m_GroupSwitch=1;
  742. m_GroupSwitchCnt=0;
  743. }
  744. volatile unsigned int pttPressFreeCt;
  745. /***********************************************************************
  746. *按键按下事件
  747. ************************************************************************/
  748. void KeyPress(void)
  749. {
  750. char buf[30];
  751. static unsigned char sucReportFlag=0;
  752. if(g_ucGtMode==0){//在GT模式下不能与串口同时发送AT指令会冲突,导致重启
  753. UI_Key();
  754. }
  755. switch(g_ulKeyValue){
  756. //-------------------------------------------------------------------
  757. case KEY_PPT_MIC:
  758. case KEY_PPT://=====================KEY_PPT Press====================
  759. g_ucKeyMode=1;//单次模式
  760. SlwTrace(INF,"[KEY_PPT/KEY_PPT_MIC Press]",1);
  761. sutPocStatus.PPTpress=1;
  762. if((g_ucGtMode==0)&&(g_ucCallPhonePro==0))
  763. {
  764. pttPressFreeCt=os_time_get()+40;
  765. ModemSendAT(POC_CMD_PPT_START);//
  766. //SlwTrace(INF, "Speak",1);
  767. }
  768. break;
  769. //-------------------------------------------------------------------
  770. case KEY_INFO://=====================KEY_UP Press==================
  771. g_ucKeyMode=1;//单次模式
  772. SlwTrace(INF,"[KEY_UP Press]",1);
  773. if((g_ucGtMode==0)&&(g_ucCallPhonePro==0)&&(sutUIstatus.Status == UIS_STANDBY)&&(sutPocStatus.Logined))
  774. {
  775. ModemSendAT(POC_CMD_UP);
  776. SwitchGroupPre();
  777. }
  778. break;
  779. case KEY_FUNC://=====================KEY_DOWN Press=================
  780. g_ucKeyMode=1;//单次模式
  781. SlwTrace(INF,"[KEY_DOWN Press]",1);
  782. if((g_ucGtMode==0)&&(g_ucCallPhonePro==0)&&(sutUIstatus.Status == UIS_STANDBY)&&(sutPocStatus.Logined))
  783. {
  784. ModemSendAT(POC_CMD_DOWN);
  785. SwitchGroupPre();
  786. }
  787. break;
  788. case KEY_PANEL_OK://=====================KEY_PANEL_OK Press=================
  789. if(sutUIstatus.Status == UIS_STANDBY && m_GroupSwitch==0)
  790. UISetNextStatus(UIS_MENU_GROUP_SEL);
  791. break;
  792. case KEY_PANEL_MENU://=====================KEY_PANEL_MENU Press=================
  793. if(m_GroupSwitch)
  794. {//
  795. m_GroupSwitch=0;
  796. snprintf(buf, sizeof(buf),"AT+POC=090000%s\r\n",sutPocStatus.switchGroupID);
  797. ModemSendAT(buf);
  798. ShowButton(1,107,"菜单");
  799. SlwTrace(INF, buf,0);
  800. }
  801. SlwTrace(INF,"[KEY_PANEL_MENU Press]",1);
  802. break;
  803. case KEY_PANEL_EXIT://=====================KEY_PANEL_EXIT Press=================
  804. SlwTrace(INF,"[KEY_PANEL_EXIT Press]",1);
  805. break;
  806. case KEY_PANEL_UP://=====================KEY_PANEL_UP Press=================
  807. SlwTrace(INF,"[KEY_PANEL_UP Press]",1);
  808. break;
  809. case KEY_PANEL_DOWN://=====================KEY_PANEL_DOWN Press=================
  810. SlwTrace(INF,"[KEY_PANEL_DOWN Press]",1);
  811. break;
  812. case KEY_EXIT_DOWN_GT://=====================KEY_UP_OK_GT Press=================
  813. // EnterGTMode();
  814. SlwTrace(INF,"[KEY_EXIT_DOWN_GT Press]",1);
  815. break;
  816. case KEY_P1_P3_UPDATE:
  817. SlwTrace(INF, "[KEY_P1_P3_UPDATE Press]",1);
  818. break;
  819. case KEY_OK_DOWN_GPS:
  820. SlwTrace(INF, "[KEY_OK_DOWN_GPS Press]",1);
  821. break;
  822. case KEY_OPTION:
  823. sutConfig.g_usOptionCnt++;
  824. //在待机界面按一下'S'键,网络允许情况下发SOS消息
  825. if(sutGpsInfo.isGpsAuthOk==1 && sutUIstatus.Status==UIS_STANDBY && g_ucModemTaskEn==1)
  826. {
  827. if(sutConfig.g_usOptionCnt ==3)
  828. TS_SendSOSMessage();
  829. }
  830. SlwTrace(INF, "[KEY_OPTION Press]",1);
  831. break;
  832. }
  833. }
  834. //长按 EXIT和下箭头3秒,只进入一次
  835. void GTMode_Detected(void)
  836. {
  837. static char GT_Flag=0;
  838. if(GT_Flag == 2) return;
  839. if(g_ulKeyValue == KEY_EXIT_DOWN_GT)
  840. {
  841. if(GT_Flag == 0)
  842. {
  843. g_ucUKC=0;
  844. GT_Flag ++;
  845. }else
  846. {
  847. if(g_ucUKC>3){
  848. EnterGTMode();
  849. GT_Flag++;
  850. }
  851. }
  852. }else
  853. {
  854. if(GT_Flag == 1)
  855. GT_Flag = 0;
  856. }
  857. }
  858. void UpdataAppVersion(void)
  859. {
  860. //正旋1格后松开,升级应用版本
  861. SpeakerEnable();
  862. ModemSendAT("AT+ZTTS=1,\"C6510759F466B065945E287548722C67F78B73513A678D51005F3A67\"\r"); //准备更新应用版本,请关机再开机
  863. SlwTrace(INF,"Update APP Version!",1);
  864. SetLedStatus(RedFastFlash);
  865. sutProductPara.IapFlag=0x55;
  866. SaveProductParaToFlash("MAIN-UP");
  867. while(1){
  868. IWDG_ReloadCounter();//喂狗
  869. os_dly_wait(1);
  870. if(OnOffCheck()){
  871. PWR_EN_LOW;
  872. }
  873. }
  874. }
  875. void UpdataPocVersion(void)
  876. {
  877. SpeakerEnable();
  878. ModemSendAT("AT+POC=10000018\r\n");
  879. SlwTrace(INF,"Update POC Version!",1);
  880. }
  881. void EnterGTMode(void)
  882. {
  883. g_ucModemTaskEn=0;
  884. SpeakerEnable();
  885. SetBeep(1176,10);
  886. os_dly_wait(20);
  887. SpeakerEnable();
  888. SetBeep(878,10);
  889. os_dly_wait(20);
  890. SpeakerEnable();
  891. SetBeep(1176,10);
  892. g_ucUART1RxMode=1;
  893. Uart1RxEnable(1);
  894. LedProcess(1);
  895. SetLedStatus(RedBlueFastFlash);
  896. SlwTrace(INF,"[EnterTxMode]",1);
  897. }
  898. /***********************************************************************
  899. *按键释放事件
  900. ************************************************************************/
  901. void KeyFree(void)
  902. {
  903. int i;
  904. char CheckCode[10];
  905. char buf[30];
  906. int flag;
  907. SUT_MODEM_AT_MSG *pMsg;
  908. unsigned int temp;
  909. char pressFlag;
  910. //-------------------------------------------------------------------
  911. if(KEY_PPT==g_ulKeyValue || KEY_PPT_MIC == g_ulKeyValue)
  912. {//===============KEY_PPT Free=============
  913. SlwTrace(INF,"[KEY_PPT/KEY_PPT_MIC Free]",1);
  914. g_ucKeyPPTPress=0;
  915. sutPocStatus.PPTpress=0;
  916. if((g_ucGtMode==0)&&((g_ucCallPhonePro==0)))
  917. {
  918. //#error "这里好了,发杨测试看看,等VPDN测试完一次发"
  919. //os_dly_wait(25);
  920. if(os_time_get() > pttPressFreeCt)
  921. {//按放间隔足够长了,只延时20即可
  922. temp=20;//防止释放太快,导致对方有可能听不到最后一个字
  923. }else{
  924. //按放间隔太短,补足30
  925. temp=pttPressFreeCt-os_time_get();
  926. }
  927. os_dly_wait(temp);
  928. ModemSendAT(POC_CMD_PPT_STOP);//结束讲话 放开PPT键
  929. g_ucKeyMode=0;
  930. }
  931. }else if(KEY_INFO==g_ulKeyValue)
  932. {//=========KEY_UP Free==============
  933. SlwTrace(INF,"[KEY_UP Free]",1);
  934. g_ucKeyMode=0;
  935. g_uikey_up_stat=1;
  936. }else if(KEY_FUNC==g_ulKeyValue)
  937. {//=========KEY_DOWN Free============
  938. g_ucKeyMode=0;
  939. SlwTrace(INF,"[KEY_DOWN Free]",1);
  940. }
  941. else if(KEY_PANEL_OK==g_ulKeyValue)
  942. {//=========KEY_PANEL_OK Free==============
  943. SlwTrace(INF,"[KEY_PANEL_OK Free]",1);
  944. return;
  945. }
  946. else if(KEY_PANEL_MENU==g_ulKeyValue)
  947. {//=========KEY_PANEL_MENU Free==============
  948. SlwTrace(INF,"[KEY_PANEL_MENU Free]",1);
  949. return;
  950. }
  951. else if(KEY_PANEL_EXIT==g_ulKeyValue)
  952. {//=========KEY_PANEL_EXIT Free==============
  953. g_uikey_up_stat=0;
  954. SlwTrace(INF,"[KEY_PANEL_EXIT Free]",1);
  955. return;
  956. }
  957. else if(KEY_PANEL_UP==g_ulKeyValue)
  958. {//=========KEY_PANEL_UP Free============
  959. }
  960. else if(KEY_PANEL_DOWN==g_ulKeyValue)
  961. {//=========KEY_PANEL_DOWN Free============
  962. }
  963. else if(KEY_EXIT_DOWN_GT==g_ulKeyValue)
  964. {//=====================KEY_EXIT_DOWN_GT Press=================
  965. g_ulKeyValue=0;
  966. SlwTrace(INF,"[KEY_EXIT_DOWN_GT Free]",1);
  967. }else if(KEY_OPTION == g_ulKeyValue)
  968. {
  969. sutConfig.g_usOptionCnt=0;
  970. SlwTrace(INF,"[KEY_OPTION Free]",1);
  971. }
  972. }
  973. #if(USE_CONFIG_FUN==1)
  974. void ConfigModeDetect(void)
  975. {//检测进入配置服务器功能
  976. //GT模式下
  977. //长按OPTION键
  978. char buf[20];
  979. unsigned char timeout=150;
  980. if(0 != g_ucModemTaskEn) return;
  981. if(sutConfig.g_ubConfigFlag==0)
  982. {
  983. if(sutConfig.g_usOptionCnt ==5)
  984. {
  985. sutConfig.g_ubConfigFlag=1;
  986. sutConfig.g_usOptionCnt=0;
  987. snprintf(buf, sizeof(buf), "AT+TCPCLOSE=%d\r\n", GPS_DATA_SOCKET);
  988. ModemSendAT(buf);
  989. SlwTrace(INF, "ConfigModeActive",1);
  990. GuiShowBmp(30,34,"logo.bmp");
  991. GuiClearRect(0,55, LCD_WIDTH-1, 100);
  992. GuiShowStr(8, 65, "正在访问配置服务器",1);
  993. sutConfig.g_ucTcpRetryNum=CONFIG_TCP_RETRY_CNT;
  994. sutConfig.g_ucConfigStatus=0x01;//上报列表
  995. sutConfig.g_ubConfigFinished=0;//
  996. tcpControl=2;
  997. }
  998. }
  999. }
  1000. #endif
  1001. void apnUpdateFun(void)
  1002. {
  1003. int len;
  1004. char buf1[400];
  1005. char *pMsg;
  1006. if(apnUpdateFlag!=1) return;
  1007. apnUpdateFlag=0;
  1008. len=HgsApnLen;
  1009. if(HgsApnLen > sizeof(buf1)) len=sizeof(buf1);
  1010. len=ReadFileData(ApnFileIndex,0,len,(u8*)buf1);
  1011. if(len==0) return;
  1012. pMsg=strstr(buf1,"APN4=");
  1013. if(0==pMsg) return;
  1014. sprintf(pMsg+5, "%s,%s;\r\n",showApnTable[6],showApnTable[7]);
  1015. ModifyFileData(ApnFileIndex, 0, strlen(buf1), (unsigned char *)buf1);
  1016. }
  1017. void cmdShutDown(char type)
  1018. {
  1019. static short cntDown;
  1020. static char ttype;
  1021. char buf[30];
  1022. ttype=type;
  1023. SlwTrace(INF, "Try to PwrOff",1);
  1024. ModemSendAT("AT$QCPWRDN\r\n");
  1025. for(cntDown=6;cntDown>=0;cntDown--)
  1026. {
  1027. switch(ttype)
  1028. {
  1029. case 0:snprintf(buf, sizeof(buf), "正在关机[%d]", cntDown);break;
  1030. case 1:snprintf(buf, sizeof(buf), "低压关机[%d]", cntDown);break;
  1031. default:return;
  1032. }
  1033. ShowMessageBox(buf);
  1034. SlwTrace(INF, buf, 1);
  1035. IWDG_ReloadCounter();
  1036. os_dly_wait(100);
  1037. }
  1038. }
  1039. void PowerOffProtetion(void)
  1040. {
  1041. if(modemPwrOffNow==0) return;
  1042. LCDTimeOut(0);
  1043. GPS_PWREN_LOW;
  1044. cmdShutDown(0);
  1045. PWR_EN_LOW;
  1046. while(1);
  1047. }
  1048. unsigned int bootMapCnt=0;
  1049. unsigned char bootFlag=0;
  1050. /*******************************************************************
  1051. *MainTask
  1052. *主任务
  1053. ********************************************************************/
  1054. __task void MainTask(void)
  1055. {
  1056. int BeepFlag=0;
  1057. int KeyFlag,GTKeystat=0;
  1058. int RealTime;
  1059. int FileIndex,SMSIndex;
  1060. char *msg;
  1061. INT8U err;
  1062. unsigned char ucCheckVbatCt=0;
  1063. static unsigned int sucCt=0;
  1064. static unsigned char sucFunReportFlag=0;
  1065. unsigned short g_usModemProtectEn;
  1066. int Vbat;
  1067. RunMake(THIS_FILE_ID);
  1068. //Obtain own system task identification number. */
  1069. idMainTask = os_tsk_self();
  1070. memset((unsigned char *)&sutPocStatus,0,sizeof(SUT_POC_STATUS));
  1071. //开机提示音
  1072. SpeakerEnable();
  1073. os_dly_wait(10);
  1074. SetBeepByNoOS(888,100);
  1075. SpeakerDisable();
  1076. //Read Product param from flash
  1077. ReadProductParaFromFlash();
  1078. APNFileInit();
  1079. printf("\r\n%s_V%d.%d Start...\r\n",sutProductPara.ProductName,sutProductPara.ProductVersion,INTER_VER);
  1080. printf("PSN:%lu\r\n",sutProductPara.PSN);
  1081. g_ucUpdataVer=0;
  1082. SlwTrace(INF,"Main Task Start!",1);
  1083. //LCD设置参数初始化
  1084. FileIndex=GetFileIndex("LcdParam.ini");
  1085. ReadFileData(FileIndex,0,sizeof(SUT_LCD_PARAM),(unsigned char *)&sutLcdParam);
  1086. if(sutLcdParam.OnTimeIndex > 4){
  1087. sutLcdParam.OnTimeIndex = 0;
  1088. sutLcdParam.OnTime=10;
  1089. ModifyFileData(FileIndex,0,sizeof(SUT_LCD_PARAM),(unsigned char *)&sutLcdParam);
  1090. //到此,说明是重新烧代码了,则初始化GPS为默认值
  1091. sutProductPara.m_GPS_TimeIndex = DEFAULT_GPS_SEND_TIME_INDEX;
  1092. GpsTimeUpdate();
  1093. SaveProductParaToFlash("MAIN-PARA");
  1094. }
  1095. sutLcdParam.OnTimeCt = 0;
  1096. //电话本
  1097. SetPhoneNumFile("HGS.Tell");
  1098. //短信
  1099. SetMessageConfi();
  1100. //SetCodePara();
  1101. LedInit();
  1102. SlwTrace(INF,"Led Init...",1);
  1103. g_iFun2KeyEncodeCt=0;
  1104. bootMapCnt=os_time_get()+2000;//开机界面持续20秒
  1105. //create PocTask
  1106. idModemUartTask=os_tsk_create_user(ModemUartTask,3,&stkModemUartTask,sizeof(stkModemUartTask));
  1107. idModemTask=os_tsk_create_user(ModemTask,3,&stkModemTask,sizeof(stkModemTask));
  1108. idTTSTask=os_tsk_create_user(TTSTask, 3, &stkTTSTask,sizeof(stkTTSTask));
  1109. RunMake(THIS_FILE_ID);
  1110. UI_Init();
  1111. while(1)
  1112. {
  1113. if(bootFlag==0)
  1114. {
  1115. if((os_time_get() > bootMapCnt) || sutPocStatus.FirstLogined)
  1116. bootFlag=1;
  1117. }
  1118. PowerOffProtetion();
  1119. if(bootFlag==1)
  1120. UI_Loop();
  1121. os_dly_wait(1);
  1122. IncomingSMS();
  1123. //处理PC发送过来的消息
  1124. RunMake(THIS_FILE_ID);
  1125. if(g_usUart1RecvLen){
  1126. PcMsgHandle((char *)RxBuffer1);
  1127. g_usUart1RecvLen=0;
  1128. DMA1_Channel5->CNDTR = UART1_RX_BUFFER_SIZE;//重设DMA传输数据长度
  1129. DMA_Cmd(DMA1_Channel5,ENABLE);//打开DMA
  1130. }
  1131. RunMake(THIS_FILE_ID);
  1132. apnUpdateFun();
  1133. //键盘处理
  1134. if(0!=(KeyFlag=GetKey())){
  1135. //按键处理
  1136. if(1==KeyFlag){ //按键按下
  1137. KeyPress();
  1138. //if(g_ulKeyValue != KEY_PPT &&
  1139. // g_ulKeyValue != KEY_PPT_MIC)
  1140. //{
  1141. LCDTimeOut(0);
  1142. sutLcdParam.OnTimeCt=0;
  1143. //}
  1144. }else{ //按键释放
  1145. KeyFree();
  1146. }
  1147. }
  1148. RunMake(THIS_FILE_ID);
  1149. //LED处理
  1150. LedProcess(0);
  1151. #if(USE_CONFIG_FUN==1)
  1152. ConfigModeDetect();
  1153. #endif
  1154. GTMode_Detected();
  1155. //---以下控制每秒执行一次---
  1156. if(os_time_get() < sucCt) continue;
  1157. sucCt = os_time_get()+100;
  1158. ModemSendAT(" AT+MODODREX?\r\n");
  1159. // if(++sucCt>99)sucCt=0;
  1160. // else continue;
  1161. RunMake(THIS_FILE_ID);
  1162. KeyCount();//键盘按下、释放计数控制
  1163. RunMake(THIS_FILE_ID);
  1164. //信号
  1165. //测量电池电压
  1166. Vbat=GetVbat();
  1167. if(Vbat>0)g_iVbat=Vbat;
  1168. //判断电池电压是否过低关机
  1169. if(ucCheckVbatCt<3)ucCheckVbatCt++;
  1170. else CheckVbat(g_iVbat);
  1171. //MODEM防护
  1172. FingerDaemonfinger(); //3.21关闭
  1173. SwitchGroupCtrl();
  1174. if(sutLcdParam.OnTime>0){
  1175. if(++sutLcdParam.OnTimeCt>=sutLcdParam.OnTime){
  1176. sutLcdParam.OnTimeCt=0;
  1177. if(sutPocStatus.FirstLogined==1)//没登陆过(刚开机),LCD一直亮着
  1178. LCDTimeOut(1);
  1179. }
  1180. }
  1181. }
  1182. }
  1183. void ADCInit(void)
  1184. {
  1185. ADC_InitTypeDef ADC_InitStructure;
  1186. GPIO_InitTypeDef GPIO_InitStructure;
  1187. RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
  1188. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
  1189. GPIO_InitStructure.GPIO_Pin =GPIO_Pin_0;
  1190. GPIO_InitStructure.GPIO_Mode =GPIO_Mode_IPU;//先内部上拉模式给IO充能
  1191. GPIO_Init(GPIOA,&GPIO_InitStructure);
  1192. DelayMs(100);
  1193. GPIO_InitStructure.GPIO_Mode =GPIO_Mode_AIN;
  1194. GPIO_Init(GPIOA,&GPIO_InitStructure); //默认速度为两兆
  1195. DelayMs(200);//让电平恢复正常
  1196. //配置ADC的运行:
  1197. ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //独立模式
  1198. ADC_InitStructure.ADC_ScanConvMode =DISABLE; //连续多通道模式
  1199. ADC_InitStructure.ADC_ContinuousConvMode =DISABLE;//ENABLE; //连续转换
  1200. ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; //转换不受外界决定
  1201. ADC_InitStructure.ADC_DataAlign =ADC_DataAlign_Right; //右对齐
  1202. ADC_InitStructure.ADC_NbrOfChannel =1; //扫描通道数
  1203. ADC_Init(ADC1,&ADC_InitStructure);
  1204. ADC_RegularChannelConfig(ADC1,ADC_Channel_0, 1,ADC_SampleTime_1Cycles5); //通道X,采样时间为1.5周期,1代表规则通道第1个这个1是啥意思我不太清楚只有是1的时候我的ADC才正常。
  1205. ADC_Cmd (ADC1,ENABLE); //使能或者失能指定的ADC
  1206. ADC_SoftwareStartConvCmd(ADC1,ENABLE);//使能或者失能指定的ADC的软件转换启动功能
  1207. }
  1208. void GPIO_Config_ALL_AIN(void)
  1209. {
  1210. GPIO_InitTypeDef GPIO_InitStructure;
  1211. /* Enable GPIOD and GPIOE clock */
  1212. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB
  1213. | RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD
  1214. | RCC_APB2Periph_AFIO, ENABLE);
  1215. /* Disable the Serial Wire Jtag Debug Port SWJ-DP */
  1216. GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, ENABLE);
  1217. /* PA */
  1218. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All;
  1219. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
  1220. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  1221. GPIO_Init(GPIOA, &GPIO_InitStructure);
  1222. /* PB */
  1223. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All;
  1224. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  1225. GPIO_Init(GPIOB, &GPIO_InitStructure);
  1226. /* PC */
  1227. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All;
  1228. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  1229. GPIO_Init(GPIOC, &GPIO_InitStructure);
  1230. /* PD */
  1231. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All;
  1232. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  1233. GPIO_Init(GPIOD, &GPIO_InitStructure);
  1234. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA
  1235. | RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD
  1236. , DISABLE);
  1237. }
  1238. /***********************************************************************
  1239. *获取电池电压
  1240. 返回值: -1为无效 ; 正数表示电池电压放大100倍,如 382表示3.82V
  1241. ***********************************************************************/
  1242. int GetVbat(void)
  1243. {
  1244. char buf[30];
  1245. static int Ct=0;
  1246. static int siVbat[10]={0,0,0,0,0,0,0,0,0,0};
  1247. int iVbat[10];
  1248. int max[5];
  1249. int sum;
  1250. int i,j,k;
  1251. int adc;
  1252. int Vbat;
  1253. #if 1
  1254. ADC_SoftwareStartConvCmd(ADC1,ENABLE);
  1255. while(ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET);
  1256. adc=ADC_GetConversionValue(ADC1);
  1257. if(adc<100 && adc>4095)
  1258. {
  1259. printf("VDAC OVER");
  1260. return -1;
  1261. }
  1262. #else
  1263. //采集ADC
  1264. if(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC)!=RESET){//检查制定ADC标志位置1与否 ADC_FLAG_EOC 转换结束标志位 if(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC)!=RESET){
  1265. ADC_SoftwareStartConvCmd(ADC1,ENABLE);
  1266. adc=ADC_GetConversionValue(ADC1);
  1267. if(adc<100 && adc>4095)
  1268. {
  1269. //printf("ERR1");
  1270. return -1;
  1271. }
  1272. }else
  1273. {
  1274. printf("ERR2");
  1275. return -1;
  1276. }
  1277. #endif
  1278. //循环存储
  1279. siVbat[Ct]=adc;
  1280. if(++Ct>9)Ct=0;
  1281. //printf("%d,%d,%d,%d,%d,%d,%d,%d,%d,%d\r\n",siVbat[0],siVbat[1],siVbat[2],siVbat[3],siVbat[4],siVbat[5],siVbat[6],siVbat[7],siVbat[8],siVbat[9]);
  1282. //滤波处理,排列取3个最大值,3个最大中去掉第一大,其余求平均
  1283. //拷贝
  1284. for(i=0;i<10;i++){
  1285. iVbat[i]=siVbat[i];
  1286. }
  1287. for(i=0;i<4;i++){
  1288. max[i]=0;
  1289. for(j=0;j<10;j++){
  1290. if(iVbat[j]>max[i]){
  1291. max[i]=iVbat[j];
  1292. k=j;
  1293. }
  1294. }
  1295. iVbat[k]=0;
  1296. }
  1297. // printf("%d,%d,%d\r\n",max[0],max[1],max[2]);
  1298. sum=max[1]+max[2];
  1299. if(max[2]<200)
  1300. {
  1301. //printf("ERR3");
  1302. return -1;
  1303. }
  1304. Vbat=sum*308/4096;
  1305. return Vbat;
  1306. }
  1307. void Sys_Standby(void)
  1308. {
  1309. RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE); //使能PWR外设时钟
  1310. PWR_WakeUpPinCmd(ENABLE); //使能唤醒管脚功能,PA0
  1311. PWR_EnterSTOPMode(PWR_Regulator_LowPower,PWR_STOPEntry_WFI);
  1312. }
  1313. /*******************************************************
  1314. *CheckVbat
  1315. *检查电池电压,控制低压报警,
  1316. *低压关机已由硬件监测
  1317. ******************************************************/
  1318. void CheckVbat(int Vbat)
  1319. {
  1320. static unsigned char sucCt=0;//提示“请充电”计数器
  1321. if(Vbat<MIN_PWR_LEVEL){//300
  1322. SlwTrace(INF,"Vbat low!shutdown now!",1);
  1323. os_dly_wait(1);
  1324. //关闭模块
  1325. if(sutPocStatus.ModemPowerOn==1){
  1326. #if 1
  1327. //发送机指令并等待7秒
  1328. cmdShutDown(1);
  1329. #else
  1330. SpeakerEnable();
  1331. ModemSendAT("AT+LSHTTSSTP\r\n");
  1332. os_dly_wait(30);
  1333. ModemSendAT("AT+LSHTTS=1,\"B5CDD1B9B4FDBBFA\"\r\n");//低压待机
  1334. IWDG_ReloadCounter();
  1335. os_dly_wait(100);
  1336. IWDG_ReloadCounter();
  1337. os_dly_wait(100);
  1338. SlwTrace(INF,"ModemPoweroff!",1);
  1339. ModemPoweroff();
  1340. #endif
  1341. }
  1342. sutPocStatus.ModemPowerOn=0;
  1343. PWR_EN_LOW;
  1344. Sleeping();
  1345. }else if(Vbat<WARN_PWR_LEVEL){//提示请充电 315
  1346. if(++sucCt>30){
  1347. sucCt=0;
  1348. //MeSpeak(ENCODE_GBK, "C7EBB3E4B5E7",0);//请充电
  1349. }
  1350. }else sucCt=0;
  1351. }
  1352. void GetXinHao(int CSQ,char *XinHao)
  1353. {
  1354. if(CSQ>31 || CSQ<1){
  1355. strcpy(XinHao,"2C00E065517FDC7EE14FF753");//无网络信号
  1356. }else if(CSQ>25){
  1357. //信号较强 "E14FF753838F3A5F"
  1358. strcpy(XinHao,"E14FF753838F3A5F");
  1359. }else if(CSQ>17){
  1360. //信号适中 "E14FF75302902D4E"
  1361. strcpy(XinHao,"E14FF75302902D4E");
  1362. }else if(CSQ>10){
  1363. //信号偏低 "E14FF7534F504E4F"
  1364. strcpy(XinHao,"E14FF7534F504E4F");
  1365. }else{
  1366. //信号很弱 "E14FF753885F315F"
  1367. strcpy(XinHao,"E14FF753885F315F");
  1368. }
  1369. }
  1370. void GetVbatPercent(int Vbat,char *Percent)
  1371. {
  1372. //10 20 30 40 50 60 70 80 90 100
  1373. const char *ccPercent[]={
  1374. "31003000",
  1375. "32003000",
  1376. "33003000",
  1377. "34003000",
  1378. "35003000",
  1379. "36003000",
  1380. "37003000",
  1381. "38003000",
  1382. "39003000",
  1383. "310030003000"};
  1384. //播报电量百分比 10,20,30, 40, 50, 60, 70, 80, 90,100
  1385. const int siVbat[] ={335,343,350,360,370,377,384,392,400,500};
  1386. int i;
  1387. for(i=0;i<10;i++){
  1388. if(Vbat<siVbat[i])break;
  1389. }
  1390. if(i>9)i=9;
  1391. strcpy(Percent,ccPercent[i]);
  1392. }
  1393. /****************************************************************
  1394. *语音播报 电量、信号、GPS
  1395. *****************************************************************/
  1396. void ReportVbatCsqGps(void)
  1397. {
  1398. unsigned char GpsFlag;
  1399. //电量百分之N,信号强,GPS已登陆已定位
  1400. char buf[30];
  1401. SpeakerEnable();
  1402. ModemSendAT("AT+ZTTS=1,");
  1403. ModemSendAT("\"3575CF917E7606524B4E");//电量百分之
  1404. GetVbatPercent(g_iVbat,buf);
  1405. ModemSendAT(buf); //10~100
  1406. GetXinHao(g_iCSQ,buf); // 信号
  1407. ModemSendAT(buf);
  1408. if(!sutGpsInfo.isGpsWork){
  1409. ModemSendAT("E065470050005300");//,无GPS
  1410. GpsFlag=0x00;
  1411. ModemSendAT("\"\r\n");
  1412. }else{
  1413. if(sutGpsInfo.isServerLogin){
  1414. ModemSendAT("470050005300F25D7B764696"); //,GPS已登陆
  1415. GpsFlag=0x20;
  1416. }else{
  1417. ModemSendAT("4700500053002A677B764696"); //,GPS未登陆
  1418. GpsFlag=0x10;
  1419. }
  1420. if(sutGpsInfo.isGpsValid){
  1421. ModemSendAT("F25D9A5B4D4F"); //已定位
  1422. GpsFlag |= 0x01;
  1423. }else{
  1424. ModemSendAT("2A679A5B4D4F"); //未定位
  1425. }
  1426. ModemSendAT("\"\r\n");
  1427. }
  1428. snprintf(buf,30,"Vbat=%d,CSQ=%d,GPS=%02x",g_iVbat,g_iCSQ,GpsFlag);
  1429. SlwTrace(INF,buf,1);
  1430. }
  1431. /***************************************************************************
  1432. 将数字转Unicode编码
  1433. pUnicode空间最长 5*4+1=21字节
  1434. ****************************************************************************/
  1435. void NumToUnicode(unsigned short Num,char *pUnicode)
  1436. {
  1437. char temp[6];
  1438. int i,j,len;
  1439. snprintf(temp, sizeof(temp),"%u",Num);//0~65535
  1440. len=strlen(temp);
  1441. j=0;
  1442. for(i=0;i<len;i++){
  1443. pUnicode[j++]=0x30+temp[i]/16;
  1444. pUnicode[j++]=0x30+temp[i]%16;
  1445. pUnicode[j++]=0x30;
  1446. pUnicode[j++]=0x30;
  1447. }
  1448. pUnicode[j]=0;
  1449. }
  1450. void ReportVersion(void)
  1451. {
  1452. char buf[150];
  1453. char temp[20];
  1454. snprintf(buf, sizeof(buf),"AT+ZTTS=1,\"945E287548722C67");
  1455. NumToUnicode(sutProductPara.ProductVersion,temp);
  1456. strcat(buf,temp);
  1457. strcat(buf,"2C00F95BB28B48722C67");
  1458. NumToUnicode((unsigned short)g_iModemVer,temp);
  1459. strcat(buf,temp);
  1460. strcat(buf,"\"\r\n");
  1461. SpeakerEnable();
  1462. ModemSendAT(buf);//应用版本
  1463. SlwTrace(INF,buf,0);
  1464. /*
  1465. SlwTrace(INF,"[ReportVersion]");
  1466. sprintf(buf,"Mcu=%u,Modem=%u\r\n",sutProductPara.ProductVersion,(unsigned short)g_iModemVer);
  1467. SlwTrace(INF,buf);
  1468. */
  1469. }
  1470. /*******************************************************************
  1471. *GetParaFromStr
  1472. *从Str中找到Para=后面至';'或非字符的字串并放入Value
  1473. 返回Value的长度
  1474. 举例:Str="GT+SMP=IP=192.168.1.1;Port=12345"
  1475. 如果Para="Port" 则Value将被赋值为"12345",并返回5
  1476. 如果Para="IP" 则Value将被赋值为"192.168.1.1",并返回11
  1477. 要求Para长度不大于20字节 ,Value长度不大于40字节
  1478. ********************************************************************/
  1479. int GetParaFromStr(char *Str,char *Para,char *Value)
  1480. {
  1481. int ValueLen=0,ParaLen=0;
  1482. char ParaTemp[22];
  1483. char *p;
  1484. char d;
  1485. int i=0;
  1486. if(0==*Str || 0==*Para)return 0;
  1487. while(0!=(d=*Para) && ParaLen<20){
  1488. ParaTemp[i++]=d;
  1489. if(d=='=' || d==';')return 0;
  1490. Para++;
  1491. ParaLen++;
  1492. }
  1493. ParaTemp[ParaLen++]='=';
  1494. ParaTemp[ParaLen]=0;
  1495. p=strstr(Str,ParaTemp);
  1496. p+=ParaLen;
  1497. //--
  1498. while(*p>0x20 && ';'!=*p && ValueLen<=80){
  1499. *Value=*p;
  1500. p++;
  1501. Value++;
  1502. ValueLen++;
  1503. }
  1504. *Value=0;
  1505. return ValueLen;
  1506. }
  1507. void IWDG_Configuration(unsigned int value)
  1508. {
  1509. // WWDG 时钟使能
  1510. RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);
  1511. if(RCC_GetFlagStatus(RCC_FLAG_IWDGRST) != RESET)RCC_ClearFlag();
  1512. //写入0x5555,用于允许狗狗寄存器写入功能
  1513. IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);
  1514. //狗狗时钟分频,40K/256=156HZ(6.4ms)
  1515. IWDG_SetPrescaler(IWDG_Prescaler_256);
  1516. //喂狗时间
  1517. //IWDG_SetReload(200);1.28s/6.4MS=200 .注意不能大于0xfff
  1518. IWDG_SetReload(value);//3.2s/6.4MS=500 .注意不能大于0xfff
  1519. //喂狗
  1520. IWDG_ReloadCounter();
  1521. //使能狗狗
  1522. IWDG_Enable();
  1523. }
  1524. /*
  1525. 此处修改:删去ModemSendAT("2C00");另外pocTask.cReplaceStrWithN(&msg[9]、msg[17]);强制将字符串后面的\n\r去掉
  1526. */
  1527. void ReportUserGroupName(void)
  1528. {
  1529. #if POC_USER_NAME_LEN>POC_GROUP_NAME_LEN
  1530. char buf[POC_USER_NAME_LEN*4];
  1531. #else
  1532. char buf[POC_GROUP_NAME_LEN*4];
  1533. #endif
  1534. SpeakerEnable();
  1535. ModemSendAT("AT+ZTTS=1,\"");
  1536. AnsiToStrUnicode((uint8_t *)buf,sizeof(buf),sutPocStatus.LocalUser.name); //函数功能未实现,需要修改
  1537. ModemSendAT(buf);
  1538. AnsiToStrUnicode((uint8_t *)buf,sizeof(buf),sutPocStatus.LocalUser.name);
  1539. ModemSendAT(buf);
  1540. ModemSendAT("\"\r");
  1541. }
  1542. void SetPowerEn(unsigned char en)
  1543. {
  1544. GPIO_InitTypeDef GPIO_InitStructure;
  1545. if(en!=0){
  1546. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC, ENABLE);
  1547. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  1548. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  1549. GPIO_InitStructure.GPIO_Pin = PWR_EN_PIN;
  1550. GPIO_Init(PWR_EN_PORT, &GPIO_InitStructure);
  1551. PWR_EN_HIGH;
  1552. }else{
  1553. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC, ENABLE);
  1554. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;
  1555. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  1556. GPIO_InitStructure.GPIO_Pin = PWR_EN_PIN;
  1557. GPIO_Init(PWR_EN_PORT, &GPIO_InitStructure);
  1558. PWR_EN_LOW;
  1559. }
  1560. }
  1561. /*****************************************************************************************
  1562. *函数名:GetCheckCodeByPsnMEID
  1563. *功能:根据PSN号和MEID码,生成伪随机码
  1564. *入口:PSN--PSN码,无符号长整形,必须是大于150000000的数值,有可能是9位数也可能是10位数
  1565. pMEID--MEID字串,长度14位或15位,第16字节必须为0。
  1566. *出口:pCheckCode:--长度为6的字符串,第7字节为结束符0x00,因此必须留够7字节的空间!
  1567. 返回:1--成功 0--因参数非法而失败
  1568. ******************************************************************************************/
  1569. const unsigned char sucRandTable[256]={
  1570. 0x68,0x59,0x63,0x64,0xc8,0xcc,0xaa,0xa7,0xa2,0xab,0xa5,0x6e,0x6a,0x56,0x8a,0x57,
  1571. 0xf4,0xbb,0xfe,0xfa,0x26,0x21,0x2d,0x29,0x0d,0x09,0x3e,0x3a,0x37,0x32,0x0a,0x07,
  1572. 0xf7,0xf2,0xfb,0xf5,0xff,0xf6,0x1c,0x18,0x13,0x14,0xf1,0xfd,0xf9,0x0c,0x9f,0x08,
  1573. 0x9a,0x97,0x92,0x9b,0x95,0x9f,0x12,0x1b,0x15,0x2c,0x28,0x23,0xf9,0x2a,0x27,0x22,
  1574. 0x24,0x2e,0x67,0x25,0x2f,0x98,0xfc,0x75,0xf8,0xf3,0x3c,0x38,0x33,0x34,0x03,0x04,
  1575. 0x05,0x0f,0x06,0x01,0x7a,0x77,0x72,0x62,0x6b,0x83,0x84,0x8e,0xc4,0xcb,0x87,0x82,
  1576. 0x35,0x3f,0x36,0x4f,0x3d,0x39,0x9c,0x98,0x93,0x94,0x42,0x4f,0x46,0x41,0x81,0x8d,
  1577. 0x4d,0x49,0x71,0x7d,0x79,0x96,0x91,0x9d,0x99,0xc3,0xc4,0x1d,0xce,0xca,0x7f,0x76,
  1578. 0x7c,0x78,0x73,0x74,0x7e,0x7b,0x75,0x1e,0x1a,0x17,0x1f,0x16,0x11,0x1d,0x47,0x19,
  1579. 0x5d,0xc7,0xc2,0xcb,0xc5,0xcf,0xd1,0xdd,0xd9,0x4c,0x48,0xc6,0xc1,0xcd,0x61,0xc9,
  1580. 0xd7,0x8c,0xfd,0x88,0xa1,0xad,0xa9,0xb1,0xbd,0xb9,0x8b,0x85,0x8f,0x4b,0x45,0x86,
  1581. 0xdc,0xd8,0xd3,0xd4,0xde,0xd2,0xdb,0xd5,0xdf,0xd6,0x43,0x44,0x4e,0x4a,0xe7,0x47,
  1582. 0xac,0xa8,0xa3,0xa4,0xae,0xba,0x0d,0xb7,0xb2,0xaf,0xa6,0xe4,0xee,0xea,0xe7,0xe2,
  1583. 0xe1,0xed,0x0f,0xe9,0x66,0x61,0x6d,0x69,0xbb,0xb5,0xbf,0xb6,0xec,0xe8,0x0b,0xe3,
  1584. 0x52,0x5c,0x65,0x6f,0x58,0x53,0x54,0x0c,0x5e,0x5b,0x55,0x5f,0x31,0x2f,0x9a,0x0b,
  1585. 0x0b,0x5a,0x2b,0x9e,0x02,0x89,0x59,0x3b,0x0e,0x51,0x6c,0xeb,0xda,0xe6,0x31,0xf6
  1586. };
  1587. int GetCheckCodeByPsnMEID(char *pCheckCode,unsigned long PSN,char *pMEID)
  1588. {
  1589. char aucPSN[12];
  1590. char aucMEID[16];
  1591. unsigned char key[10];
  1592. unsigned char temp1,temp2;
  1593. int MeidLen,PsnLen;
  1594. int i,j;
  1595. //PSN合法性检测
  1596. if(PSN<150100000)return 0;
  1597. //MEID合法性检测
  1598. MeidLen=strlen(pMEID);
  1599. //if(MeidLen!=14 && MeidLen!=15)return 0; //MEID号长度必须为14或15
  1600. if(MeidLen!=14 && MeidLen!=15){
  1601. snprintf(aucPSN, sizeof(aucMEID),"%015lu",pMEID); //不够15位前面补零
  1602. }
  1603. //PSN转字符串,不够10位的前面补'0'
  1604. snprintf(aucPSN, sizeof(aucPSN),"%010lu",PSN);
  1605. PsnLen=strlen(aucPSN);
  1606. //取MEID的最后10个字符
  1607. j=0;
  1608. for(i=(MeidLen-10);i<MeidLen;i++){
  1609. aucMEID[j]=pMEID[i];
  1610. j++;
  1611. }
  1612. //所有字节进行相互异或运算,使每个字节的变化对整体结果都敏感
  1613. temp1=0;
  1614. temp2=0;
  1615. for(i=0;i<10;i++){
  1616. temp1^=(unsigned char)aucPSN[i];
  1617. temp2^=(unsigned char)aucMEID[i];
  1618. }
  1619. temp1^=temp2;
  1620. temp2=sucRandTable[temp1];
  1621. //循环查表异或运算,生成key
  1622. for(i=0;i<10;i++){
  1623. temp1=aucPSN[i]^temp2;
  1624. key[i]=aucMEID[i]^temp1;
  1625. temp2=sucRandTable[temp1];
  1626. }
  1627. //取最后6个key,分别除10取余后再转Ascii,作为结果,结果为6个数字串,如"123456"
  1628. j=0;
  1629. for(i=4;i<10;i++){
  1630. pCheckCode[j]=key[i]%10;
  1631. pCheckCode[j]+=0x30;
  1632. j++;
  1633. }
  1634. pCheckCode[6]=0; //结束符,方便调试打印和语音播报。
  1635. return 1;
  1636. }
  1637. //使用12位唯一ID生成唯一7位(14位)鉴权码
  1638. void makeAuthCode(unsigned char *auth)
  1639. {
  1640. unsigned char i,temp1,temp2;
  1641. unsigned char tempAuth[14]="hS";//前面设置成唯一的
  1642. unsigned char srcId[12];
  1643. GetSTM32ID(srcId);
  1644. temp1=0;
  1645. for(i=0;i<12;i++)
  1646. {
  1647. temp1 ^= srcId[i];
  1648. temp1 ^= i;
  1649. }
  1650. memcpy(&tempAuth[2], srcId, 12);
  1651. for(i=0;i<14;i++)
  1652. {
  1653. temp2 = tempAuth[i] ^ sucRandTable[temp1];
  1654. tempAuth[i] = temp1 ^ temp2;
  1655. }
  1656. //组合成7个字节内容
  1657. AscStrToHexStr(tempAuth, auth);
  1658. }
  1659. /***************************************************************************
  1660. 将数字串转Unicode编码,方便播报
  1661. pUnicode长度必须为pNum长度的8倍,否则内存溢出!
  1662. ****************************************************************************/
  1663. void NumStrToUnicode(char *pNum,char *pUnicode)
  1664. {
  1665. char temp[10];
  1666. int i,j,len;
  1667. len=strlen(pNum);
  1668. snprintf(temp, sizeof(temp),"len=%d",len);
  1669. SlwTrace(INF,temp,1);
  1670. j=0;
  1671. for(i=0;i<len;i++){
  1672. pUnicode[j++]='3';
  1673. pUnicode[j++]=pNum[i];
  1674. pUnicode[j++]='0';
  1675. pUnicode[j++]='0';
  1676. if(i==(len-1))break;//最后一个不用加逗号‘,’
  1677. //","
  1678. pUnicode[j++]='2';
  1679. pUnicode[j++]='0';
  1680. pUnicode[j++]='0';
  1681. pUnicode[j++]='0';
  1682. }
  1683. pUnicode[j]=0;
  1684. }
  1685. /**************************************************************
  1686. *ReportCheckCode
  1687. ***************************************************************/
  1688. void ReportCheckCode(void)
  1689. {
  1690. char temp[12];
  1691. char buf[80];
  1692. SpeakerEnable();
  1693. //终端编号xxxx
  1694. if(sutProductPara.PSN<150100000 || sutProductPara.PSN==0xffffffff){
  1695. SlwTrace(INF,"PSN Error!",1);
  1696. ModemSendAT("AT+ZTTS=1,\"C87EEF7A167FF7531995EF8B\"\r");//终端编号错误
  1697. return;
  1698. }
  1699. //校验码xxxx
  1700. if(GetCheckCodeByPsnMEID(temp,sutProductPara.PSN,sutProductPara.IMEI)){
  1701. snprintf(buf, sizeof(buf),"CheckCode=%s",temp);
  1702. SlwTrace(INF,buf,1);
  1703. NumStrToUnicode(temp,buf);
  1704. ModemSendAT("AT+ZTTS=1,\"21688C9A01782C00");//校验码,
  1705. ModemSendAT(buf);
  1706. ModemSendAT("\"\r");
  1707. }else{
  1708. SlwTrace(INF,"CheckCode=NULL",1);
  1709. ModemSendAT("AT+ZTTS=1,\"21688C9A0178B783D6533159258D\"\r");//校验码获取失败
  1710. }
  1711. IWDG_ReloadCounter();//喂狗
  1712. os_dly_wait(100);
  1713. IWDG_ReloadCounter();//喂狗
  1714. os_dly_wait(100);
  1715. IWDG_ReloadCounter();//喂狗
  1716. os_dly_wait(100);
  1717. IWDG_ReloadCounter();//喂狗
  1718. //终端编码xxx
  1719. snprintf(temp, sizeof(temp),"%lu",sutProductPara.PSN);
  1720. snprintf(buf, sizeof(buf),"CheckCode=%s",temp);
  1721. SlwTrace(INF,buf,1);
  1722. NumStrToUnicode(temp,buf);
  1723. ModemSendAT("AT+ZTTS=1,\"C87EEF7A167FF7532C00");//终端编码,
  1724. ModemSendAT(buf);
  1725. ModemSendAT("\"\r");
  1726. }
  1727. /************************************************************************************
  1728. ResetModem
  1729. *************************************************************************************/
  1730. void ResetModem(void)
  1731. {
  1732. //set modem reset
  1733. MODEM_RESET_HIGH;
  1734. os_dly_wait(100);
  1735. MODEM_RESET_LOW;
  1736. MODEM_PWRKEY_HIGH;
  1737. os_dly_wait(100);
  1738. MODEM_PWRKEY_LOW;
  1739. //set uart3 reset
  1740. Uart3Init();
  1741. }
  1742. /*************************************************************************************
  1743. *FingerDaemonfinger
  1744. *守护进程
  1745. *用于防止通讯模块死机,或者与通讯模块通讯的串口异常而重新启动模块或通讯驱动。
  1746. *用于防止GPS模块异常而重启GPS
  1747. *此函数需要确保每秒调用一次
  1748. 入口参数
  1749. sutPocStatus.FirstLogined
  1750. sutPocStatus.PocLostCt
  1751. sutPocStatus.ModemPowerOn
  1752. sutPocStatus.ModemInactiveCt
  1753. g_iCSQ
  1754. **************************************************************************************/
  1755. void FingerDaemonfinger(void)
  1756. {
  1757. static unsigned char sucPocLostTimeoutCount=0;//
  1758. static unsigned char sucModemInactiveCount=0;
  1759. unsigned short PocLostCtMax;
  1760. IWDG_ReloadCounter();//喂狗
  1761. //return;
  1762. if(g_ucModemTaskEn==0)return;
  1763. //如果曾经登陆过POC系统,然后离线,开始计数,直到再次登陆,如果一直不登陆超过一定时间,则重启模块和串口
  1764. if(sutPocStatus.FirstLogined){
  1765. if(sutPocStatus.Logined==0){
  1766. // if(g_iCSQ<5 || g_iCSQ==99){//如果信号不好
  1767. // PocLostCtMax=180;//等待时间为3分钟
  1768. // }else{//如果信号还行
  1769. // PocLostCtMax=60;//等待时间为1分钟
  1770. // }
  1771. PocLostCtMax=pocTimeOutTime*60;
  1772. if(++sutPocStatus.PocLostCt>PocLostCtMax){
  1773. sutPocStatus.PocLostCt=0;
  1774. //长时间不登陆,重启模块及串口驱动部分
  1775. SlwTrace(INF,"PocLostTimeout!Reset Modem!",1);
  1776. ResetModem();
  1777. // if(++sucPocLostTimeoutCount>2){//连续重启3次都失败,则复位整个系统
  1778. // sucPocLostTimeoutCount=0;
  1779. // SystemReset();
  1780. // }
  1781. }
  1782. }else{
  1783. sutPocStatus.PocLostCt=0;
  1784. sucPocLostTimeoutCount=0;
  1785. }
  1786. }
  1787. //如果模块已开机,长时间收不到串口消息,则重启模块及串口驱动部分
  1788. if(sutPocStatus.ModemPowerOn==1){
  1789. if(sutPocStatus.ModemInactiveCt==0){//ModemInactiveCt必须在接收到Modem串口消息后才清零
  1790. sucModemInactiveCount=0;
  1791. }
  1792. if(++sutPocStatus.ModemInactiveCt>40){//等待时间15秒 4G模块重启后至少要15秒才能启动
  1793. sutPocStatus.ModemInactiveCt=1;
  1794. //长时间收不到串口消息,重启模块及串口驱动
  1795. SlwTrace(INF,"ModemRecvTimeout!Reset Modem!",1);
  1796. ResetModem();
  1797. //连续重启3次无效,复位整个系统
  1798. // if(sucModemInactiveCount>2){
  1799. // sucModemInactiveCount=0;
  1800. // SystemReset();
  1801. // }
  1802. }
  1803. }
  1804. //GPS守护
  1805. if(sutGpsInfo.isGpsWork>0){
  1806. if(++sutGpsInfo.GpsInactiveCt>10){
  1807. sutGpsInfo.GpsInactiveCt=0;
  1808. //复位GPS
  1809. GPSInit();
  1810. Uart3Init();
  1811. TSGpsDataInit();
  1812. }
  1813. }
  1814. }
  1815. /**************************************
  1816. *延时(带喂狗)
  1817. t 系统滴答为单位
  1818. ***************************************/
  1819. void OsDelayTime(unsigned short t)
  1820. {
  1821. int i;
  1822. for(i=0;i<t;i++){
  1823. os_dly_wait(1);
  1824. IWDG_ReloadCounter();//喂狗
  1825. }
  1826. }
  1827. //255.255.255.255
  1828. //-->0xff 0xff 0xff 0xff
  1829. unsigned char GetStringIP2Bytes(unsigned char *IPBytes,char *IPString)
  1830. {
  1831. unsigned char len,i,segment,j;
  1832. char *p;
  1833. char temp[3];
  1834. len = strlen(IPString);
  1835. if(len<7 || len >15) return 1;
  1836. segment=0;
  1837. j=0;
  1838. p=IPString;
  1839. for(i=0;i<len;i++)
  1840. {
  1841. if(IPString[i] == '.')
  1842. {
  1843. if(segment < 4) IPBytes[segment++] = atoi(p);
  1844. else return 2;
  1845. p=&IPString[i+1];
  1846. }else if(IPString[i] < '0' || IPString[i] > '9') return 3;
  1847. }
  1848. if(segment < 5) IPBytes[segment++] = atoi(p);
  1849. return 0;
  1850. }
  1851. void MakeStrEndByNewLine(char *str)
  1852. {//一定要以'\r'结尾
  1853. unsigned short i;
  1854. for(i=0;i<strlen(str);i++)
  1855. {
  1856. if(str[i] == '\r')
  1857. {
  1858. str[i]=0;
  1859. return;
  1860. }
  1861. }
  1862. }
  1863. uint16_t StrUnicodeToAnsi(uint8_t *dest,uint16_t size,const char *src)
  1864. {
  1865. //不需要转
  1866. }
  1867. uint16_t AnsiToStrUnicode(uint8_t *dest,uint16_t size,const char *src)
  1868. {
  1869. //不需要转
  1870. }
  1871. //"3132" --> 0x31,0x32
  1872. void StrAsciiToHex(char *src, unsigned char *des)
  1873. {
  1874. unsigned char temp[2],i;
  1875. if(strlen(src)%2) return;
  1876. while(0!=*src)
  1877. {
  1878. for(i=0;i<2;i++)
  1879. {
  1880. temp[i] = *src++;
  1881. if(temp[i] >= '0' && temp[i] <= '9') temp[i] -= 0x30;
  1882. else if(temp[i] >= 'A' && temp[i] <= 'F') temp[i] -= 0x37;
  1883. else temp[i] -= 0x57;
  1884. }
  1885. temp[0] <<= 4;
  1886. temp[0] &= 0xf0;
  1887. *des++=temp[0]|temp[1];
  1888. }
  1889. *des=0;
  1890. }