sys_data.c 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. #include "sys_data.h"
  2. #include "led.h"
  3. #include "usart.h"
  4. #include "time.h"
  5. USART_MSG_t usartMsg;
  6. static const uint16_t wCRCTable[] =
  7. {
  8. 0X0000, 0XC0C1, 0XC181, 0X0140, 0XC301, 0X03C0, 0X0280, 0XC241,
  9. 0XC601, 0X06C0, 0X0780, 0XC741, 0X0500, 0XC5C1, 0XC481, 0X0440,
  10. 0XCC01, 0X0CC0, 0X0D80, 0XCD41, 0X0F00, 0XCFC1, 0XCE81, 0X0E40,
  11. 0X0A00, 0XCAC1, 0XCB81, 0X0B40, 0XC901, 0X09C0, 0X0880, 0XC841,
  12. 0XD801, 0X18C0, 0X1980, 0XD941, 0X1B00, 0XDBC1, 0XDA81, 0X1A40,
  13. 0X1E00, 0XDEC1, 0XDF81, 0X1F40, 0XDD01, 0X1DC0, 0X1C80, 0XDC41,
  14. 0X1400, 0XD4C1, 0XD581, 0X1540, 0XD701, 0X17C0, 0X1680, 0XD641,
  15. 0XD201, 0X12C0, 0X1380, 0XD341, 0X1100, 0XD1C1, 0XD081, 0X1040,
  16. 0XF001, 0X30C0, 0X3180, 0XF141, 0X3300, 0XF3C1, 0XF281, 0X3240,
  17. 0X3600, 0XF6C1, 0XF781, 0X3740, 0XF501, 0X35C0, 0X3480, 0XF441,
  18. 0X3C00, 0XFCC1, 0XFD81, 0X3D40, 0XFF01, 0X3FC0, 0X3E80, 0XFE41,
  19. 0XFA01, 0X3AC0, 0X3B80, 0XFB41, 0X3900, 0XF9C1, 0XF881, 0X3840,
  20. 0X2800, 0XE8C1, 0XE981, 0X2940, 0XEB01, 0X2BC0, 0X2A80, 0XEA41,
  21. 0XEE01, 0X2EC0, 0X2F80, 0XEF41, 0X2D00, 0XEDC1, 0XEC81, 0X2C40,
  22. 0XE401, 0X24C0, 0X2580, 0XE541, 0X2700, 0XE7C1, 0XE681, 0X2640,
  23. 0X2200, 0XE2C1, 0XE381, 0X2340, 0XE101, 0X21C0, 0X2080, 0XE041,
  24. 0XA001, 0X60C0, 0X6180, 0XA141, 0X6300, 0XA3C1, 0XA281, 0X6240,
  25. 0X6600, 0XA6C1, 0XA781, 0X6740, 0XA501, 0X65C0, 0X6480, 0XA441,
  26. 0X6C00, 0XACC1, 0XAD81, 0X6D40, 0XAF01, 0X6FC0, 0X6E80, 0XAE41,
  27. 0XAA01, 0X6AC0, 0X6B80, 0XAB41, 0X6900, 0XA9C1, 0XA881, 0X6840,
  28. 0X7800, 0XB8C1, 0XB981, 0X7940, 0XBB01, 0X7BC0, 0X7A80, 0XBA41,
  29. 0XBE01, 0X7EC0, 0X7F80, 0XBF41, 0X7D00, 0XBDC1, 0XBC81, 0X7C40,
  30. 0XB401, 0X74C0, 0X7580, 0XB541, 0X7700, 0XB7C1, 0XB681, 0X7640,
  31. 0X7200, 0XB2C1, 0XB381, 0X7340, 0XB101, 0X71C0, 0X7080, 0XB041,
  32. 0X5000, 0X90C1, 0X9181, 0X5140, 0X9301, 0X53C0, 0X5280, 0X9241,
  33. 0X9601, 0X56C0, 0X5780, 0X9741, 0X5500, 0X95C1, 0X9481, 0X5440,
  34. 0X9C01, 0X5CC0, 0X5D80, 0X9D41, 0X5F00, 0X9FC1, 0X9E81, 0X5E40,
  35. 0X5A00, 0X9AC1, 0X9B81, 0X5B40, 0X9901, 0X59C0, 0X5880, 0X9841,
  36. 0X8801, 0X48C0, 0X4980, 0X8941, 0X4B00, 0X8BC1, 0X8A81, 0X4A40,
  37. 0X4E00, 0X8EC1, 0X8F81, 0X4F40, 0X8D01, 0X4DC0, 0X4C80, 0X8C41,
  38. 0X4400, 0X84C1, 0X8581, 0X4540, 0X8701, 0X47C0, 0X4680, 0X8641,
  39. 0X8201, 0X42C0, 0X4380, 0X8341, 0X4100, 0X81C1, 0X8081, 0X4040};
  40. // crc校验
  41. uint16_t Checkcrc16(const uint8_t *nData, uint16_t wLength)
  42. {
  43. uint8_t nTemp;
  44. uint16_t wCRCWord = 0xFFFF;
  45. while (wLength--)
  46. {
  47. nTemp = *nData++ ^ wCRCWord;
  48. wCRCWord >>= 8;
  49. wCRCWord ^= wCRCTable[nTemp];
  50. }
  51. return wCRCWord;
  52. }
  53. uint8_t result ;
  54. // 校验码
  55. unsigned char CheckXor(const uint8_t *strData,int len)
  56. {
  57. char checksum = 0;
  58. for (int i = 0;i < len;i++)
  59. {
  60. checksum = checksum ^ strData[i];
  61. }
  62. return (unsigned char)checksum;
  63. }
  64. void call_back()
  65. {
  66. // 检测发送完成标志位
  67. if (RESET != USART_GetFlagStatus(USART_232,USART_FLAG_RXNE))
  68. {
  69. if (usartMsg.rxIndex < _USART3_RXSIZE - 1){
  70. usartMsg.rxBuf[usartMsg.rxIndex] = USART_ReceiveData(USART_232);
  71. usartMsg.rxIndex++;
  72. }
  73. else
  74. USART_ReceiveData(USART_232);
  75. }
  76. // 检测空闲标志位
  77. if ((usartMsg.rxIndex > 0) && RESET != USART_GetFlagStatus(USART_232, USART_FLAG_IDLE))
  78. {
  79. uint8_t i;
  80. usartMsg.done = 1;
  81. // 清除空闲中断
  82. i = USART_232->SR; // 先读取SR寄存器
  83. i = USART_232->DR; // 再读取DR寄存器
  84. }
  85. else
  86. {
  87. uint8_t i;
  88. // 清除空闲中断
  89. i = USART_232->SR; // 先读取SR寄存器
  90. i = USART_232->DR; // 再读取DR寄存器
  91. }
  92. }
  93. // 发送回馈信息
  94. int sendCmd(uint8_t *data, uint16_t size)
  95. {
  96. while(usartMsg.txBusy == 1)
  97. {
  98. delay_ms(10);
  99. }
  100. usartMsg.txBusy = 1;
  101. memset(usartMsg.rxBuf, 0, _USART3_RXSIZE);
  102. usartMsg.rxIndex = 0;
  103. delay_ms(1);
  104. for (uint16_t i = 0; i < size; i++)
  105. {
  106. USART_SendData(USART_232,data[i]);
  107. while (USART_GetFlagStatus(USART_232, USART_FLAG_TXE) == RESET);
  108. }
  109. while (RESET == USART_GetFlagStatus(USART_232, USART_FLAG_TC));
  110. usartMsg.done=0;
  111. usartMsg.txBusy = 0;
  112. return 1;
  113. }
  114. // 文件更新升级
  115. //uint8_t updata()
  116. //{
  117. // uint16_t crc;
  118. // uint8_t databuf[1024];
  119. // uint16_t packId = 0x01;
  120. // uint8_t i = 30,c = 0x63,ack = 0x06,nack = 0x15;
  121. // // 发送第一个'c'
  122. // sendCmd(&c,1);
  123. // //检测 3s 内有无收到数据
  124. // for(int i = 0; i < 3000; i++)
  125. // {
  126. // delay_ms(1);
  127. // // 收到数据,跳转到处理数据
  128. // if(usartMsg.done == 1)
  129. // {
  130. // goto __start;
  131. // }
  132. // }
  133. // //3s 内未收到第一包数据,再发送'c'
  134. // sendCmd(&c,1);
  135. //__start:
  136. // // 开始处理数据
  137. // // 当数据包为EOT(0x04),表示结束
  138. // while(usartMsg.done == 1 && usartMsg.rxBuf[0] != 0x04)
  139. // {
  140. // // 检测帧头
  141. // if(usartMsg.rxBuf[0] != 0x02)
  142. // {
  143. // sendCmd(&nack,1);
  144. // goto __start;
  145. // }
  146. // // 检测包序列
  147. // if(usartMsg.rxBuf[1] != packId)
  148. // {
  149. // sendCmd(&nack,1);
  150. // goto __start;
  151. // }
  152. // // 检测包号反码
  153. // if(usartMsg.rxBuf[2] != ~packId)
  154. // {
  155. // sendCmd(&nack,1);
  156. // goto __start;
  157. // }
  158. // // 提取数据包
  159. // for(int i = 0; i < 1024; i++)
  160. // {
  161. // databuf[i] = usartMsg.rxBuf[3 + i];
  162. // }
  163. // crc = Checkcrc16(databuf, 1024);
  164. // // 检测数据包的校验码
  165. // if (((crc & 0x00FF) != usartMsg.rxBuf[1028]) || (((crc & 0xFF00) >> 8) != usartMsg.rxBuf[1027]))
  166. // {
  167. // sendCmd(&nack,1);
  168. // goto __start;
  169. // }
  170. // // 准备接收下一包数据
  171. // sendCmd(&ack,1);
  172. // packId += 1;
  173. // }
  174. // // 接收到结束信号,反馈ack
  175. // sendCmd(&ack,1);
  176. // if(packId != 0)
  177. // return 1;
  178. // else
  179. // return 2;
  180. //}
  181. void broad_to_host()
  182. {
  183. int i, j;
  184. // 数据包大小
  185. int packIndex = 0;
  186. result = 2;// 初始化为 2 表示操作失败(硬件故障或其他原因)
  187. // 反馈信息
  188. uint8_t txData[8];
  189. // 校验位验证信息
  190. uint8_t crc[1 + (4 * usartMsg.rxBuf[4])];
  191. // 判断帧头帧尾
  192. if(usartMsg.rxBuf[0] != 0xAA || usartMsg.rxBuf[1] != 0xFF || usartMsg.rxBuf[2] != 0x55 || usartMsg.rxBuf[3] != 0xCC|| usartMsg.rxBuf[10 + (4 * (usartMsg.rxBuf[4] - 1))] != 0xDD || usartMsg.rxBuf[11 + (4 * (usartMsg.rxBuf[4] - 1))] != 0xFF)
  193. {
  194. result = 0x04;//帧头/帧尾异常
  195. goto __feedback;
  196. }
  197. // 判断指令数
  198. if(usartMsg.rxBuf[4] < 1 || usartMsg.rxBuf[4] > 255)
  199. {
  200. result = 5;//帧内容异常(指令值超出范围等)
  201. goto __feedback;
  202. }
  203. // 判断校验位
  204. // 提取指令数
  205. crc[0] = usartMsg.rxBuf[4];
  206. // 提取指令码、channel、平台号、指令值
  207. for(j = 0; j < usartMsg.rxBuf[4] * 4;j += 4)
  208. {
  209. crc[1 + j] = usartMsg.rxBuf[5+ j];//指令码
  210. crc[2 + j] = usartMsg.rxBuf[6+ j];//channel
  211. crc[3 + j] = usartMsg.rxBuf[7+ j];//平台号
  212. crc[4 + j] = usartMsg.rxBuf[8+ j];//指令值
  213. packIndex++;
  214. }
  215. if((CheckXor(crc,1 + (4 * usartMsg.rxBuf[4])) != usartMsg.rxBuf[9 + (4 * (usartMsg.rxBuf[4] - 1))]))
  216. {
  217. result = 0x03;//校验位异常
  218. goto __feedback;
  219. }
  220. // 数据包判断
  221. if(usartMsg.rxBuf[4] != packIndex )
  222. {
  223. result = 5;//帧内容异常(指令值超出范围等)
  224. goto __feedback;
  225. }
  226. // 执行指令
  227. for(i = 0; i < usartMsg.rxBuf[4] * 4;i += 4)
  228. {
  229. // 判断指令码
  230. switch (usartMsg.rxBuf[5 + i])
  231. {
  232. case 0x01: // LED指令
  233. result = channel_LED(usartMsg.rxBuf[6 + i], i);
  234. if(result != 1) goto __feedback;
  235. break;
  236. case 0x02: // 12V BAT指令
  237. result = channel_12VBAT(usartMsg.rxBuf[6 + i], i);
  238. if(result != 1) goto __feedback;
  239. break;
  240. case 0x03: // 5V BAT指令 channel和平台号固定为0x00
  241. result = channel_5VBAT(usartMsg.rxBuf[8 + i]);
  242. if(result != 1)goto __feedback;
  243. break;
  244. // case 0x04: // updata指令
  245. // if(usartMsg.rxBuf[8] == 1)
  246. // result = updata();
  247. // break;
  248. default:
  249. result = 0x05;//帧内容异常(指令值超出范围等)
  250. goto __feedback;
  251. }
  252. }
  253. __feedback:
  254. txData[0] = 0xBB; // 帧头
  255. txData[1] = 0xFF; // 帧头
  256. txData[2] = 0x55; // 帧头
  257. txData[3] = 0xCC; // 帧头
  258. txData[4] = result; // 反馈值
  259. txData[5] = CheckXor(&txData[4], 1); // 校验位
  260. txData[6] = 0xEE; // 帧尾
  261. txData[7] = 0xFF; // 帧尾
  262. sendCmd(txData,8);
  263. }