task.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. #include "task.h"
  2. #include "cjson.h"
  3. #include "myFile.h"
  4. #include "gateway_message.h"
  5. #include "log.h"
  6. #include "malloc.h"
  7. #include "sx1276.h"
  8. #include "protocol.h"
  9. #include "usart.h"
  10. #include "node_data_acquisition.h"
  11. #include "sys_mqtt.h"
  12. #include "sys_http.h"
  13. #include "node_message.h"
  14. #include "usart.h"
  15. #include "mmodbus.h"
  16. #include "sys_mqtt.h"
  17. #include "gateway_message.h"
  18. #include "MQTTClient.h"
  19. #include "cJSON.h"
  20. #include "time_count.h"
  21. void master_task(uint8_t *string,uint16_t stringlength);
  22. void slave_task();
  23. int READ_MODBUS_DATA(DEVICE_PARAMS *current_device,char* buf);
  24. ///////////////////////////////////////////////////////////////////////////////////////////
  25. char string[512];
  26. void findDifference(char* data1, char* data2, char* string) ;
  27. int jsoncunt = 1;
  28. ////////////////////////////////////////////////////////////////////////////////////////////
  29. uint16_t BufferSize;
  30. uint8_t Buffer[256];
  31. uint32_t rx_num = 0;
  32. uint8_t PingMsg[] = "PING\0";
  33. uint8_t PongMsg[] = "PONG\0";
  34. tRadioDriver *Radio=NULL;
  35. /*
  36. *********************************************************************************************************
  37. * 函 数 名: void data_task(void *pdata)
  38. * 功能说明: 主要是data_task处理线程,优先级高。其运行逻辑是将nandflash中的数据解析出来轮询发送数据
  39. * 形 参:无
  40. * 返 回 值: 无
  41. *********************************************************************************************************
  42. */
  43. void data_task(void *pdata)
  44. {
  45. OS_CPU_SR cpu_sr;
  46. pdata = pdata;
  47. // Radio = RadioDriverInit();
  48. // Radio->Init();
  49. mmodbus_init(1);
  50. char *device_config_json = mymalloc(SRAMEX, 9 * 1024);
  51. read_file("device.txt", device_config_json);
  52. addGatewayParams(device_config_json);
  53. myfree(SRAMEX, device_config_json);
  54. GATEWAY_PARAMS *get;
  55. get= get_gateway_config_params();
  56. int deviceIndex=0;
  57. DEVICE_PARAMS *current_device=get->device_params;
  58. // uint32_t baudrate = get->baudrate;
  59. // uint8_t databits = get->dataBits;
  60. // uint8_t stopbits = get->stopBit;
  61. // uint8_t parity = get->parity;
  62. // uint8_t flowcontrol = get->flowControl;
  63. // Config_485_Port(baudrate, databits, stopbits, parity, flowcontrol);
  64. uint16_t bufferLength;
  65. OS_Q_DATA Qnum;
  66. StringInfo message;
  67. char *mqttRecv;
  68. uint8_t err;
  69. while (current_device!=NULL)
  70. {
  71. char buf[1000]; // 接收modbus读取的数据
  72. READ_MODBUS_DATA(current_device, buf);
  73. if(current_device->nextDevice!=NULL)
  74. {
  75. current_device=current_device->nextDevice;
  76. }
  77. else
  78. {
  79. sprintf(buf + strlen(buf) - 1, "}");
  80. time1 = OSTimeGet();
  81. if( jsoncunt || time2 <= time1 - 10000)
  82. {
  83. memset(pubJsonStringCopy,0, strlen(pubJsonStringCopy));
  84. memcpy(pubJsonStringCopy + strlen(pubJsonStringCopy), buf, strlen(buf));//备份上一次的数据
  85. sprintf(pubJsonString,"{\"DEVICEID\":\"%s\",\"data\":[%s]",get->deviceId, buf);
  86. int msg = MBOX_USER_PUBLISHQOS2;
  87. if(mqtt_connectFlag==1) OSMboxPost(mqtt_sendMseeageMbox, &msg);
  88. current_device=get->device_params;
  89. jsoncunt = 0;
  90. time2 = OSTimeGet();
  91. }//10s进行一次
  92. else
  93. {
  94. if(strcmp(buf,pubJsonStringCopy))
  95. {
  96. memset(string, 0 , strlen(string));
  97. findDifference(buf, pubJsonStringCopy, string);
  98. memset(pubJsonString,0, strlen(pubJsonString));
  99. sprintf(pubJsonString,"{\"deviceId\":\"%s\",\"data\":[{%s}]}",get->deviceId, string);
  100. memset(pubJsonStringCopy,0, strlen(pubJsonStringCopy));
  101. sprintf(pubJsonStringCopy, buf, strlen(buf));
  102. int msg = MBOX_USER_PUBLISHQOS2;
  103. if(mqtt_connectFlag==1) OSMboxPost(mqtt_sendMseeageMbox, &msg);
  104. }
  105. }
  106. memset(buf,0,strlen(buf));
  107. current_device=get->device_params;
  108. }
  109. }
  110. }
  111. #if 0 //测试代码不经过转发直接进行相应的解析
  112. SlaveProtocolAnalysis(string,bufferLength);
  113. data_acquisition();
  114. uint8_t node_string[256];
  115. uint16_t node_string_Length;
  116. nodeSendReaddValue(node_string,&node_string_Length);
  117. GatewayProtocolAnalysis(node_string,node_string_Length);
  118. #endif
  119. /*
  120. *********************************************************************************************************
  121. * 函 数 名: int READ_MODBUS_DATA(DEVICE_PARAMS *device)
  122. * 功能说明: 读取当前节点上的modbus数据
  123. * 形 参:DEVICE_PARAMS *device 当前设备
  124. * 返 回 值: 1 :成功 0:失败
  125. *********************************************************************************************************
  126. */
  127. int READ_MODBUS_DATA(DEVICE_PARAMS *device, char* buf)
  128. {
  129. DEVICE_PARAMS *current_device=device;
  130. GATEWAY_PARAMS* get;
  131. get = get_gateway_config_params();
  132. GATEWAY_READ_MODBUS_COMMAND *currentModbusParams = current_device->params->gateway_read_modbus_command;
  133. GATEWAY_READ_DLT645_COMMAND *currentDLT645Params = current_device->params->gateway_read_dlt645_command;
  134. while(current_device->params != NULL)
  135. {
  136. if (current_device->protocol == MODBUS_READ)
  137. {
  138. protocol_485=1;
  139. uint16_t data[currentModbusParams->registerByteNum /2]; // modbus寄存器长度
  140. mmodbus_set16bitOrder(current_device->MDBbigLittleFormat);
  141. if (currentModbusParams->functionCode == 0x03 | currentModbusParams->functionCode == 0x01)
  142. {
  143. bool success = mmodbus_readHoldingRegisters16i(currentModbusParams->slaveAddress,
  144. currentModbusParams->registerAddress,
  145. currentModbusParams->registerByteNum /2,
  146. data);
  147. if (success)
  148. {
  149. uint32_t value;
  150. if (currentModbusParams->registerByteNum == 4)
  151. {
  152. value = (uint32_t)data[0] | data[1];
  153. }
  154. else if (currentModbusParams->registerByteNum == 2)
  155. {
  156. value = data[0];
  157. }
  158. if (currentModbusParams->decimalPoint == 0)
  159. {
  160. currentModbusParams->value[0] = value;
  161. currentModbusParams->value[1] = value << 8;
  162. currentModbusParams->value[2] = value << 16;
  163. currentModbusParams->value[3] = value << 24;
  164. }
  165. else
  166. {
  167. float convertedValue = (float)value / pow(10, currentModbusParams->decimalPoint);
  168. memcpy(currentModbusParams->value, &convertedValue, 4);
  169. }
  170. sprintf(buf + strlen(buf), "{\"deviceId\":\"%s\",\"%s\":%d},",
  171. current_device->deviceID, currentModbusParams->keyword, value);
  172. currentModbusParams = currentModbusParams->nextParams;
  173. if (currentModbusParams == NULL)
  174. {
  175. sprintf(buf + strlen(buf) - 1, "");
  176. return 0;
  177. }
  178. }
  179. }
  180. }
  181. }
  182. return 1;
  183. }
  184. /*
  185. *********************************************************************************************************
  186. * 函 数 名:void WRITE_MODBUS_DATA(char* cJSONstring)
  187. * 功能说明: 接收mqtt数据并写入modbus寄存器
  188. * 形 参:char* cJSONstring mqtt接收到的数据
  189. * 返 回 值: 无
  190. *********************************************************************************************************
  191. */
  192. void WRITE_MODBUS_DATA(char* cJSONstring)
  193. {
  194. uint16_t data;
  195. uint16_t number;
  196. uint16_t slaveAddress;
  197. GATEWAY_PARAMS* get;
  198. get = get_gateway_config_params();
  199. DEVICE_PARAMS* current_device = get->device_params;
  200. cJSON *root = cJSON_Parse(cJSONstring);
  201. const char *deviceId = cJSON_GetStringValue(cJSON_GetObjectItem(root, "deviceId"));
  202. const cJSON *power = cJSON_GetObjectItemCaseSensitive(root, "power");
  203. const cJSON *temp = cJSON_GetObjectItemCaseSensitive(root, "temp");
  204. const cJSON *mode = cJSON_GetObjectItemCaseSensitive(root, "mode");
  205. const cJSON *fan = cJSON_GetObjectItemCaseSensitive(root, "fan");
  206. while(current_device)
  207. {
  208. char* device_ID = (char*)current_device->deviceID;
  209. GATEWAY_WRITE_MODBUS_COMMAND *currentModbusParams = current_device->params->gateway_write_modbus_command;
  210. if(!strcmp(device_ID,deviceId))
  211. {
  212. OSTimeDlyHMSM(0, 0, 0, 70);
  213. OSIntEnter();
  214. if(power)
  215. {
  216. slaveAddress = currentModbusParams->slaveAddress;
  217. number =currentModbusParams->registerAddress;
  218. data = power->valueint;
  219. mmodbus_writeHoldingRegister16i(slaveAddress, number, data);
  220. }
  221. if(temp)
  222. {
  223. currentModbusParams = currentModbusParams->nextParams;
  224. slaveAddress = currentModbusParams->slaveAddress;
  225. number =currentModbusParams->registerAddress;
  226. data = temp->valueint;
  227. mmodbus_writeHoldingRegister16i(slaveAddress, number, data);
  228. }
  229. if(mode)
  230. {
  231. currentModbusParams = currentModbusParams->nextParams;
  232. slaveAddress = currentModbusParams->slaveAddress;
  233. number =currentModbusParams->registerAddress;
  234. data = mode->valueint;
  235. mmodbus_writeHoldingRegister16i(slaveAddress, number, data);
  236. }
  237. if(fan)
  238. {
  239. currentModbusParams = currentModbusParams->nextParams;
  240. slaveAddress = currentModbusParams->slaveAddress;
  241. number =currentModbusParams->registerAddress;
  242. data = fan->valueint;
  243. mmodbus_writeHoldingRegister16i(slaveAddress, number, data);
  244. }
  245. OSIntExit();
  246. }
  247. current_device = current_device->nextDevice;
  248. }
  249. cJSON_Delete(root);
  250. }
  251. // 比较两个 JSONItem 数组,找到变化的部分
  252. void findDifference(char* buf, char* pubJsonStringCopy, char* string)
  253. {
  254. const char* delimiter = "{}";
  255. char* saveptr1;
  256. char* saveptr2;
  257. char* data1 = malloc(strlen(buf) + 1);
  258. char* data2 = malloc(strlen(pubJsonStringCopy) + 1); ;
  259. memcpy(data1, buf, strlen(buf));
  260. memcpy(data2, pubJsonStringCopy, strlen(pubJsonStringCopy));
  261. // 利用strtok_r函数分割字符串,并逐一比较
  262. char* token1 = strtok_r((char*)data1, delimiter, &saveptr1);
  263. char* token2 = strtok_r((char*)data2, delimiter, &saveptr2);
  264. while (token1 != NULL && token2 != NULL) {
  265. if (strcmp(token1, token2) != 0) {
  266. memcpy(string + strlen(string), token1, strlen(token1));
  267. }
  268. token1 = strtok_r(NULL, delimiter, &saveptr1);
  269. token2 = strtok_r(NULL, delimiter, &saveptr2);
  270. }
  271. // // 如果有剩余字符串未比较,则打印剩余字符串
  272. // while (token1 != NULL) {
  273. // sprintf(string + strlen(string),"%s,", token1);
  274. // token1 = strtok_r(NULL, delimiter, &saveptr1);
  275. // }
  276. // while (token2 != NULL) {
  277. // //sprintf(string + strlen(string),"{%s},", token2);
  278. // token2 = strtok_r(NULL, delimiter, &saveptr2);
  279. // }
  280. free(data1);
  281. free(data2);
  282. }