ml307a.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. #include "ml307a.h"
  2. #include "usart.h"
  3. #include "tt808.h"
  4. #include "rtc.h"
  5. //*结构体
  6. extern Menu_table menu;
  7. extern TT808 tt808;
  8. RTC_DateTypeDef GetData; //获取日期结构体
  9. RTC_TimeTypeDef GetTime; //获取时间结构体
  10. //*整型
  11. uint8_t step4g = 0;
  12. uint8_t resetcount_4g=0;
  13. uint8_t ICCID[30];
  14. //*布尔
  15. bool module4G_F = false;
  16. bool reset4Gmodule = false;
  17. bool MgnssFlag = false;
  18. extern bool refresh;
  19. extern TipsFlag tipsflag;
  20. bool signal = false;
  21. //*字符
  22. char year_str[3];
  23. char month_str[3];
  24. char day_str[3];
  25. char hour_str[3];
  26. char minute_str[3];
  27. char second_str[3];
  28. extern char Newip[30];
  29. extern Ipaddr ipaddr;
  30. //*本模块方法
  31. void ML307AReset(void);
  32. void RTCtime(void);
  33. void MQTTCONN(void);
  34. void TcpConn(char *value, uint8_t cid, char *IPaddr, uint16_t port, uint8_t tcpConnmode)
  35. {
  36. char *ptr = value;
  37. ptr += sprintf(ptr, "AT+MIPOPEN=%d,\"TCP\",\"%s\",%d,60,%d\r\n",cid,IPaddr,port,tcpConnmode);
  38. }
  39. uint16_t phonenum[3];
  40. bool phonenull=false;
  41. char topica[50];//*终端发布A
  42. char topicb[50];//*服务器发布B
  43. void ML307A_Init(void)
  44. {
  45. //*phoneNumADDR
  46. Flash_ReadBytes(phonenum, phoneNumADDR, 3);//读取phonenum
  47. if(phonenum[0]==0xFFFF)
  48. {
  49. phonenull=true;
  50. phonenum[0]=0x0000;
  51. phonenum[1]=0x1600;
  52. phonenum[2]=0x0008;
  53. }
  54. else
  55. {
  56. //
  57. }
  58. sprintf(topica, "%s%04X%04X%04X%s", PCMQTTTOPIC_PREFIX, phonenum[0], phonenum[1], phonenum[2], PCMQTTTOPIC_SUFFIXA);//终端发布
  59. sprintf(topicb, "%s%04X%04X%04X%s", PCMQTTTOPIC_PREFIX, phonenum[0], phonenum[1], phonenum[2], PCMQTTTOPIC_SUFFIXB);//终端订阅
  60. Flash_ReadBytes((uint16_t*)&(ipaddr.IP0),ReIPAddr,5);//读取phonenum
  61. if(ipaddr.IP0==0xFFFF)
  62. {
  63. }
  64. else
  65. {
  66. char *ptr = Newip;
  67. ptr += sprintf(ptr, "%d.", ipaddr.IP0);
  68. ptr += sprintf(ptr, "%d.", ipaddr.IP1);
  69. ptr += sprintf(ptr, "%d.", ipaddr.IP2);
  70. ptr += sprintf(ptr, "%d", ipaddr.IP3);
  71. }
  72. printf("\t###02\t4G_init...%d\r\n",resetcount_4g);
  73. sendCmd_4G("AT+MGNSS=0\r\n", "OK", 1, 1);//关闭MGNSS
  74. sendCmd_4G("AT+MQTTDISC=0\r\n", "OK", 1, 1);//关闭MQTT
  75. switch(step4g)
  76. {
  77. case 0:
  78. {
  79. if (sendCmd_4G("AT\r\n", "OK", 1, 5))
  80. {
  81. sendCmd_4G("AT+MCFG=\"simhot\",1\r\n", "OK", 1, 1);
  82. printf("#4G模组正常\r\n");
  83. if (sendCmd_4G("AT+ICCID\r\n", "OK", 1, 5))
  84. {
  85. memcpy(ICCID,&U4_4GrecvBuff[8],20);
  86. ICCID[20]=0x00;
  87. ICCID[21]=0x01;//版本号(待修改)
  88. }
  89. step4g++;
  90. }
  91. else
  92. {
  93. ML307AReset();
  94. break;
  95. }
  96. }
  97. case 1:
  98. {
  99. if (sendCmd_4G("AT+CPIN?\r\n", "+CPIN: READY", 1, 5))
  100. {
  101. printf("#4G模组状态正常\r\n");
  102. step4g++;
  103. }
  104. //break;
  105. }
  106. case 2:
  107. {
  108. if (sendCmd_4G("AT+CEREG?\r\n", "+CEREG: 0,1", 1, 5))
  109. {
  110. printf("#4G模组附着正常\r\n");
  111. printf("#4G模组初始化完成\r\n");
  112. step4g++;
  113. }
  114. //break;
  115. }
  116. case 3:
  117. {
  118. #if open4G == 1
  119. if(sendCmd_4G("AT+MIPCLOSE=1\r\n", "+MIPSEND:", 1, 1))//断开所有平台
  120. {
  121. printf("#断开连接\r\n");
  122. }
  123. char TCPconnvalue[100];
  124. if(Newip[0] == NULL)
  125. {
  126. TcpConn(TCPconnvalue, 1, JLPTIP, JLPTPORT,0); //cid=1 tcpConnmode=0 普通模式
  127. }
  128. else
  129. {
  130. TcpConn(TCPconnvalue, 1, Newip, ipaddr.IPp,0); //cid=1 tcpConnmode=0 普通模式
  131. }
  132. if(sendCmd_4G(TCPconnvalue, "+MIPOPEN: 1,0", 1, 1)) //TCP连接 0普通模式 2缓存模式 1透传模式
  133. #endif
  134. {
  135. step4g++;
  136. }
  137. MQTTCONN();//*连接MQTT
  138. char MQTT_SUBbuf[50]; // 调整缓冲区大小以适应新的字符串长度
  139. // 拼接订阅指令字符串
  140. snprintf(MQTT_SUBbuf, 50, "AT+MQTTSUB=0,\"%s\",1\r\n", topicb);
  141. // 发送订阅指令并检查结果
  142. if (sendCmd_4G(MQTT_SUBbuf, "+MQTTURC: \"suback\"", 1, 1)) {
  143. printf("#订阅成功\r\n");
  144. }
  145. //break;
  146. }
  147. case 4:
  148. {
  149. sendCmd_4G("AT+MIPCFG=\"encoding\",1,1,1\r\n", "OK", 1, 1);//默认输入输出为ASCII,0 发16,1 接16,1
  150. if(!reset4Gmodule)
  151. {
  152. if(sendCmd_4G("AT+MGNSSCFG=\"nmea/mask\",0\r\n", "OK", 1, 1))
  153. {
  154. printf("#使能NMEA信息\r\n");
  155. if(sendCmd_4G("AT+MGNSSLOC=0\r\n", "OK", 1, 1))
  156. {
  157. printf("#关闭自动定位上报\r\n");
  158. if(sendCmd_4G("AT+MGNSS=1\r\n", "OK", 1, 1))
  159. {
  160. printf("#开启MGNSS\r\n");
  161. MgnssFlag=true;
  162. }
  163. }
  164. }
  165. }
  166. else
  167. {
  168. reset4Gmodule=false;
  169. }
  170. printf("#TCP设置完成\r\n");
  171. Time_inquiry(0);
  172. if(tipsflag == NoSIM)
  173. {
  174. module4G_F=false;
  175. }
  176. else
  177. {
  178. module4G_F=true;
  179. }
  180. RTCtime();//写入做参考
  181. break;
  182. }
  183. }
  184. Flash_ReadBytes(&ManualWork,ManualWorkaddr,1);
  185. printf("%04X\r\n",ManualWork);
  186. if(ManualWork==0xFFFF)
  187. {
  188. ManualWork=1;
  189. }
  190. printf("%04X\r\n",ManualWork);
  191. menu.current=0;//默认进入PDA
  192. refresh=true;
  193. }
  194. /**
  195. * @breaf 4G发送串口命令
  196. */
  197. uint8_t sendCmd_4G(char *pCmd, char *pRes, uint32_t timeOut, uint8_t sendNum)
  198. {
  199. uint8_t i = 0;
  200. uint32_t time;
  201. for(i = 0; i < sendNum; i++)
  202. {
  203. time = timeOut * 10;
  204. memset(U4_4GrecvBuff,0,sizeof(U4_4GrecvBuff));
  205. USART_SendString(&huart4, pCmd);
  206. HAL_Delay(100);
  207. while(time--)
  208. {
  209. if(strstr((const char *)U4_4GrecvBuff, pRes) != NULL) // 如果检索到关键词
  210. {
  211. return 1;
  212. }
  213. HAL_Delay(100);
  214. }
  215. }
  216. return 0;
  217. }
  218. uint8_t MQTT_CONN(char *IpAddr, uint16_t port, char *ID, char *User, char *Passwd, char* pRes)
  219. {
  220. char MQTT_Sendbuf[128];
  221. sprintf((char *)MQTT_Sendbuf,"AT+MQTTCONN=0,\"%s\",%d,\"%s\",\"%s\",\"%s\"\r\n",IpAddr, port, ID,User, Passwd);
  222. if(sendCmd_4G(MQTT_Sendbuf,pRes,1,1))
  223. {
  224. return 1;
  225. }
  226. return 0;
  227. }
  228. uint8_t MQTT_PUB(uint8_t connect_id, char *topic, char *mesg, char* pRes)
  229. {
  230. char MQTT_Sendbuf[200];
  231. uint8_t length = strlen(mesg);
  232. sprintf((char *)MQTT_Sendbuf,"AT+MQTTPUB=%d,\"%s\",1,0,0,%d,\"%s\"\r\n",connect_id, topic, length, mesg);
  233. if(sendCmd_4G(MQTT_Sendbuf,pRes,1,1))
  234. {
  235. printf("#发布心跳成功\r\n");
  236. return 1;
  237. }
  238. return 0;
  239. }
  240. /**
  241. * @breaf MQTT初始化
  242. */
  243. void MQTTCONN(void)
  244. {
  245. if(MQTT_CONN((char*)PCMQTTADDR,PCMQTTPORT,"dtu",(char*)PCMQTTUSER,(char*)PCMQTTPSWD,"+MQTTURC: \"conn\",0,0"))
  246. {
  247. printf("#连接MQTT成功\r\n");
  248. //*订阅
  249. }
  250. }
  251. /**
  252. @brief 重启模块
  253. @param 无
  254. @return 无
  255. */
  256. void ML307AReset(void)
  257. {
  258. step4g=0;
  259. reset4Gmodule=true;
  260. resetcount_4g+=1;
  261. printf("4G Module_Reset\n");
  262. HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_RESET);
  263. HAL_Delay(5000);
  264. HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_SET);
  265. }
  266. void Pre_processing_4G(void)//传递消息前处理
  267. {
  268. if(module4G_F) //4G启动位
  269. {
  270. module4G_F=false; //鉴权操作
  271. #if open4G ==1
  272. tt808FsFunc(ICCID,22,MessageID_authentication);
  273. #endif
  274. }
  275. if(!Online)
  276. {
  277. //printf("未连接平台\r\n");
  278. //wdiFlag = true;
  279. }
  280. }
  281. void Transfer_time(uint8_t outTt[],char in[])//转换时间数据
  282. {
  283. const char *hex = (const char *)in; // 将 uint8_t * 转换为 const char *
  284. int size = strlen(hex) / 2; // 计算二进制数据的长度
  285. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  286. hex2bin(bin, hex); // 调用hex2bin函数进行转换
  287. memcpy(outTt, bin, 1); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  288. free(bin); // 释放内存
  289. }
  290. void RTCtime(void)
  291. {
  292. HAL_RTC_GetTime(&hrtc, &GetTime, RTC_FORMAT_BIN);
  293. /* Get the RTC current Date */
  294. HAL_RTC_GetDate(&hrtc, &GetData, RTC_FORMAT_BIN);
  295. tt808.Rtime[0] = GetData.Year;
  296. tt808.Rtime[1] = GetData.Month;
  297. tt808.Rtime[2] = GetData.Date;
  298. tt808.Rtime[3] = GetTime.Hours;
  299. tt808.Rtime[4] = GetTime.Minutes;
  300. tt808.Rtime[5] = GetTime.Seconds;
  301. hexArrayToBcd(tt808.Rtime,6,dblocptr->location.timeBCD);
  302. //printf("%02X%02X%02X%02X%02X%02X\r\n",tt808.Rtime[0],tt808.Rtime[1],tt808.Rtime[2],tt808.Rtime[3],tt808.Rtime[4],tt808.Rtime[5]);
  303. //printf("%02X%02X%02X%02X%02X%02X\r\n",dblocptr->location.timeBCD[0],dblocptr->location.timeBCD[1],dblocptr->location.timeBCD[2],dblocptr->location.timeBCD[3],dblocptr->location.timeBCD[4],dblocptr->location.timeBCD[5]);
  304. time_bj();//转换时间戳
  305. }
  306. void Time_inquiry(uint8_t flag)
  307. {
  308. if(flag==0)//首次问
  309. {
  310. if (sendCmd_4G("AT+CCLK?\r\n", "OK", 1, 1))
  311. {
  312. memcpy(year_str, &U4_4GrecvBuff[8], 2); // 复制两个字符
  313. memcpy(month_str, &U4_4GrecvBuff[11], 2);
  314. memcpy(day_str, &U4_4GrecvBuff[14], 2);
  315. memcpy(hour_str, &U4_4GrecvBuff[17], 2);
  316. memcpy(minute_str, &U4_4GrecvBuff[20], 2);
  317. memcpy(second_str, &U4_4GrecvBuff[23], 2);
  318. year_str[2] = '\0'; // 添加空字符结束符
  319. month_str[2] = '\0';
  320. day_str[2] = '\0';
  321. hour_str[2] = '\0';
  322. minute_str[2] = '\0';
  323. second_str[2] = '\0';
  324. Transfer_time(&tt808.Rtime[0],year_str);
  325. Transfer_time(&tt808.Rtime[1],month_str);
  326. Transfer_time(&tt808.Rtime[2],day_str);
  327. Transfer_time(&tt808.Rtime[3],hour_str);
  328. Transfer_time(&tt808.Rtime[4],minute_str);
  329. Transfer_time(&tt808.Rtime[5],second_str);
  330. SyncTime(tt808.Rtime[0], tt808.Rtime[1], tt808.Rtime[2], tt808.Rtime[3], tt808.Rtime[4], tt808.Rtime[5]);
  331. }
  332. }
  333. else
  334. {
  335. /* 上面通过AT指令问 */
  336. RTCtime();//上电同步后,作业时需再次同步
  337. }
  338. }