MainTask.c 56 KB

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