Ec800m_Regist.c 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. #include "CONFIG.h"
  2. #if EC800M
  3. #include "stm32f10x.h"
  4. #include "Regist.h"
  5. #include "FlashSetup.h"
  6. #include <stdio.h>
  7. #include <stdarg.h>
  8. #include <string.h>
  9. #include <stdlib.h>
  10. #include "cJSON.h"
  11. #include "mbedtls_util.h"
  12. #include "Log_Module.h"
  13. #include "At_Module.h"
  14. #include "Common_Util.h"
  15. #include "Tuoreniot.h"
  16. #include "ec800m.h"
  17. // socket ID
  18. static uint8_t connectID = 2;
  19. // 注册参数
  20. static struct TUORENIOT_RegistRequestStruct regist_request = {
  21. .version = 1,
  22. .networkType = 2,
  23. .networkProtocol = 1,
  24. .deviceId = "3431228A1936013C",
  25. .userId = "1000"
  26. };
  27. // 函数声明
  28. static void REGIST_Process(void); // 注册流程
  29. static void REGIST_SetStatus(enum REGIST_StatusEnum status); // 设置注册状态
  30. static void REGIST_SetResult(enum REGIST_ResultEnum result); // 设置注册结果
  31. static void goto_start(void); // 开始
  32. static void goto_success(void); // 成功
  33. static void goto_failure(char * _info); // 失败
  34. static void goto_finish(void); // 结束
  35. // 流程
  36. enum Step{
  37. STEP_START, // 开始
  38. STEP_EXIT_SLEEP, // 退出睡眠
  39. STEP_ENTER_SLEEP, // 进入睡眠
  40. STEP_WAIT, // 等待
  41. STEP_STATE, // 查询状态
  42. STEP_OPEN, // 打开
  43. STEP_OPEN_WAIT_RESULT, // 等待打开结果
  44. STEP_JUDGE_AUTH_OR_DATA, // 判断认证还是发送
  45. STEP_JOIN_AUTH_MESSAGE, // 拼接认证报文
  46. STEP_JOIN_DATA_MESSAGE, // 拼接数据报文
  47. STEP_QUERY_SLEEP, // 查询休眠
  48. STEP_SET_SLEEP, // 开启休眠
  49. STEP_QUERY_QENG_SERVINGCELL, // 查询信号质量
  50. STEP_SET_QISDE_0, // 关闭发送回显
  51. STEP_SEND, // 发送
  52. STEP_RECV, // 等待发送结果
  53. STEP_SET_CFUN_0, // 设置最小功能模式
  54. STEP_WAIT_SET_CFUN_0, // 等待设置最小功能模式
  55. STEP_SET_CFUN_1, // 设置全功能模式
  56. STEP_WAIT_SET_CFUN_1, // 等待设置全功能模式结果
  57. STEP_SET_CGREG_2, // 设置ps域允许上报网络注册和位置信息
  58. STEP_QUERY_CGREG, // 查询网络注册状态
  59. STEP_CLOSE, // 关闭
  60. STEP_SUCCESS, // 成功
  61. STEP_FAILURE, // 失败
  62. STEP_FINISH, // 流程结束
  63. STEP_VERIFY_REGIST, // 验证注册
  64. STEP_VERIFY_INITIALIZE, // 验证初始化
  65. };
  66. // 步骤跳转时的监听
  67. static uint8_t STEP_QUERY_CGREG_times = 0; // 查询网络状态的次数
  68. static void initialize()
  69. {
  70. STEP_QUERY_CGREG_times = 0;
  71. }
  72. static uint16_t goto_step_event(uint16_t ns)
  73. {
  74. // 重置ec800m状态
  75. ec800m.reset();
  76. // 流程控制
  77. uint16_t step = ns;
  78. if(ns == STEP_QUERY_CGREG && STEP_QUERY_CGREG_times++ >= 20)
  79. {
  80. goto_failure("查询网络状态的次数过多,联网失败");
  81. step = STEP_FAILURE;
  82. }
  83. return step;
  84. }
  85. // 流程控制
  86. static struct PCTRL_Struct pctrl = {
  87. .current_step = STEP_FINISH,
  88. .next_step = STEP_FINISH,
  89. .step_wait = STEP_WAIT,
  90. .goto_step_listener = goto_step_event,
  91. };
  92. // 备注
  93. static char info[40];
  94. // 开始
  95. static void goto_start(void)
  96. {
  97. initialize();
  98. PCTRL_GotoStep(&pctrl, STEP_START, "开始");
  99. }
  100. // 成功
  101. static void goto_success(void)
  102. {
  103. REGIST_SetResult(REGIST_Result_Success);
  104. PCTRL_GotoStep(&pctrl, STEP_SUCCESS, "成功");
  105. }
  106. // 失败
  107. static void goto_failure(char * _info)
  108. {
  109. REGIST_SetResult(REGIST_Result_Failure);
  110. memset(info, 0, sizeof(info));
  111. strcpy(info, _info);
  112. PCTRL_GotoStep(&pctrl, STEP_FAILURE, "失败");
  113. Log_Printf_Debug("info:%s!\r\n", info);
  114. }
  115. // 结束
  116. static void goto_finish(void)
  117. {
  118. REGIST_SetStatus(REGIST_Status_Done);
  119. PCTRL_GotoStep(&pctrl, STEP_FINISH, "结束");
  120. }
  121. // 注册状态
  122. static enum REGIST_StatusEnum regist_status = REGIST_Status_None;
  123. // 注册结果
  124. static enum REGIST_ResultEnum regist_result = REGIST_Result_None;
  125. // 设置注册状态
  126. static void REGIST_SetStatus(enum REGIST_StatusEnum status)
  127. {
  128. regist_status = status;
  129. }
  130. // 获取注册状态
  131. enum REGIST_StatusEnum REGIST_GetStatus(void)
  132. {
  133. return regist_status;
  134. }
  135. // 设置注册结果
  136. static void REGIST_SetResult(enum REGIST_ResultEnum result)
  137. {
  138. regist_result = result;
  139. }
  140. // 获取注册结果
  141. enum REGIST_ResultEnum REGIST_GetResult(void)
  142. {
  143. return regist_result;
  144. }
  145. // 重置注册
  146. enum EXECUTE_ResultEnum REGIST_Reset(void)
  147. {
  148. if(REGIST_GetStatus() == REGIST_Status_Being)
  149. {
  150. Log_Printf_Debug("注册流程重置错误!\r\n");
  151. return EXECUTE_Result_Failure;
  152. }
  153. REGIST_SetStatus(REGIST_Status_None);
  154. REGIST_SetResult(REGIST_Result_None);
  155. return EXECUTE_Result_Success;
  156. }
  157. // 开始注册
  158. enum EXECUTE_ResultEnum REGIST_Start(void)
  159. {
  160. REGIST_Reset();
  161. if(REGIST_GetStatus() != REGIST_Status_None)
  162. {
  163. Log_Printf_Debug("注册流程启动错误!\r\n");
  164. return EXECUTE_Result_Failure;
  165. }
  166. goto_start();
  167. REGIST_SetStatus(REGIST_Status_Being);
  168. return EXECUTE_Result_Success;
  169. }
  170. // 注册流程处理,放到大循环里
  171. void REGIST_ProcessHandle(void)
  172. {
  173. if(REGIST_GetStatus() == REGIST_Status_Being)
  174. {
  175. REGIST_Process();
  176. }
  177. }
  178. // 发送数据的逻辑
  179. static enum Result result = Result_None;
  180. static uint8_t cgreg_n;
  181. static uint8_t cgreg_stat;
  182. static uint16_t cgreg_lac;
  183. static uint32_t cgreg_ci;
  184. static uint16_t socket_err = 0;
  185. static void REGIST_Process(void)
  186. {
  187. // 流程
  188. switch(pctrl.current_step)
  189. {
  190. case STEP_START: // 开始
  191. PCTRL_GotoStep(&pctrl, STEP_EXIT_SLEEP, "退出休眠");
  192. break;
  193. case STEP_EXIT_SLEEP: // 退出休眠
  194. ec800m.exit_sleep();
  195. PCTRL_GotoStepWait(&pctrl, STEP_SET_SLEEP, 3, "设置休眠模式");
  196. break;
  197. case STEP_SET_SLEEP: // 设置休眠模式
  198. result = ec800m.set_sleep(1);
  199. if(result != Result_None)
  200. {
  201. PCTRL_GotoStep(&pctrl, STEP_SET_CFUN_1, "设置全功能模式");
  202. }
  203. else if(result == Result_Failed)
  204. {
  205. goto_failure("设置休眠模式失败");
  206. }
  207. break;
  208. case STEP_SET_CFUN_1: // 设置全功能模式
  209. result = ec800m.set_cfun(1);
  210. if(result == Result_Success)
  211. {
  212. PCTRL_GotoStep(&pctrl, STEP_SET_CGREG_2, "设置ps域");
  213. }
  214. else if(result == Result_Failed)
  215. {
  216. goto_failure("设置全功能模式失败");
  217. }
  218. break;
  219. case STEP_SET_CGREG_2: // 设置ps域
  220. result = ec800m.set_cgreg(2);
  221. if(result == Result_Success)
  222. {
  223. PCTRL_GotoStep(&pctrl, STEP_QUERY_CGREG, "查询ps域");
  224. }
  225. else if(result == Result_Failed)
  226. {
  227. goto_failure("设置ps域失败");
  228. }
  229. break;
  230. case STEP_QUERY_CGREG: // 查询ps域
  231. result = ec800m.query_cgreg(&cgreg_n, &cgreg_stat, &cgreg_lac, &cgreg_ci);
  232. if(result == Result_Success)
  233. {
  234. if(cgreg_stat == 1)
  235. {
  236. PCTRL_GotoStep(&pctrl, STEP_CLOSE, "断开tcp连接");
  237. }
  238. else
  239. {
  240. PCTRL_GotoWait(&pctrl, 500);
  241. }
  242. }
  243. else if(result == Result_Failed)
  244. {
  245. goto_failure("查询ps域失败");
  246. }
  247. break;
  248. case STEP_CLOSE: // 关闭连接
  249. result = ec800m.close_socket(connectID);
  250. if(result == Result_Success)
  251. {
  252. if(REGIST_GetResult() != REGIST_Result_None)
  253. {
  254. PCTRL_GotoStep(&pctrl, STEP_SET_CFUN_0, "设置最小功能模式");
  255. }
  256. else
  257. {
  258. PCTRL_GotoStep(&pctrl, STEP_SET_QISDE_0, "关闭发送回显");
  259. }
  260. }
  261. else if(result == Result_Failed)
  262. {
  263. goto_failure("断开tcp连接失败");
  264. }
  265. break;
  266. case STEP_SET_QISDE_0: // 关闭发送回显
  267. result = ec800m.set_qisde(0);
  268. if(result == Result_Success)
  269. {
  270. PCTRL_GotoStep(&pctrl, STEP_OPEN, "连接tcp");
  271. }
  272. else if(result == Result_Failed)
  273. {
  274. goto_failure("关闭发送回显失败");
  275. }
  276. break;
  277. case STEP_OPEN: // 打开客户端
  278. result=ec800m.open_socket(connectID, "TCP", REGIST_SERVER, REGIST_PORT, 1, &socket_err);
  279. if(result == Result_Success)
  280. {
  281. PCTRL_GotoStep(&pctrl, STEP_SEND, "发送数据");
  282. // 打包注册请求
  283. memset(regist_data, 0, sizeof(regist_data));
  284. TUORENIOT_PackRegistRequest(regist_data, &regist_data_length, &regist_request);
  285. Log_Printf_Debug("regist_data: \r\n");
  286. Log_SendHex(regist_data, regist_data_length);
  287. Log_Printf_Debug("\r\n");
  288. TUORENIOT_PrintfRegistRequestStruct(&regist_request);
  289. }
  290. else if(result == Result_Failed)
  291. {
  292. goto_failure("连接tcp失败");
  293. }
  294. break;
  295. case STEP_SEND: // 发送send
  296. result = ec800m.send(connectID, regist_data, regist_data_length);
  297. if(result == Result_Success)
  298. {
  299. PCTRL_GotoStep(&pctrl, STEP_RECV, "等待结果");
  300. memset(regist_data, 0, sizeof(regist_data));
  301. }
  302. else if(result == Result_Failed)
  303. {
  304. goto_failure("发送数据失败");
  305. }
  306. break;
  307. case STEP_RECV: // 等待结果
  308. result = ec800m.recv_with_time(connectID, regist_data, &regist_data_length, 10000);
  309. if(result == Result_Success)
  310. {
  311. uint8_t res = TUORENIOT_AnalysisRegistData(regist_data, regist_data_length);
  312. if(res == 1) // 成功
  313. {
  314. goto_success();
  315. }
  316. else // 失败
  317. {
  318. goto_failure("解析失败");
  319. }
  320. PCTRL_GotoStep(&pctrl, STEP_CLOSE, "断开tcp连接");
  321. }
  322. else if(result == Result_Failed)
  323. {
  324. goto_failure("等待结果失败");
  325. }
  326. break;
  327. case STEP_SET_CFUN_0: // 设置最小功能模式
  328. result = ec800m.set_cfun(0);
  329. if(result != Result_None)
  330. {
  331. PCTRL_GotoStep(&pctrl, STEP_ENTER_SLEEP, "进入睡眠");
  332. }
  333. break;
  334. case STEP_ENTER_SLEEP: // 进入睡眠
  335. ec800m.enter_sleep();
  336. goto_finish();
  337. break;
  338. case STEP_WAIT: // 等待
  339. PCTRL_Wait(&pctrl);
  340. break;
  341. case STEP_SUCCESS: // 成功
  342. PCTRL_GotoStep(&pctrl, STEP_SET_CFUN_0, "设置最小功能模式");
  343. break;
  344. case STEP_FAILURE: // 失败
  345. PCTRL_GotoStep(&pctrl, STEP_SET_CFUN_0, "设置最小功能模式");
  346. break;
  347. case STEP_FINISH: // 结束流程
  348. break;
  349. default:
  350. goto_failure("步骤不存在");
  351. break;
  352. }
  353. }
  354. #endif