Bc260y_Regist.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  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 "Delay.h"
  28. #include "mbedtls_util.h"
  29. #include "Log_Module.h"
  30. #include "At_Module.h"
  31. #include "Common_Util.h"
  32. #include "Tuoreniot.h"
  33. static uint8_t register_status;//注册成功,向flash存储标志
  34. static Coefficient_Data flashdata;
  35. static uint8_t mcu_id[8]="ceshi001";
  36. // 生成环境
  37. static char * REGIST_SERVER = "iot.tuoren.com" ; //注册服务器地址
  38. static uint16_t REGIST_PORT = 8888; //端口号
  39. static uint8_t tcpconnectID = 2;
  40. // 开发环境
  41. //static char * REGIST_SERVER = "z18z017026.51vip.biz" ; //注册服务器地址
  42. //static uint16_t REGIST_PORT = 31396; //端口号
  43. // 注册参数
  44. static struct Regist_Params_Struct regist_params_struct = {
  45. .platform = "aliyun",
  46. .connType = "CoAP",
  47. .deviceId = "123456",
  48. .userId = 4562
  49. };
  50. static uint8_t regist_data[512];
  51. static uint16_t regist_data_length;
  52. //清空flash
  53. void clearflash(void){
  54. flashdata.read_flag=0;
  55. memset(flashdata.deviceSecret, 0, sizeof(flashdata.deviceSecret));
  56. memset(flashdata.productKey, 0, sizeof(flashdata.productKey));
  57. memset(flashdata.deviceName, 0, sizeof(flashdata.deviceName));
  58. delay_ms(10);
  59. STMFLASH_Write(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  60. }
  61. void storedata(void)
  62. {
  63. flashdata.read_flag=1;
  64. strcpy(flashdata.deviceSecret, regist_params_struct.deviceSecret);
  65. strcpy(flashdata.productKey, regist_params_struct.productKey);
  66. strcpy(flashdata.deviceName, regist_params_struct.deviceName);
  67. delay_ms(10);
  68. STMFLASH_Write(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  69. flashdata.read_flag=0;
  70. delay_ms(10);
  71. Log_Printf_Debug("写入数据完成\r\n");
  72. STMFLASH_Read(FLASH_SAVE_ADDR,(uint16_t*)&flashdata,sizeof(flashdata));
  73. Log_Printf_Debug("读取完成read_flag:%d,deviceSecret:%s,productKey:%s,deviceName:%s\r\n",flashdata.read_flag,flashdata.deviceSecret,flashdata.productKey,flashdata.deviceName);
  74. }
  75. uint8_t regist_Handle()
  76. {
  77. uint8_t mode,stat,regist_flag = 0;
  78. uint16_t lac,err = 0;
  79. uint32_t ci = 0;
  80. enum Result result = Result_None;
  81. GPIO_SetBits(WAKE_GPIO, WAKE_GPIO_Pin);
  82. bc260y.exit_sleep_sync();//退出休眠
  83. delay_ms(100);
  84. bc260y.reset();
  85. result = bc260y.set_qisde_sync(0);//关闭回显
  86. if(result==Result_Failed)
  87. {
  88. return 0;
  89. }
  90. result=bc260y.set_sleep_sync(1);//设置休眠模式
  91. if(result==Result_Failed)
  92. {
  93. return 0;
  94. }
  95. result=bc260y.set_cfun_sync(1);//设置全功能模式
  96. if(result==Result_Failed)
  97. {
  98. return 0;
  99. }
  100. result=bc260y.set_cgreg_sync(2);//设置网络状态
  101. if(result==Result_Failed)
  102. {
  103. return 0;
  104. }
  105. for(int i=0;i<20;i++){
  106. delay_ms(400);
  107. result=bc260y.query_cgreg_sync(&mode,&stat,&lac,&ci);//循环查询网络状态最多20次
  108. if(stat==1)
  109. {i=20;
  110. }
  111. }
  112. // if(result==Result_Failed)
  113. // {
  114. // return 0;
  115. // }
  116. // if(stat==0)
  117. // {
  118. // Log_Printf_Debug(" stat=%d\r\n", stat);
  119. // return 0;
  120. // }
  121. if(result==Result_Success&&stat==1)
  122. {
  123. result=bc260y.close_socket_sync(tcpconnectID);//防止以前链接没断开,断开tcp链接
  124. }
  125. if(result==Result_Failed)
  126. {
  127. Log_Printf_Debug(" result=%d\r\n", result);
  128. return 0;
  129. }
  130. //tcp连接流程
  131. result=bc260y.open_socket_sync(tcpconnectID,"TCP",REGIST_SERVER,REGIST_PORT,1,&err);//连接tcp
  132. if(result==Result_Failed)
  133. {
  134. Log_Printf_Debug(" result=%d\r\n", result);
  135. return 0;
  136. }
  137. if(result==Result_Success)
  138. {
  139. memset(regist_data, 0, sizeof(regist_data));
  140. byteToHexStr(mcu_id, regist_params_struct.deviceId, sizeof(mcu_id));
  141. packRegistParams(regist_data, &regist_data_length, regist_params_struct);
  142. printf_regist_param_struct(regist_params_struct);
  143. result =bc260y.send_sync(tcpconnectID, regist_data, regist_data_length);//数据发送
  144. }
  145. result = bc260y.dataformat_sync(1);//配置发送数据格式
  146. if(result==Result_Failed)
  147. {
  148. return 0;
  149. }
  150. if(result==Result_Success)
  151. {
  152. memset(regist_data, 0, sizeof(regist_data));
  153. result =bc260y.recv_with_time_sync(tcpconnectID,regist_data,&regist_data_length,10000);
  154. if(result==Result_Failed)
  155. {
  156. return result;
  157. }
  158. // 解析注册数据
  159. regist_flag = analysisRegistData(regist_data, regist_data_length, &regist_params_struct);
  160. printf_regist_param_struct(regist_params_struct);
  161. }
  162. if(result==Result_Success)
  163. {
  164. result=bc260y.close_socket_sync(tcpconnectID);//断开tcp连接
  165. }
  166. bc260y.enter_sleep();//进入休眠状态
  167. return regist_flag;
  168. }
  169. uint8_t regist_device_sync(void)
  170. {
  171. flashdata.read_flag=0;
  172. //读取flash
  173. Log_Printf_Debug("读取前read_flag:%d\r\n",flashdata.read_flag);
  174. STMFLASH_Read(FLASH_SAVE_ADDR,(u16*)&flashdata,sizeof(flashdata));//读取flash
  175. delay_ms(10);
  176. //已经注册。读取flash成功
  177. if(flashdata.read_flag == 1)
  178. {
  179. register_status=1;
  180. 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);
  181. return 1;
  182. }
  183. //未注册开始注册流程
  184. register_status=regist_Handle();//注册流程
  185. if (register_status==0)//注册流程失败不储存flash
  186. {
  187. clearflash();
  188. return 0;
  189. }
  190. else
  191. {
  192. storedata();//存储到flash
  193. return 1;
  194. }
  195. }
  196. enum Regist_Result regist_get_result(void)
  197. {
  198. if(register_status==1){
  199. return Regist_Result_Success;
  200. }
  201. else
  202. {
  203. return Regist_Result_Failure;
  204. }
  205. }
  206. char * regist_get_aliyun_productKey(void)
  207. {
  208. return flashdata.productKey;
  209. }
  210. char * regist_get_aliyun_deviceName(void)
  211. {
  212. return flashdata.deviceName;
  213. }
  214. char * regist_get_aliyun_deviceSecret(void)
  215. {
  216. return flashdata.deviceSecret;
  217. }
  218. #endif