app_protocol.c 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. #include "app_protocol.h"
  2. #include "hc32_ll_mcan.h"
  3. #include "hal_uart.h"
  4. #include "hal_flash.h"
  5. #include "hal_spi.h"
  6. #include "hal_can.h"
  7. #include "FreeRTOS.h"
  8. #include "queue.h"
  9. #include "semphr.h"
  10. /* 全局变量 */
  11. cmd_05_01_device_status_t mcu_decie_status = {0};
  12. static uint16_t g_dnpcrc_table[256] =
  13. {
  14. 0x0000, 0x365E, 0x6CBC, 0x5AE2, 0xD978, 0xEF26, 0xB5C4, 0x839A,
  15. 0xFF89, 0xC9D7, 0x9335, 0xA56B, 0x26F1, 0x10AF, 0x4A4D, 0x7C13,
  16. 0xB26B, 0x8435, 0xDED7, 0xE889, 0x6B13, 0x5D4D, 0x07AF, 0x31F1,
  17. 0x4DE2, 0x7BBC, 0x215E, 0x1700, 0x949A, 0xA2C4, 0xF826, 0xCE78,
  18. 0x29AF, 0x1FF1, 0x4513, 0x734D, 0xF0D7, 0xC689, 0x9C6B, 0xAA35,
  19. 0xD626, 0xE078, 0xBA9A, 0x8CC4, 0x0F5E, 0x3900, 0x63E2, 0x55BC,
  20. 0x9BC4, 0xAD9A, 0xF778, 0xC126, 0x42BC, 0x74E2, 0x2E00, 0x185E,
  21. 0x644D, 0x5213, 0x08F1, 0x3EAF, 0xBD35, 0x8B6B, 0xD189, 0xE7D7,
  22. 0x535E, 0x6500, 0x3FE2, 0x09BC, 0x8A26, 0xBC78, 0xE69A, 0xD0C4,
  23. 0xACD7, 0x9A89, 0xC06B, 0xF635, 0x75AF, 0x43F1, 0x1913, 0x2F4D,
  24. 0xE135, 0xD76B, 0x8D89, 0xBBD7, 0x384D, 0x0E13, 0x54F1, 0x62AF,
  25. 0x1EBC, 0x28E2, 0x7200, 0x445E, 0xC7C4, 0xF19A, 0xAB78, 0x9D26,
  26. 0x7AF1, 0x4CAF, 0x164D, 0x2013, 0xA389, 0x95D7, 0xCF35, 0xF96B,
  27. 0x8578, 0xB326, 0xE9C4, 0xDF9A, 0x5C00, 0x6A5E, 0x30BC, 0x06E2,
  28. 0xC89A, 0xFEC4, 0xA426, 0x9278, 0x11E2, 0x27BC, 0x7D5E, 0x4B00,
  29. 0x3713, 0x014D, 0x5BAF, 0x6DF1, 0xEE6B, 0xD835, 0x82D7, 0xB489,
  30. 0xA6BC, 0x90E2, 0xCA00, 0xFC5E, 0x7FC4, 0x499A, 0x1378, 0x2526,
  31. 0x5935, 0x6F6B, 0x3589, 0x03D7, 0x804D, 0xB613, 0xECF1, 0xDAAF,
  32. 0x14D7, 0x2289, 0x786B, 0x4E35, 0xCDAF, 0xFBF1, 0xA113, 0x974D,
  33. 0xEB5E, 0xDD00, 0x87E2, 0xB1BC, 0x3226, 0x0478, 0x5E9A, 0x68C4,
  34. 0x8F13, 0xB94D, 0xE3AF, 0xD5F1, 0x566B, 0x6035, 0x3AD7, 0x0C89,
  35. 0x709A, 0x46C4, 0x1C26, 0x2A78, 0xA9E2, 0x9FBC, 0xC55E, 0xF300,
  36. 0x3D78, 0x0B26, 0x51C4, 0x679A, 0xE400, 0xD25E, 0x88BC, 0xBEE2,
  37. 0xC2F1, 0xF4AF, 0xAE4D, 0x9813, 0x1B89, 0x2DD7, 0x7735, 0x416B,
  38. 0xF5E2, 0xC3BC, 0x995E, 0xAF00, 0x2C9A, 0x1AC4, 0x4026, 0x7678,
  39. 0x0A6B, 0x3C35, 0x66D7, 0x5089, 0xD313, 0xE54D, 0xBFAF, 0x89F1,
  40. 0x4789, 0x71D7, 0x2B35, 0x1D6B, 0x9EF1, 0xA8AF, 0xF24D, 0xC413,
  41. 0xB800, 0x8E5E, 0xD4BC, 0xE2E2, 0x6178, 0x5726, 0x0DC4, 0x3B9A,
  42. 0xDC4D, 0xEA13, 0xB0F1, 0x86AF, 0x0535, 0x336B, 0x6989, 0x5FD7,
  43. 0x23C4, 0x159A, 0x4F78, 0x7926, 0xFABC, 0xCCE2, 0x9600, 0xA05E,
  44. 0x6E26, 0x5878, 0x029A, 0x34C4, 0xB75E, 0x8100, 0xDBE2, 0xEDBC,
  45. 0x91AF, 0xA7F1, 0xFD13, 0xCB4D, 0x48D7, 0x7E89, 0x246B, 0x1235,
  46. };
  47. extern __IO en_flag_status_t spi_rx_complete_flag;
  48. //extern char spi_tx_buf[EXAMPLE_SPI_BUF_LEN];
  49. //extern char spi_rx_buf[EXAMPLE_SPI_BUF_LEN];
  50. extern QueueHandle_t can1_recieve2_data_queue;
  51. extern QueueHandle_t can2_recieve1_data_queue;
  52. static void creat_software_crc16(const uint8_t *pbuf, const uint32_t data_len, uint32_t *cur_crc);
  53. static unsigned short crc16_modbus(unsigned char *pdata, int len);
  54. static int8_t struct_convert_to_buffer(pack_t *pack,uint8_t *data);
  55. uint8_t flash_write_finish = false;
  56. int8_t pack_buffer[DATA_LENTH];
  57. gps_info_t gps_info;
  58. communication_data_t communication_data;
  59. output_control_t output_control;
  60. sleep_control_t sleep_control;
  61. communication_control_t communication_control;
  62. flash_write_t flash_write;
  63. sys_paratemer_info_t sys_paratemer_info;
  64. SemaphoreHandle_t spi_communication_semaphore = NULL;
  65. static unsigned short crc16_modbus(unsigned char *pdata, int len)
  66. {
  67. int j = 0;
  68. int i = 0;
  69. uint16_t reg_crc = 0xffff;
  70. while (i < len )
  71. {
  72. reg_crc ^= pdata[i];
  73. i++;
  74. for (j = 0; j < 8; j++)
  75. {
  76. if ((reg_crc & 0x01) == 1)
  77. {
  78. reg_crc = (uint16_t)((reg_crc >> 1) ^ 0xa001);
  79. }
  80. else
  81. {
  82. reg_crc = (uint16_t)( reg_crc >> 1);
  83. }
  84. }
  85. }
  86. return reg_crc;
  87. }
  88. static void creat_software_crc16(const uint8_t *pbuf, const uint32_t data_len, uint32_t *cur_crc)
  89. {
  90. uint16_t crc = 0u;
  91. uint32_t index = 0u;
  92. for (index = 0u; index < data_len; index++)
  93. {
  94. crc = ( crc >> 8 ) ^ g_dnpcrc_table[( crc ^ pbuf[index]) & 0x00ff] ;
  95. }
  96. *cur_crc = (uint32_t)((~crc) & 0xFFFFu);
  97. }
  98. static int8_t struct_convert_to_buffer(pack_t *pack,uint8_t *data)
  99. {
  100. if(pack!=NULL && data!=NULL && pack->data_lenth<=DATA_LENTH)
  101. {
  102. data[0] = pack->frame_head;
  103. data[1] = pack->source_addr;
  104. data[2] = pack->destination_addr;
  105. data[3] = pack->data_head;
  106. data[4] = pack->cmd;
  107. data[5] = pack->cmd_type;
  108. data[6] = pack->data_lenth>>8;
  109. data[7] = pack->data_lenth&0xff;
  110. memcpy(&data[8],pack->data,pack->data_lenth);
  111. data[pack->data_lenth+8] = pack->crc>>8;
  112. data[pack->data_lenth+9] = pack->crc&0xff;
  113. data[pack->data_lenth+10] = pack->frame_tail;
  114. return 0;
  115. }
  116. else
  117. {
  118. return -1;
  119. }
  120. }
  121. static uint8_t data_decode_mpu(uint8_t *input_data, uint32_t input_data_len, uint8_t* output, uint32_t* output_data_len)
  122. {
  123. uint16_t frame_len = 0; // 获取帧长度
  124. uint16_t frame_start = 0; // 帧起始位
  125. uint8_t frame_flag = false; //找到帧起始位
  126. *output_data_len = 0;
  127. static frame_pack_t frame_tmp = {0};
  128. frame_pack_t* frame_read_tmp;
  129. for(uint32_t i = 0; i < (input_data_len - sizeof(frame_pack_t)) && 0 == frame_flag; i++)
  130. {
  131. if(0X5A == input_data[i])
  132. {
  133. frame_len = input_data[i + FRAME_LEN_INDEX] + (input_data[i + FRAME_LEN_INDEX + 1] << 8);
  134. if((i + frame_len + 1) < input_data_len && input_data[frame_len - 1] + (input_data[frame_len] << 8) == crc16_modbus(input_data + i, frame_len -2))
  135. {
  136. frame_flag = true;
  137. frame_start = i;
  138. break;
  139. }
  140. }
  141. }
  142. if(false == frame_flag)
  143. return 1;
  144. *output_data_len += sizeof(frame_pack_t);
  145. switch(input_data[frame_start + FRAME_CMD_INDEX])
  146. {
  147. case 0X50:
  148. switch(input_data[frame_start + FRAME_CMD_TYPE_INDEX])
  149. {
  150. case 0X01:
  151. memcpy(output, &frame_tmp, sizeof(frame_pack_t));
  152. *output_data_len += sizeof(cmd_05_01_device_status_t);
  153. memcpy(output + sizeof(frame_pack_t), &mcu_decie_status, sizeof(cmd_05_01_device_status_t));
  154. break;
  155. case 0X02:
  156. break;
  157. case 0X03:
  158. break;
  159. default:
  160. break;
  161. }
  162. break;
  163. case 0X60:
  164. switch(input_data[frame_start + FRAME_CMD_TYPE_INDEX])
  165. {
  166. case 0X01:
  167. break;
  168. case 0X02:
  169. break;
  170. case 0X03:
  171. break;
  172. case 0X04:
  173. break;
  174. default:
  175. break;
  176. }
  177. break;
  178. default:
  179. break;
  180. }
  181. return 0;
  182. }
  183. void mcu_to_mpu_task(void *arg)
  184. {
  185. can1_recieve2_data_queue = xQueueCreate(5,sizeof(hc32_can_rx_msg_t));//can1存放非升级帧的队列
  186. can2_recieve1_data_queue = xQueueCreate(5,sizeof(hc32_can_rx_msg_t));//can2存放非升级帧的队列
  187. spi_communication_semaphore = xSemaphoreCreateBinary();
  188. while(1)
  189. {
  190. if(pdTRUE == xSemaphoreTake(spi_communication_semaphore,1))
  191. {
  192. // data_process(spi_rx_buf,spi_tx_buf);
  193. // memset(spi_rx_buf,0,sizeof(spi_rx_buf));
  194. }
  195. }
  196. }