Radar.c 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. /* Copyright Statement:
  2. *
  3. * This software/firmware and related documentation ("AutoChips Software") are
  4. * protected under relevant copyright laws. The information contained herein is
  5. * confidential and proprietary to AutoChips Inc. and/or its licensors. Without
  6. * the prior written permission of AutoChips inc. and/or its licensors, any
  7. * reproduction, modification, use or disclosure of AutoChips Software, and
  8. * information contained herein, in whole or in part, shall be strictly
  9. * prohibited.
  10. *
  11. * AutoChips Inc. (C) 2016. All rights reserved.
  12. *
  13. * BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
  14. * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("AUTOCHIPS SOFTWARE")
  15. * RECEIVED FROM AUTOCHIPS AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER
  16. * ON AN "AS-IS" BASIS ONLY. AUTOCHIPS EXPRESSLY DISCLAIMS ANY AND ALL
  17. * WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
  18. * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
  19. * NONINFRINGEMENT. NEITHER DOES AUTOCHIPS PROVIDE ANY WARRANTY WHATSOEVER WITH
  20. * RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY,
  21. * INCORPORATED IN, OR SUPPLIED WITH THE AUTOCHIPS SOFTWARE, AND RECEIVER AGREES
  22. * TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO.
  23. * RECEIVER EXPRESSLY ACKNOWLEDGES THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO
  24. * OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES CONTAINED IN AUTOCHIPS
  25. * SOFTWARE. AUTOCHIPS SHALL ALSO NOT BE RESPONSIBLE FOR ANY AUTOCHIPS SOFTWARE
  26. * RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
  27. * STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND AUTOCHIPS'S
  28. * ENTIRE AND CUMULATIVE LIABILITY WITH RESPECT TO THE AUTOCHIPS SOFTWARE
  29. * RELEASED HEREUNDER WILL BE, AT AUTOCHIPS'S OPTION, TO REVISE OR REPLACE THE
  30. * AUTOCHIPS SOFTWARE AT ISSUE, OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE
  31. * CHARGE PAID BY RECEIVER TO AUTOCHIPS FOR SUCH AUTOCHIPS SOFTWARE AT ISSUE.
  32. */
  33. #include "ac780x_uart_reg.h"
  34. #include "ac780x_gpio.h"
  35. #include "Radar.h"
  36. #include "uart.h"
  37. #include "string.h"
  38. #include "crc16.h"
  39. #define LaDarUARTx UART0
  40. #define LaDarUARTx_IRQn UART0_IRQn
  41. #define RADAR_RX_BUFF_LENGTH 7
  42. #define RADAR_MAX_BUFFERSIZE 32
  43. #define RadarCmd_NULL (0)
  44. #define RadarCmd_AirHeight (1)
  45. #define RadarCmd_Trans (2)
  46. uint8_t g_radarRxDataBuff[RADAR_RX_BUFF_LENGTH];
  47. uint16_t g_radarRxDataIndex;
  48. uint8_t *g_radarTxDataPoint;
  49. uint16_t g_radarTxDataLength;
  50. uint16_t g_radarTxDataIndex;
  51. static uint8_t * p_float;
  52. //static float tmp_v;
  53. static int16_t tmp_v;
  54. //static uint16_t _crc = 0;
  55. static uint8_t recvbuffer_len = 0;
  56. static uint8_t databuffer_len = 0;
  57. static uint8_t trans_recvbuffer[RADAR_MAX_BUFFERSIZE] = {0}; //透传指令暂存buffer
  58. static uint8_t trans_databuffer[RADAR_MAX_BUFFERSIZE] = {0}; //透传回应数据暂存buffer
  59. #define WAITTING_TIMEOUT (100) //单位 ms
  60. static uint8_t cmd_radar = RadarCmd_NULL;
  61. uint8_t waiting_time_ladar =0; //等待数据时间, ms
  62. static uint8_t radar_timeout_count = 0; //雷达超时次数
  63. static float airHeight = 0;
  64. static uint8_t _status = 0;
  65. //uint8_t radar_cmd[8] = {0x7F, 0x04, 0x0A, 0x0F, 0x00, 0x02, 0x48, 0x0E};
  66. uint8_t radar_cmd[8] = {0xFF, 0x03, 0x00, 0x01, 0x00, 0x01, 0xC0, 0x14};
  67. //static uint8_t radar_cmd[32];
  68. //uint8_t
  69. //static uint32_t ladar_printfBuff[16];
  70. //static uint16_t ladar_printfLen = 0;
  71. static int TransmitData(uint8_t *pdata, uint16_t length);
  72. /**
  73. * UartEventCallback
  74. *
  75. * @param[in] device: UART_Type pointer
  76. * @param[in] wpara: UART lsr0 register
  77. * @param[in] lpara: UART lsr1 register
  78. * @return none
  79. *
  80. * @brief uart receive handle
  81. */
  82. static void UartEventCallback(void *device, uint32_t wpara, uint32_t lpara)
  83. {
  84. uint8_t data = 0;
  85. uint16_t _crc = 0;
  86. UART_Type *uart_Device = (UART_Type *)device;
  87. /*rx interrupt*/
  88. if ((uart_Device->IER & UART_IER_ERXNE_Msk) && (wpara & UART_LSR0_DR_Msk))
  89. {
  90. data = uart_Device->RBR;
  91. waiting_time_ladar =0;
  92. if(RadarCmd_AirHeight == cmd_radar){
  93. radar_timeout_count = 0;
  94. g_radarRxDataBuff[g_radarRxDataIndex++] = data;
  95. if (g_radarRxDataIndex >= RADAR_RX_BUFF_LENGTH)
  96. {
  97. g_radarRxDataIndex = 0;
  98. _crc = crc16(g_radarRxDataBuff, RADAR_RX_BUFF_LENGTH-2);
  99. if( _crc == (((uint16_t)g_radarRxDataBuff[5]<<8) | g_radarRxDataBuff[6])){
  100. _status = STATUS_NORMAL;
  101. tmp_v = (int16_t)(g_radarRxDataBuff[3]<<8)|g_radarRxDataBuff[4];
  102. airHeight = tmp_v/1000.0;
  103. }else{
  104. _status = STATUS_DataError;
  105. airHeight = 0.0;
  106. }
  107. //读空高命令结束
  108. cmd_radar = RadarCmd_NULL;
  109. // ladar_printfLen = snprintf((char*)ladar_printfBuff, 64, "Radar st[%d], airheight: %f m [%x][%x][%x][%x][%x][%x][%x]\r\n",
  110. // _status, airHeight,
  111. // g_radarRxDataBuff[0],
  112. // g_radarRxDataBuff[1],
  113. // g_radarRxDataBuff[2],
  114. // g_radarRxDataBuff[3],
  115. // g_radarRxDataBuff[4],
  116. // g_radarRxDataBuff[5],
  117. // g_radarRxDataBuff[6]);
  118. // rs485_TransmitData((uint8_t*)ladar_printfBuff, ladar_printfLen);
  119. }
  120. }else if(RadarCmd_Trans == cmd_radar){
  121. if(databuffer_len < RADAR_MAX_BUFFERSIZE){
  122. trans_databuffer[databuffer_len++]=data;
  123. }
  124. }
  125. }
  126. /*tx interrupt*/
  127. if ((uart_Device->IER & UART_IER_ETXE_Msk) && (wpara & UART_LSR0_THRE_Msk))
  128. {
  129. uart_Device->RBR = g_radarTxDataPoint[g_radarTxDataIndex++];
  130. if (g_radarTxDataIndex >= g_radarTxDataLength)
  131. {
  132. UART_SetTXEInterrupt(device, DISABLE); ///<发送最后一个字节时关闭发送空中断
  133. }
  134. }
  135. }
  136. /**
  137. * uart_Initialize
  138. *
  139. * @param[in] none
  140. * @return none
  141. *
  142. * @brief uart 初始化
  143. */
  144. static void uart0_Initialize(void)
  145. {
  146. UART_ConfigType uartConfig = {0};
  147. uartConfig.baudrate = 115200;
  148. uartConfig.dataBits = UART_WORD_LEN_8BIT;
  149. uartConfig.stopBits = UART_STOP_1BIT;
  150. uartConfig.parity = UART_PARI_NO;
  151. uartConfig.fifoByteEn = DISABLE; ///<must enable fifoByte when use DMA
  152. uartConfig.dmaEn = UART_DMA_TXRX_NONE;
  153. uartConfig.callBack = UartEventCallback; ///<uart0 interrupt callback
  154. UART_Init(LaDarUARTx, &uartConfig);
  155. UART_SetRXNEInterrupt(LaDarUARTx, ENABLE);
  156. ///Enable UARTx interrupt
  157. NVIC_SetPriority(LaDarUARTx_IRQn, 3);
  158. NVIC_ClearPendingIRQ(LaDarUARTx_IRQn);
  159. NVIC_EnableIRQ(LaDarUARTx_IRQn);
  160. }
  161. /**
  162. * TransmitData
  163. *
  164. * @param[in] pdata :发送数据指针
  165. * @param[in] length :发送数据长度
  166. * @return none
  167. *
  168. * @brief uart 发送函数,通过中断发送
  169. */
  170. int TransmitData(uint8_t *pdata, uint16_t length)
  171. {
  172. if (g_radarTxDataIndex < g_radarTxDataLength){
  173. return -1; ///<有数据正在发送
  174. }
  175. g_radarTxDataPoint = pdata;
  176. g_radarTxDataLength = length;
  177. g_radarTxDataIndex = 0;
  178. UART_SetTXEInterrupt(LaDarUARTx, ENABLE);
  179. return 0;
  180. }
  181. void Radar_Init(void)
  182. {
  183. uart0_Initialize();
  184. _status = STATUS_NORMAL;
  185. airHeight = 0;
  186. radar_timeout_count = 0;
  187. }
  188. //uint8_t Radar_ReadAirHeight(void)
  189. //{
  190. //// uint16_t crc = 0;
  191. ////
  192. //// //清空、接收缓冲
  193. //// g_radarRxDataIndex = 0;
  194. //// radar_cmd[0] = 0xFF,
  195. //// radar_cmd[1] = 0x03,
  196. //// radar_cmd[2] = 0x00,
  197. //// radar_cmd[3] = 0x01,
  198. //// radar_cmd[4] = 0x00,
  199. //// radar_cmd[5] = 0x01,
  200. //// crc = crc16(radar_cmd, 6);
  201. //// radar_cmd[6] = (uint8_t)((crc>>8) & 0x00ff);
  202. //// radar_cmd[7] = (uint8_t)(crc & 0x00ff);
  203. //
  204. // TransmitData(radar_cmd, 8);
  205. // return 0;
  206. //}
  207. void Radar_CheckResponse(void)
  208. {
  209. if(RadarCmd_NULL != cmd_radar){
  210. if(waiting_time_ladar >= WAITTING_TIMEOUT){
  211. //通信命令结束
  212. cmd_radar = RadarCmd_NULL;
  213. if(RadarCmd_AirHeight == cmd_radar){
  214. radar_timeout_count++;
  215. g_radarRxDataIndex = 0;
  216. if(radar_timeout_count >= 3){
  217. radar_timeout_count =3;
  218. _status = STATUS_NoResponse;
  219. airHeight = 0.0;
  220. }
  221. // ladar_printfLen = snprintf((char*)ladar_printfBuff, 64, "Radar_CheckResponse st[%d], airheight: %f m \r\n", _status, airHeight);
  222. // rs485_TransmitData((uint8_t*)ladar_printfBuff, ladar_printfLen);
  223. }else {
  224. recvbuffer_len = 0;
  225. }
  226. }
  227. }
  228. }
  229. void Radar_SendRequest(void)
  230. {
  231. if(RadarCmd_NULL != cmd_radar){
  232. return;
  233. }
  234. // ladar_printfLen = snprintf((char*)ladar_printfBuff, 64, "Radar_SendRequest recvbuffer_len[%d] m \r\n", recvbuffer_len);
  235. // rs485_TransmitData((uint8_t*)ladar_printfBuff, ladar_printfLen);
  236. if(recvbuffer_len > 0){
  237. //有透传数据需要发送
  238. cmd_radar = RadarCmd_Trans;
  239. TransmitData(trans_recvbuffer, recvbuffer_len);
  240. waiting_time_ladar = 0;
  241. //清空接收缓存
  242. databuffer_len=0;
  243. memset(trans_databuffer, 0, RADAR_MAX_BUFFERSIZE);
  244. }else{
  245. //读取空高数据
  246. cmd_radar = RadarCmd_AirHeight;
  247. TransmitData(radar_cmd, 8);
  248. waiting_time_ladar = 0;
  249. g_radarRxDataIndex = 0;
  250. }
  251. }
  252. void Radar_SendData(uint8_t* pData, uint8_t data_len)
  253. {
  254. if(data_len > RADAR_MAX_BUFFERSIZE){
  255. return ;
  256. }
  257. if(RadarCmd_Trans == cmd_radar){ //上一个透传指令还没结束
  258. return;
  259. }
  260. memcpy(trans_recvbuffer, pData, data_len);
  261. recvbuffer_len = data_len;
  262. }
  263. void Radar_ReadData(uint8_t* pBuffer, uint8_t read_len)
  264. {
  265. if(read_len > RADAR_MAX_BUFFERSIZE){
  266. read_len = RADAR_MAX_BUFFERSIZE;
  267. }
  268. memcpy(pBuffer, trans_databuffer, read_len);
  269. //清空接收缓存
  270. databuffer_len=0;
  271. memset(trans_databuffer, 0, RADAR_MAX_BUFFERSIZE);
  272. }
  273. //uint8_t Radar_SetInstallHeight(uint16_t install_height)
  274. //{
  275. // //清空、接收缓冲
  276. // g_radarRxDataIndex = 0;
  277. // TransmitData(radar_cmd, 8);
  278. //
  279. // return 0;
  280. //}
  281. uint8_t Radar_GetHeight(float* height)
  282. {
  283. *height = airHeight;
  284. return _status;
  285. }
  286. uint8_t Radar_Print(void)
  287. {
  288. return 0;
  289. }
  290. void Radar_DeInit(void)
  291. {
  292. }
  293. void Radar_Timer1_Callback(void)
  294. {
  295. if(waiting_time_ladar < 0xFF){
  296. waiting_time_ladar++;
  297. }
  298. }