Bc260y_Regist.c 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. #include "CONFIG.h"
  2. #if BC260Y
  3. /**
  4. ******************************************************************************
  5. * 版 本 :V1.0.0
  6. * 作 者 :liuyanbin
  7. * 版权所有,盗版必究。
  8. * Copyright(C) All rights reserved
  9. ******************************************************************************
  10. * 历史记录
  11. * 序号 版本 变更内容 作者 日期
  12. * 1 V0.0.1 实现4G注册 刘艳斌 2023/12/20
  13. * 2 V0.0.2 实现NB注册 刘艳斌 2023/12/20
  14. * 3 V0.0.3 整合4g和nb 刘艳斌 2024/1/24
  15. *
  16. ******************************************************************************
  17. */
  18. #include "stm32f10x.h"
  19. #include "Regist.h"
  20. #include "bc260y.h"
  21. #include "INflash.h"
  22. #include <stdio.h>
  23. #include <stdarg.h>
  24. #include <string.h>
  25. #include <stdlib.h>
  26. #include "cJSON.h"
  27. #include "mbedtls_util.h"
  28. #include "Log_Module.h"
  29. #include "At_Module.h"
  30. #include "Common_Util.h"
  31. #include "Tuoreniot.h"
  32. static uint8_t register_status;//注册成功,向flash存储标志
  33. static Coefficient_Data flashdata;
  34. static uint8_t mcu_id[8]="ceshi002";
  35. // 生成环境
  36. static char * REGIST_SERVER = "iot.tuoren.com" ; //注册服务器地址
  37. static uint16_t REGIST_PORT = 8888; //端口号
  38. // 开发环境
  39. //static char * REGIST_SERVER = "z18z017026.51vip.biz" ; //注册服务器地址
  40. //static uint16_t REGIST_PORT = 31396; //端口号
  41. static uint8_t tcpconnectID = 2;
  42. // 注册参数
  43. static struct Regist_Params_Struct regist_params_struct = {
  44. .platform = "aliyun",
  45. .connType = "CoAP",
  46. .deviceId = "3431228A1936013C",
  47. .userId = 4562
  48. };
  49. static uint8_t regist_data[512];
  50. static uint16_t regist_data_length;
  51. //清空flash
  52. void clearflash(void){
  53. flashdata.read_flag=0;
  54. memset(flashdata.deviceSecret, 0, sizeof(flashdata.deviceSecret));
  55. memset(flashdata.productKey, 0, sizeof(flashdata.productKey));
  56. memset(flashdata.deviceName, 0, sizeof(flashdata.deviceName));
  57. my_delay_ms(10);
  58. STMFLASH_Write(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  59. }
  60. void storedata(void)
  61. {
  62. flashdata.read_flag=1;
  63. strcpy(flashdata.deviceSecret, regist_params_struct.deviceSecret);
  64. strcpy(flashdata.productKey, regist_params_struct.productKey);
  65. strcpy(flashdata.deviceName, regist_params_struct.deviceName);
  66. my_delay_ms(10);
  67. STMFLASH_Write(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  68. flashdata.read_flag=0;
  69. my_delay_ms(10);
  70. Log_Printf_Debug("写入数据完成\r\n");
  71. STMFLASH_Read(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  72. Log_Printf_Debug("读取完成read_flag:%d,deviceSecret:%s,productKey:%s,deviceName:%s\r\n",flashdata.read_flag,flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName);
  73. }
  74. uint8_t regist_Handle()
  75. {
  76. uint8_t cfun_mode, mode,stat,regist_flag = 0;
  77. uint16_t lac,err = 0;
  78. uint32_t ci = 0;
  79. enum Result result = Result_None;
  80. // GPIO_SetBits(WAKE_GPIO, WAKE_GPIO_Pin);
  81. result = bc260y.exit_sleep_sync();//退出休眠
  82. if(result==Result_Success)
  83. {
  84. Log_Printf_Debug("退出休眠成功\r\n");
  85. result = bc260y.set_qisde_sync(1);//开启回显
  86. }
  87. if(result==Result_Success)
  88. {
  89. Log_Printf_Debug("开启回显成功\r\n");
  90. result=bc260y.set_sleep_sync(1);//设置休眠模式
  91. }
  92. if(result==Result_Success)
  93. {
  94. Log_Printf_Debug("设置休眠模式成功\r\n");
  95. result = bc260y.dataformat_sync(0); // 设置数据格式
  96. }
  97. if(result==Result_Success)
  98. {
  99. Log_Printf_Debug("设置数据格式成功\r\n");
  100. result=bc260y.query_cfun_sync(&cfun_mode);//查询功能模式
  101. }
  102. if(result==Result_Success)
  103. {
  104. Log_Printf_Debug("查询功能模式成功\r\n");
  105. if(cfun_mode == 0)
  106. {
  107. result=bc260y.set_cfun_sync(1);//设置全功能模式
  108. }
  109. }
  110. if(result==Result_Success)
  111. {
  112. Log_Printf_Debug("设置全功能模式成功\r\n");
  113. result=bc260y.set_cereg_sync(2);//设置网络状态
  114. }
  115. if(result==Result_Success)
  116. {
  117. Log_Printf_Debug("设置网络状态成功\r\n");
  118. for(uint8_t i = 0; i < 10; i++)
  119. {
  120. result=bc260y.query_cereg_sync(&mode,&stat,&lac,&ci);//循环查询网络状态最多10次
  121. if(result == Result_Failed || stat == 1)
  122. {
  123. break;
  124. }
  125. my_delay_ms(400);
  126. }
  127. }
  128. if(result==Result_Success)
  129. {
  130. Log_Printf_Debug("网络注册成功\r\n");
  131. result=bc260y.close_socket_sync(tcpconnectID);//防止以前链接没断开,断开tcp链接
  132. }
  133. if(result==Result_Success)
  134. {
  135. Log_Printf_Debug("断开tcp链接成功\r\n");
  136. result=bc260y.open_socket_sync(tcpconnectID,"TCP",REGIST_SERVER,REGIST_PORT,1,&err);//连接tcp
  137. }
  138. if(result==Result_Success)
  139. {
  140. Log_Printf_Debug("连接tcp成功\r\n");
  141. memset(regist_params_struct.deviceId, 0, sizeof(regist_params_struct.deviceId));
  142. byteToHexStr(mcu_id, regist_params_struct.deviceId, sizeof(mcu_id));
  143. memset(regist_data, 0, sizeof(regist_data));
  144. packRegistParams(regist_data, &regist_data_length, regist_params_struct);
  145. printf_regist_param_struct(regist_params_struct);
  146. result =bc260y.send_sync(tcpconnectID, regist_data, regist_data_length);//数据发送
  147. }
  148. if(result==Result_Success)
  149. {
  150. Log_Printf_Debug("数据发送成功\r\n");
  151. memset(regist_data, 0, sizeof(regist_data));
  152. result =bc260y.recv_with_time_sync(tcpconnectID,regist_data,&regist_data_length,10000);
  153. Log_Printf_Debug("解密前:\r\n");
  154. Log_SendHex(regist_data, regist_data_length);
  155. Log_Printf_Debug("\r\n");
  156. }
  157. if(result == Result_Success)
  158. {
  159. Log_Printf_Debug("数据返回成功\r\n");
  160. // 解析注册数据
  161. regist_flag = analysisRegistData(regist_data, regist_data_length, &regist_params_struct);
  162. printf_regist_param_struct(regist_params_struct);
  163. result=bc260y.close_socket_sync(tcpconnectID);//断开tcp连接
  164. }
  165. if(result==Result_Success)
  166. {
  167. Log_Printf_Debug("断开tcp连接成功\r\n");
  168. }
  169. // 注册失败,进入最小功能模式,防止耗电
  170. if(result == Result_Failed)
  171. {
  172. Log_Printf_Debug("设置最小功能模式\r\n");
  173. // bc260y.set_cfun_sync(0);//设置最小功能模式
  174. }
  175. return regist_flag;
  176. }
  177. uint8_t regist_device_sync(void)
  178. {
  179. flashdata.read_flag=0;
  180. //读取flash
  181. Log_Printf_Debug("读取前read_flag:%d\r\n",flashdata.read_flag);
  182. STMFLASH_Read(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));//读取flash
  183. my_delay_ms(10);
  184. //已经注册。读取flash成功
  185. if(flashdata.read_flag == 1)
  186. {
  187. register_status=1;
  188. Log_Printf_Debug("读取flash成功read_flag:%d,\ndeviceSecret:%s,\n productKey:%s,\ndeviceName:%s\r\n",flashdata.read_flag,flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName);
  189. return 1;
  190. }
  191. //未注册开始注册流程
  192. register_status=regist_Handle();//注册流程
  193. if (register_status==0)//注册流程失败不储存flash
  194. {
  195. clearflash();
  196. return 0;
  197. }
  198. else
  199. {
  200. storedata();//存储到flash
  201. return 1;
  202. }
  203. }
  204. enum Regist_Result regist_get_result(void)
  205. {
  206. if(register_status==1){
  207. return Regist_Result_Success;
  208. }
  209. else
  210. {
  211. return Regist_Result_Failure;
  212. }
  213. }
  214. char * regist_get_aliyun_productKey(void)
  215. {
  216. return flashdata.productKey;
  217. }
  218. char * regist_get_aliyun_deviceName(void)
  219. {
  220. return flashdata.deviceName;
  221. }
  222. char * regist_get_aliyun_deviceSecret(void)
  223. {
  224. return flashdata.deviceSecret;
  225. }
  226. #endif