Modem.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780
  1. /**********************************************************************************
  2. * File Name: Modem.c
  3. * Function Describe:device for modem
  4. * Relate Module:
  5. * Explain: the modem must be using ZTE MC8332
  6. * Writer: ShiLiangWen
  7. * Date: 2015.1.20
  8. ***********************************************************************************/
  9. #define THIS_FILE_ID 2
  10. /* Includes ------------------------------------------------------------------*/
  11. #include "includes.h"
  12. //os_mbx_declare (PocMsgBox, 5); /* Declare an RTX mailbox */
  13. //_declare_box(PocMpool,sizeof(SUT_MODEM_POC_MSG),5);
  14. //os_mbx_declare (AtMsgBox, 10); /* Declare an RTX mailbox */
  15. //_declare_box(AtMpool,sizeof(SUT_MODEM_AT_MSG),10);
  16. SUT_MODEM_AT_MSG sutAtm,sutAtmPro;
  17. unsigned char g_ucModemSentTcpCt;//TCP 发送计数器
  18. /************************************************************************************
  19. * Usart3_DMA_Send(ucData,strlen((void *)ucData));
  20. *************************************************************************************/
  21. void ModemSendAT(char *p)
  22. {
  23. Uart2Send((unsigned char *)p,strlen(p));
  24. }
  25. /************************************************************************************
  26. *
  27. *************************************************************************************/
  28. void ModemSendData(unsigned char *pData,unsigned short datalen)
  29. {
  30. Uart2Send(pData,datalen);
  31. }
  32. /**********************************************************************************
  33. 等待模块启动完成
  34. 0:成功 -1:超时
  35. ***********************************************************************************/
  36. int WaitModemIsOpened(void)
  37. {
  38. int i;
  39. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  40. RunMake(THIS_FILE_ID);
  41. for(i=0;i<100;i++){
  42. // SlwTrace(INF,"AT\r\n");
  43. ModemSendAT("AT\r\n");
  44. //if(OS_R_TMO!=os_mbx_wait(AtMsgBox,(void **)&pMsg,50)){
  45. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData)))){
  46. if('O'==pMsg->MsgData[0] && 'K'==pMsg->MsgData[1]){
  47. return 0;
  48. }
  49. //free(pMsg);
  50. }else os_dly_wait(100);
  51. }
  52. return 1;
  53. }
  54. void ModemCtrlInit(void)
  55. {
  56. }
  57. /**********************************************************************************
  58. ModemInit
  59. 返回:1 初始化成功 0-失败
  60. ***********************************************************************************/
  61. int ModemInit(void)
  62. {
  63. GPIO_InitTypeDef GPIO_InitStructure;
  64. MsgQueueSet();
  65. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  66. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  67. GPIO_InitStructure.GPIO_Pin = MODEM_RESET_PIN;
  68. GPIO_Init(MODEM_RESET_PORT, &GPIO_InitStructure);
  69. GPIO_InitStructure.GPIO_Pin = MODEM_PWRKEY_PIN;
  70. GPIO_Init(MODEM_PWRKEY_PORT, &GPIO_InitStructure);
  71. RunMake(THIS_FILE_ID);
  72. g_ucModemSentTcpCt=0;
  73. RunMake(THIS_FILE_ID);
  74. MODEM_RESET_HIGH;
  75. os_dly_wait(100);
  76. MODEM_RESET_LOW;
  77. MODEM_PWRKEY_HIGH;
  78. os_dly_wait(100);
  79. MODEM_PWRKEY_LOW;
  80. //return 0;//测试天线
  81. if(WaitModemStart())return 0;
  82. //return ModemGetIMEI();
  83. return 1;
  84. }
  85. /**********************************************************************************
  86. CSQ2Num
  87. ***********************************************************************************/
  88. int CSQ2Num(char *str)
  89. {
  90. int csq;
  91. csq=atoi(str);
  92. if(csq<0 || csq>99)return 99;
  93. else return csq;
  94. }
  95. /**********************************************************************************
  96. ModemStrCmp
  97. ***********************************************************************************/
  98. int ModemStrCmp(char *msg,char *str)
  99. {
  100. char *p1=str;
  101. char *p2=msg;
  102. while(*p1!=0){
  103. if(*p1!=*p2)return 1;
  104. p1++;
  105. p2++;
  106. }
  107. return 0;
  108. }
  109. /**********************************************************************************
  110. ModemWaitAckMsg
  111. Input:
  112. pATCmd--AT Command string
  113. pAck --期待回的ACK,头相同即可
  114. pMsg --实际消息内容,可能比pAck长
  115. timeout --超时,10ms为单位
  116. Output:
  117. if timeout return 0
  118. else return 1 注意,处理完消息要调用_free_box释放消息
  119. ***********************************************************************************/
  120. int ModemSendAT2WaitAckMsg(char *pATCmd,char *pAck,SUT_MODEM_AT_MSG **pMsg,int timeout)
  121. {
  122. int r;
  123. SUT_MODEM_AT_MSG *Msg=&sutAtmPro;
  124. ModemSendAT(pATCmd);
  125. while(timeout){
  126. if((Msg->MsgLen = MsgQueueAccept(Msg->MsgData,sizeof(Msg->MsgData)))){
  127. if(0==ModemStrCmp((char *)Msg->MsgData,pAck)){
  128. *pMsg=Msg;
  129. return 1;
  130. }else{
  131. }
  132. }else {
  133. timeout--;
  134. os_dly_wait(1);
  135. }
  136. }
  137. return 0;
  138. }
  139. int ModemSendTcpData(unsigned char socket,unsigned char *pData,unsigned short len)
  140. {
  141. int i;
  142. char buf[142];
  143. char tmp[5];
  144. unsigned char temp=0;
  145. unsigned short debuglen;
  146. sprintf(buf,"AT+ZIPSEND=%d,%d\r",socket,len);
  147. ModemSendAT(buf);
  148. ModemSendData(pData,len);
  149. if(g_ucModemSentTcpCt<255)g_ucModemSentTcpCt++;
  150. sprintf(buf,"TcpSend[%d]",len);
  151. SlwTrace(INF,buf,1);
  152. #if 0
  153. if(len>45)debuglen=45;
  154. else debuglen=len;
  155. buf[0]='>';buf[1]='>';buf[2]=0;
  156. for(i=0;i<debuglen;i++){
  157. sprintf(tmp,"%02x,",pData[i]);
  158. strcat(buf,tmp);
  159. }
  160. strcat(buf,"\r\n");
  161. SlwTrace(DEBUG,buf);
  162. #endif
  163. return 0;
  164. }
  165. int ModemSendUdpData(unsigned char socket,unsigned char *pData,unsigned short len)
  166. {
  167. int i;
  168. char buf[142];
  169. char tmp[5];
  170. unsigned char temp=0;
  171. sprintf(buf,"AT+ZIPSENDU=%d,%d\r",socket,len);
  172. ModemSendAT(buf);
  173. ModemSendData(pData,len);
  174. sprintf(buf,"UdpSend[%d]",len);
  175. SlwTrace(INF,buf,1);
  176. #if 1
  177. if(len>45)len=45;
  178. buf[0]='>';buf[1]='>';buf[2]=0;
  179. for(i=0;i<len;i++){
  180. sprintf(tmp,"%02x,",pData[i]);
  181. strcat(buf,tmp);
  182. }
  183. strcat(buf,"\r");
  184. SlwTrace(DEBUG,buf,0);
  185. #endif
  186. return 0;
  187. }
  188. unsigned short StrToNum(char *str)
  189. {
  190. unsigned short num;
  191. if(str[0]>0x2f && str[0]<0x3a){
  192. if(str[1]>0x2f && str[1]<0x3a){
  193. if(str[2]>0x2f && str[2]<0x3a){
  194. if(str[3]>0x2f && str[3]<0x3a){
  195. num=1000*(str[0]-0x30);
  196. num+=100*(str[1]-0x30);
  197. num+=10*(str[2]-0x30);
  198. num+=(str[3]-0x30);
  199. }else{
  200. num=100*(str[0]-0x30);
  201. num+=10*(str[1]-0x30);
  202. num+=(str[2]-0x30);
  203. }
  204. }else{
  205. num=10*(str[0]-0x30);
  206. num+=(str[1]-0x30);
  207. }
  208. }else{
  209. num= str[0]-0x30;
  210. }
  211. }else{
  212. num=0;
  213. }
  214. return num;
  215. }
  216. void ModemPoweroff(void)
  217. {
  218. ModemSendAT("AT+ZPWROFF\r\n");
  219. os_dly_wait(50);
  220. ModemSendAT("AT+ZPWROFF\r\n");
  221. IWDG_ReloadCounter();//喂狗
  222. os_dly_wait(100);
  223. IWDG_ReloadCounter();//喂狗
  224. os_dly_wait(100);
  225. IWDG_ReloadCounter();//喂狗
  226. os_dly_wait(50);
  227. IWDG_ReloadCounter();//喂狗
  228. MODEM_PWRKEY_LOW;
  229. MODEM_RESET_HIGH;
  230. os_dly_wait(10);
  231. MODEM_RESET_LOW;
  232. }
  233. /*******************************************************************
  234. *GetIPStatus
  235. 返回:0--未获取 1--获取成功
  236. ********************************************************************/
  237. //int ModemGetMEID(void)
  238. //{
  239. // int t,j;
  240. // int i,len;
  241. // SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  242. // for(i=0;i<50;i++)
  243. // {
  244. // t=50;
  245. // ModemSendAT("AT^MEID\r\n");//0xA100005B114142
  246. // while(t--)
  247. // {
  248. // if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  249. // {
  250. // len=strlen((char*)pMsg->MsgData);
  251. // if(pMsg->MsgLen == 19) j= 14;
  252. // else if(pMsg->MsgLen == 20) j=15;
  253. // else continue;
  254. // memcpy(sutProductPara.MEID, &pMsg->MsgData[2], j);
  255. // if(j<sizeof(sutProductPara.MEID))
  256. // sutProductPara.MEID[j]=0;
  257. // return 1;
  258. // }else
  259. // os_dly_wait(1);
  260. // }
  261. // }
  262. // return 0;
  263. //}
  264. /*******************************************************************
  265. *GetIPStatus
  266. 返回:0--未获取 1--获取成功
  267. ********************************************************************/
  268. //int ModemGetIMEI(void)
  269. //{
  270. // int t,j;
  271. // int i,len;
  272. // unsigned char tempa,tempb;
  273. // unsigned char aucIMEI[16];
  274. // SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  275. // for(i=0;i<50;i++){
  276. // ModemSendAT("AT+GSN\r\n");//0x80DA219D
  277. // //862015030301209 两种情况都会返回
  278. // t=50;
  279. // while(t--)
  280. // {
  281. // if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  282. // {
  283. // len=strlen((char *)&(pMsg->MsgData));
  284. // if(0==ModemStrCmp((char *)pMsg->MsgData,"0x"))
  285. // {
  286. // len -=4;
  287. // memcpy(sutProductPara.IMEI, &pMsg->MsgData[2], len);
  288. // if(len < sizeof(sutProductPara.IMEI))
  289. // sutProductPara.IMEI[len]=0;
  290. //
  291. // memset(aucIMEI,0,sizeof(aucIMEI));
  292. // tempa=15-strlen(sutProductPara.IMEI);
  293. // for(tempb=0;tempb<tempa;tempb++){
  294. // aucIMEI[tempb]=0x30;
  295. // }
  296. // strcat(aucIMEI,sutProductPara.IMEI);
  297. // strncpy(sutProductPara.IMEI,aucIMEI,sizeof(sutProductPara.IMEI));
  298. //
  299. // return 1;
  300. // }else if(len == 17)
  301. // {
  302. // len -= 2;
  303. // memcpy(sutProductPara.IMEI, pMsg->MsgData, len);
  304. // if(len < sizeof(sutProductPara.IMEI))
  305. // sutProductPara.IMEI[len]=0; //可以不做保存
  306. // return 2;
  307. // }
  308. // }else
  309. // os_dly_wait(1);
  310. // }
  311. // }
  312. // return 0;
  313. //}
  314. //
  315. char SetModemTCPHexMode(TCPUDP_DEF mode)
  316. {
  317. int t,i;
  318. char buf[40];
  319. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  320. for(i=0;i<3;i++){
  321. t=50;
  322. ModemSendAT("AT+MIPHEX?\r\n");
  323. while(t--)
  324. {
  325. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData, sizeof(pMsg->MsgData))))
  326. {
  327. if(0==ModemStrCmp((char *)pMsg->MsgData,"+MIPHEX:"))
  328. {
  329. if(pMsg->MsgData[8] != mode)
  330. {
  331. sprintf(buf, "AT+MIPHEX=%c\r\n", mode);
  332. ModemSendAT(buf);
  333. }else
  334. {
  335. SlwTrace(INF, "[11]TcpDataMode->HEX",1);
  336. return 1;
  337. }
  338. }
  339. }else os_dly_wait(1);
  340. }
  341. }
  342. SlwTrace(INF, "[11]TCPModeSet failed",1);
  343. return 0;
  344. }
  345. /*******************************************************************
  346. *ModemCheckPocParam
  347. return:
  348. 1--not same, Reset
  349. 0--same,no reset
  350. ********************************************************************/
  351. int ModemCheckPocParam(void)
  352. {
  353. int t,j;
  354. int i,len;
  355. char buf[60];
  356. char buf1[130];
  357. char buf2[40];
  358. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  359. RunMake(THIS_FILE_ID);
  360. for(i=0;i<5;i++)
  361. {
  362. ModemSendAT("AT+POC=020000\r\n");
  363. //+POC:0200000069643D3135393930303130313B69703D3235352E3235352E3235352E3235353B7077643D4131303030303542313134313432 len <= 13 + 100
  364. //id=159900101;ip=255.255.255.255;pwd=A100005B114142
  365. t=50;
  366. while(t--)
  367. {
  368. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  369. {
  370. if(0==ModemStrCmp((char *)pMsg->MsgData,"+POC:02"))
  371. {
  372. sprintf(buf, "id=%lu;",sutProductPara.PSN);
  373. sprintf(buf2, "ip=%d.%d.%d.%d;",sutNewSegmentPara.PIP[0],sutNewSegmentPara.PIP[1],sutNewSegmentPara.PIP[2],sutNewSegmentPara.PIP[3]);
  374. strcat(buf, buf2);
  375. sprintf(buf2, "pwd=%s;",sutNewSegmentPara.HARDID);
  376. strcat(buf, buf2);
  377. AscStrToHexStr(buf,buf1);
  378. for(j=0;j<strlen(pMsg->MsgData);j++) if(pMsg->MsgData[j]== '\r') pMsg->MsgData[j] = 0;
  379. if(0!=strcasecmp((char *)&pMsg->MsgData[13],buf1))
  380. {
  381. ModemSendAT("AT+POC=010000");
  382. ModemSendAT(buf1);
  383. ModemSendAT("\r\n");
  384. return 1;
  385. }else return 0;
  386. }
  387. }else os_dly_wait(1);
  388. }
  389. }
  390. return 0;
  391. }
  392. void ModemInfo(void)
  393. {
  394. int t;
  395. int i,len,ver,j;
  396. char bufTemp[30],version[10],type,countFlag;
  397. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  398. RunMake(THIS_FILE_ID);
  399. ver=0;
  400. SlwTrace(INF, "[03]ModemInfo:",1);
  401. type=0;
  402. for(i=0;i<10;i++)
  403. {
  404. if(type==0) ModemSendAT("ATI\r\n");//模块型号
  405. else ModemSendAT("AT+LCTSW\r\n");//版本信息
  406. t=50;
  407. while(t--)
  408. {
  409. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  410. {
  411. if(type==0)
  412. {//Manufacturer: LONGSUNG
  413. //Model: U9507C
  414. if(0==ModemStrCmp((char *)pMsg->MsgData,"Manufacturer:")) SlwTrace(INF, pMsg->MsgData, 0);
  415. else if(0==ModemStrCmp((char *)pMsg->MsgData,"Model:"))
  416. {
  417. SlwTrace(INF, pMsg->MsgData, 0);
  418. type ++;
  419. break;
  420. }
  421. }else{
  422. //SoftwareVersion: LLA0029.1.2_M005
  423. //InnerVersion: LLA0029_0016_1.0.57_L0901_EFS2.6
  424. //AP: LLA0029_0016_0.0.57_L0901_M005
  425. if(0==ModemStrCmp((char *)pMsg->MsgData,"SoftwareVersion:")) SlwTrace(INF, pMsg->MsgData, 0);
  426. else if(0==ModemStrCmp((char *)pMsg->MsgData,"AP:"))
  427. {
  428. SlwTrace(INF, pMsg->MsgData, 0);
  429. return;
  430. }
  431. else if(0==ModemStrCmp((char *)pMsg->MsgData,"InnerVersion:"))
  432. {
  433. SlwTrace(INF, pMsg->MsgData, 0);
  434. countFlag=0;
  435. for(j=0;j<strlen(pMsg->MsgData);j++)
  436. {
  437. if(pMsg->MsgData[j] == '_')
  438. {
  439. countFlag++;
  440. if(countFlag == 1)
  441. {
  442. version[0] = pMsg->MsgData[j+3];
  443. version[1] = pMsg->MsgData[j+4];
  444. }else if(countFlag == 3)
  445. {
  446. version[2] = pMsg->MsgData[j+2];
  447. version[3] = pMsg->MsgData[j+3];
  448. version[4] = pMsg->MsgData[j+4];
  449. version[5] = pMsg->MsgData[j+5];
  450. version[6] = 0;
  451. sprintf(bufTemp, "[03]ModemVer:%s",version);
  452. SlwTrace(INF, bufTemp, 1);
  453. g_iModemVer=atoi(version);
  454. }
  455. }
  456. }
  457. }
  458. }
  459. }else os_dly_wait(1);
  460. }
  461. }
  462. }
  463. void ModemPocVersionCheck(void)
  464. {
  465. char bufTemp[40];
  466. short t,i,len,ver,j;
  467. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  468. for(i=0;i<5;i++)
  469. {
  470. t=50;
  471. ModemSendAT("AT+POC_VER?\r\n");
  472. while(t--)
  473. {
  474. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  475. {
  476. if(0==ModemStrCmp((char *)pMsg->MsgData,"+POC_VER:"))
  477. {
  478. len = strlen(pMsg->MsgData);
  479. j=0;
  480. for(i=0;i<len;i++)
  481. {
  482. if(pMsg->MsgData[i] == '\r')
  483. {
  484. bufTemp[j]=0;
  485. ver=atoi(bufTemp);
  486. sprintf(bufTemp,"[04]POCver:%d<->%s", ver,pMsg->MsgData);
  487. SlwTrace(INF, bufTemp,0);
  488. g_iPocVer=ver;
  489. return;
  490. }else if(pMsg->MsgData[i] >= '0' && pMsg->MsgData[i] <= '9') bufTemp[j++]=pMsg->MsgData[i];
  491. }
  492. }
  493. }else
  494. os_dly_wait(1);
  495. }
  496. }
  497. sprintf(bufTemp,"[04]PocVer=%d", ver);
  498. SlwTrace(INF, bufTemp, 1);
  499. }
  500. int ModemCheckUIM(void)
  501. {
  502. unsigned char t,round=0;
  503. int i,len,ver;
  504. char cmd[10];
  505. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  506. RunMake(THIS_FILE_ID);
  507. ver=0;
  508. for(i=0;i<30;i++)
  509. {
  510. t=50;
  511. if(round==0)
  512. {
  513. round=1;
  514. ModemSendAT("AT+QCPIN?\r\n");
  515. sprintf(cmd, "+QCPIN:");
  516. }else{
  517. round=0;
  518. ModemSendAT("AT+CPIN?\r\n");
  519. sprintf(cmd, "+CPIN:");
  520. }
  521. while(t--)
  522. {
  523. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  524. {
  525. if(0==ModemStrCmp((char *)pMsg->MsgData,cmd))
  526. {//+QCPIN: READY
  527. //+CPIN: READY
  528. if(pMsg->MsgData[7+round]=='R' && pMsg->MsgData[9+round]=='A'){
  529. return 1;
  530. }
  531. }
  532. }else
  533. os_dly_wait(1);
  534. }
  535. }
  536. return 0;
  537. }
  538. void M9507CSendTcpData(unsigned char socket, unsigned char *pData, unsigned short len)
  539. {
  540. char buf[20];
  541. sprintf(buf, "AT+TCPSEND=%d,%d,",socket, len);
  542. ModemSendAT(buf);
  543. ModemSendData(pData, len);
  544. ModemSendAT("\r\n");
  545. }
  546. void MC8332ModemSendTcpData(unsigned char socket,unsigned char *pData,unsigned short len)
  547. {
  548. M9507CSendTcpData(socket, pData, len);
  549. PrintTcpData(pData,len);
  550. if(socket == GPS_DATA_SOCKET)
  551. if(g_ucModemSentTcpCt<255)g_ucModemSentTcpCt++;
  552. if(socket == GPS_DATA_SOCKET)
  553. sutGpsInfo.isServerLogin = OPEN;
  554. }
  555. int ModemGPSStart(void)
  556. {
  557. int t;
  558. int i;
  559. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  560. RunMake(THIS_FILE_ID);
  561. for(i=0;i<5;i++)
  562. {
  563. t=100;
  564. ModemSendAT("AT+GPSSTART\r\n");//此指令一旦设置了一次后,下次会返回ERROR
  565. while(t--)
  566. {
  567. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  568. {
  569. if(0==ModemStrCmp((char *)pMsg->MsgData,"RING") || 0==ModemStrCmp((char *)pMsg->MsgData,"ERROR")){
  570. return 0;
  571. }
  572. }else
  573. os_dly_wait(1);
  574. }
  575. }
  576. return 1;
  577. }
  578. char GPSModeSet(void)
  579. {
  580. int t,i;
  581. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  582. RunMake(THIS_FILE_ID);
  583. for(i=0;i<3;i++)
  584. {
  585. t=100;
  586. ModemSendAT("AT+NMEAS?\r\n");
  587. while(t--)
  588. {
  589. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  590. {
  591. if(0==ModemStrCmp((char *)pMsg->MsgData,"+NMEAS:"))
  592. {
  593. if(pMsg->MsgData[7] == '0') return 0; //OK
  594. else ModemSendAT("AT+NMEAS=0\r\n");
  595. }
  596. }else
  597. os_dly_wait(1);
  598. }
  599. }
  600. return 1;
  601. }
  602. void ModemApnConfig(void)
  603. {
  604. char buf[60],index;
  605. char buf2[40];
  606. char i;
  607. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  608. sprintf(buf, "[11]Accessp:");
  609. if(sutProductPara.APNApn[0]==0)
  610. {//接入点为空时不配置,因为模块不支持
  611. strcat(buf, "unsupport-Empty");
  612. }else
  613. {
  614. sprintf(buf2, "AT+MIPPROFILE=1,\"%s\"\r\n",sutProductPara.APNApn);
  615. ModemSendAT(buf2);
  616. sprintf(buf2, "%s",sutProductPara.APNApn);
  617. strcat(buf,buf2);
  618. }
  619. SlwTrace(INF,buf,0);
  620. sprintf(buf, ",Name-Pass:");
  621. if(sutProductPara.APNName[0] ==0 ||
  622. sutProductPara.APNPass[0] ==0)
  623. {//名称或密码为空不配置,因为模块不支持
  624. strcat(buf, "unsupport-Empty");
  625. }else
  626. {
  627. sprintf(buf2,"AT^PPPCFG=\"%s\",\"%s\"\r\n",sutProductPara.APNName,sutProductPara.APNPass);
  628. ModemSendAT(buf2);
  629. sprintf(buf2, "%s,%s",sutProductPara.APNName,sutProductPara.APNPass);
  630. strcat(buf,buf2);
  631. }
  632. SlwTrace(INF,buf,1);
  633. }
  634. char WaitModemStart(void)
  635. {
  636. int t,i;
  637. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  638. SlwTrace(INF, "WaitModemRun:",0);
  639. for(i=0;i<100;i++)
  640. {
  641. t=50;
  642. ModemSendAT("ATE0\r\n");
  643. while(t--)
  644. {
  645. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  646. {
  647. if(0==ModemStrCmp((char *)pMsg->MsgData,"OK") ||
  648. 0==ModemStrCmp((char *)pMsg->MsgData,"+POC:START"))
  649. {
  650. SlwTrace(INF, "Runing",1);
  651. return 0;
  652. }
  653. }else
  654. os_dly_wait(1);
  655. }
  656. }
  657. SlwTrace(INF, "TimeOut",1);
  658. return 1;
  659. }
  660. void ModemSetSpeed(void)
  661. {
  662. char i,t;
  663. int Volume;
  664. SUT_MODEM_AT_MSG *pMsg=&sutAtmPro;
  665. for(i=0;i<5;i++)
  666. {
  667. t=50;
  668. REGO:
  669. ModemSendAT("AT+LSHTTSSPEED?\r\n");
  670. while(t--)
  671. {
  672. if((pMsg->MsgLen = MsgQueueAccept(pMsg->MsgData,sizeof(pMsg->MsgData))))
  673. {
  674. if(0==ModemStrCmp((char *)pMsg->MsgData,"+LSHTTSSPEED:"))
  675. {
  676. Volume=atoi(&pMsg->MsgData[13]);
  677. if(7000 != Volume)
  678. {
  679. ModemSendAT("AT+LSHTTSSPEED=-1,7000\r\n");
  680. os_dly_wait(1);
  681. goto REGO;
  682. }
  683. else
  684. {
  685. SlwTrace(INF, "[06]SetTTS Speed Ok",1);
  686. return;
  687. }
  688. }
  689. }else
  690. os_dly_wait(1);
  691. }
  692. }
  693. SlwTrace(INF, "[06]SetTTS Speed Failed",1);
  694. }
  695. char GetUniStringByID(char *HardIDString)
  696. {//输出15个字节的字符串
  697. unsigned char id[12];
  698. unsigned char string[16];
  699. long long temp;
  700. short i;
  701. unsigned char seed;
  702. if(HardIDString == '\0') return 0;
  703. GetSTM32ID(id);
  704. printf("STM32 ID==");
  705. for(i=0;i<12;i++)printf("%02x",id[i]);
  706. printf("\r\n");
  707. for(i=5;i>=0;i--){
  708. temp <<=8;
  709. temp |= id[i];
  710. }
  711. temp &= 0xffffffffffff;
  712. printf("temp=%015llu\r\n",temp);
  713. snprintf(string,sizeof(string),"%015llu",temp);
  714. for(i=0;i<15;i++) HardIDString[i]=string[i];
  715. HardIDString[15]='\0';
  716. //snprintf(HardIDString,16,"%015llu",temp);
  717. return 1;
  718. }
  719. /***********************************************************************************/