dm_scaner.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. /*******************************************************************************************
  2. * @file dm_scaner.c
  3. *
  4. * @brief ��ά��ɨ��������
  5. *
  6. * (c) Copyright 2020, Shandong Huali electromechanical Co., Ltd..
  7. * This is protected by international copyright laws. Knowledge of the
  8. * source code may not be used to write a similar product. This file may
  9. * only be used in accordance with a license and should not be redistributed
  10. * in any way. We appreciate your understanding and fairness.
  11. *
  12. *
  13. * @author Deman
  14. * @date Created: 2020.08.06-T11:18:09+0800
  15. *
  16. *******************************************************************************************/
  17. #include "dm_scaner.h"
  18. #include "hardware.h"
  19. #include "env.h"
  20. #define DBG_SECTION_NAME "scaner"
  21. #define DBG_LEVEL DBG_INFO
  22. #include <rtdbg.h>
  23. typedef struct
  24. {
  25. rt_device_t device;
  26. char end_sign;
  27. uint8_t *recv_buffer;
  28. rt_size_t recv_bufsz;
  29. rt_size_t cur_recv_len;
  30. rt_sem_t rx_notice;
  31. }DMScaner_parser_t;
  32. static DMScaner_parser_t DMScannerParser = {0};
  33. DmScanerData_t DmScanerData;
  34. Scaner_TypeDef scan = {0};
  35. /**
  36. * @funtion Xor
  37. * @brief �����
  38. * @Author Deman
  39. * @DateTime 2020.08.12-T8:54:31+0800
  40. *
  41. * @param data ��������
  42. * @param len ���ݳ���
  43. * @return ����
  44. */
  45. uint8_t DMScannerXor(uint8_t* data,uint8_t len)
  46. {
  47. uint8_t i;
  48. uint8_t xor_res = 0;
  49. for(i = 0;i < len -1 ; i++)
  50. xor_res ^= data[i];
  51. return xor_res;
  52. }
  53. static rt_err_t DMScannerRxInd(rt_device_t dev, rt_size_t size)
  54. {
  55. if(DMScannerParser.rx_notice)
  56. {
  57. rt_sem_release(DMScannerParser.rx_notice);
  58. return RT_EOK;
  59. }
  60. return RT_ENOMEM;
  61. }
  62. void DmUsart7_Send(uint8_t *ch, int len)
  63. {
  64. RS485_TX_EN = 1;
  65. rt_device_write(DMScannerParser.device, 0, ch, len);
  66. RS485_TX_EN = 0;
  67. }
  68. static rt_err_t DMScannerGetchar(DMScaner_parser_t *parser, char *ch, rt_int32_t timeout)
  69. {
  70. rt_err_t result = RT_EOK;
  71. while (rt_device_read(parser->device, 0, ch, 1) == 0)
  72. {
  73. rt_sem_control(parser->rx_notice, RT_IPC_CMD_RESET, RT_NULL);
  74. result = rt_sem_take(parser->rx_notice, rt_tick_from_millisecond(timeout));
  75. if (result != RT_EOK)
  76. {
  77. return result;
  78. }
  79. }
  80. return RT_EOK;
  81. }
  82. static int DMScannerReadline(DMScaner_parser_t *parser, uint32_t timeout)
  83. {
  84. rt_size_t read_len = 0;
  85. char ch = 0;
  86. int rc = RT_EOK;
  87. rt_memset(parser->recv_buffer, 0x00, parser->recv_bufsz);
  88. parser->cur_recv_len = 0;
  89. while (parser->device)
  90. {
  91. rc = DMScannerGetchar(parser, &ch, timeout);
  92. if(rc != RT_EOK)
  93. {
  94. return read_len;
  95. }
  96. if (read_len < parser->recv_bufsz)
  97. {
  98. parser->recv_buffer[read_len++] = ch;
  99. parser->cur_recv_len = read_len;
  100. }
  101. }
  102. return read_len;
  103. }
  104. /**
  105. * @funtion mb_send
  106. * @brief ���ݷ���
  107. * @Author Deman
  108. * @DateTime 2020.08.12-T8:53:08+0800
  109. *
  110. * @param buffer ���ݻ���ָ��
  111. * @param len �������ݳ���
  112. */
  113. static void mb_send(uint8_t* buffer, uint16_t len)
  114. {
  115. DmUsart7_Send(buffer, len);
  116. }
  117. /**
  118. * @funtion DMScanerDH_parse
  119. * @brief ɨ��������������
  120. * @Author Deman
  121. * @DateTime 2020.08.12-T8:48:59+0800
  122. *
  123. * @param parser �������ݽṹ��
  124. * @param timeout ���ճ�ʱʱ�䣬��ʱ˵��һ֡���ݽ������
  125. * @return description
  126. */
  127. static int DMScanerDH_parse(DMScaner_parser_t *parser)
  128. {
  129. uint8_t * DmRecvData;
  130. static uint16_t recvErrCnt;
  131. if(DMScannerXor(parser->recv_buffer, parser->cur_recv_len - 1)
  132. == parser->recv_buffer[parser->cur_recv_len - 1])
  133. {
  134. if(parser->recv_buffer[0] == 0)
  135. {
  136. DmRecvData = parser->recv_buffer;
  137. S.DmS = DmRecvData[0];
  138. //LogInfo("S.DmS: %X\r\n",S.DmS);
  139. S.xOffset = (DmRecvData[4] & (0X01<<6))> 0?(DmRecvData[4]<<7 | DmRecvData[5] + 0xC000):(DmRecvData[4]<<7 | DmRecvData[5]);
  140. S.yOffset = (DmRecvData[6] & (0X01<<6))> 0?(DmRecvData[6]<<7 | DmRecvData[7] + 0xC000):(DmRecvData[6]<<7 | DmRecvData[7]);
  141. S.Angle = DmRecvData[10] * 0x80 + DmRecvData[11];
  142. //LogInfo("S.DmAngle: %d\r\n",S.DmAngle);
  143. /* C X Y 01002004 */
  144. uint32_t TagNum;
  145. uint32_t xValue; //巷值
  146. uint32_t yValue; //坡值
  147. uint32_t cValue; //层值
  148. TagNum = (DmRecvData[14] << 21 | DmRecvData[15] << 14 | DmRecvData[16] << 7 | DmRecvData[17]);
  149. if(TagNum)
  150. {
  151. S. TagNum = TagNum;
  152. xValue = (S.TagNum / 1000) % 1000;
  153. if(xValue)
  154. scan.xValue = xValue;
  155. else LOG_E("scan err x");
  156. yValue = S.TagNum % 1000;
  157. if(yValue)
  158. scan.yValue = yValue;
  159. else LOG_E("scan err y");
  160. cValue = (S.TagNum / 1000 /1000) % 1000;
  161. if(cValue)
  162. scan.cValue = cValue;
  163. else LOG_E("scan err c");
  164. }
  165. // S.yValue = scan.yValue;
  166. // S.xValue = (S.TagNum / 1000) % 1000;
  167. // //LogInfo("S.xValue: %d\r\n",S.xValue);
  168. // S.yValue = S.TagNum % 1000;
  169. // //LogInfo("S.yValue: %d\r\n",S.yValue);
  170. // /*��С�����������ϣ��������ⲿ����(��ȡ�������������¡�λ���������)*/
  171. // if(S.TagNum != Set.TsjStation) //提升机码
  172. // {
  173. // S.cValue = (S.TagNum / 1000 /1000) % 1000;
  174. // }
  175. //LogInfo("S.yValue: %d\r\n",S.yValue);
  176. //LogInfo("S.Point: %d\r\n",S.Point);
  177. DmScanerData.Ready = true;
  178. DmScanerData.Sta = DMSCANER_VALUE_UPDATE;
  179. }
  180. else
  181. {
  182. DmScanerData.Ready = false;
  183. DmScanerData.Sta = DMSCANER_VALUE_INVALID;
  184. }
  185. recvErrCnt = 0;
  186. }
  187. else{
  188. recvErrCnt++;
  189. }
  190. if(parser->rx_notice)
  191. {
  192. /*��ʱδ���յ����������ݣ���Ϊ������ʧЧ*/
  193. if(recvErrCnt > 100){
  194. DmScanerData.Sta = DMSCANER_ERR;
  195. S.Status = STATUS_DRIVER_ERROR;
  196. }
  197. }
  198. return 0;
  199. }
  200. /**
  201. * @funtion DMDMScanerDH_Ready
  202. * @brief ��ȡ��ǰ��ά���Ƿ���Ч
  203. * @Author Deman
  204. * @DateTime 2020.08.13-T14:26:43+0800
  205. *
  206. * @return description
  207. */
  208. bool DMScanerDH_Ready(void)
  209. {
  210. return DmScanerData.Ready;
  211. }
  212. /**
  213. * @funtion DMScanerDH_poll
  214. * @brief DMɨ������ʱ���Ͳ�ѯָ���Լ������������
  215. * @Author Deman
  216. * @DateTime 2020.08.12-T8:48:01+0800
  217. *
  218. */
  219. void DMScanerDH_poll(void *param) //二维码
  220. {
  221. static uint32_t read_time = 0;
  222. DMScannerParser.recv_bufsz = 200;
  223. DMScannerParser.cur_recv_len = 0;
  224. DMScannerParser.recv_buffer = (uint8_t *) rt_calloc(1, DMScannerParser.recv_bufsz);
  225. DMScannerParser.rx_notice = rt_sem_create("gnss_cs", 0, RT_IPC_FLAG_FIFO);
  226. DMScannerParser.device = rt_device_find("uart7");
  227. if (DMScannerParser.device)
  228. {
  229. rt_err_t open_result = RT_EOK;
  230. open_result = rt_device_open(DMScannerParser.device, RT_DEVICE_OFLAG_RDWR | RT_DEVICE_FLAG_INT_RX);
  231. RT_ASSERT(open_result == RT_EOK);
  232. rt_device_set_rx_indicate(DMScannerParser.device, DMScannerRxInd);
  233. }
  234. while(1)
  235. {
  236. if(read_time >= 2){
  237. read_time = 0;
  238. uint8_t send_buf[3];
  239. send_buf[0] = 0xC8;
  240. send_buf[1] = 0X37;
  241. mb_send(send_buf, 2);
  242. }
  243. if(DMScannerReadline(&DMScannerParser, 8))
  244. {
  245. DMScanerDH_parse(&DMScannerParser);
  246. }
  247. if(S.xValue == 0 ||S.yValue == 0|| S.cValue == 0)
  248. {
  249. LOG_E("S-xyz err");
  250. }
  251. if(scan.xValue)
  252. S.xValue = scan.xValue;
  253. if(scan.yValue)
  254. S.yValue = scan.yValue;
  255. if(S.TagNum != Set.TsjStation) //非提升机码
  256. {
  257. if(scan.cValue)
  258. S.cValue = scan.cValue;
  259. }
  260. else
  261. {
  262. if(scan.Set_cValue)
  263. S.cValue = scan.Set_cValue;
  264. }
  265. S.Point = (S.xValue * 1000 + S.yValue);
  266. read_time++;
  267. }
  268. }
  269. /**
  270. * @funtion DMScanerInit
  271. * @brief ɨ������ʼ��
  272. * @Author Deman
  273. * @DateTime 2020.08.06-T11:20:25+0800
  274. *
  275. * @return description
  276. */
  277. int DMScanerInit(void)
  278. {
  279. scan.Set_cValue = 1;
  280. S.xValue = 255;
  281. S.yValue = 255;
  282. S.cValue = 255;
  283. rt_thread_t tid;
  284. // thread
  285. tid = rt_thread_create("scan",
  286. DMScanerDH_poll, RT_NULL,
  287. 1024,
  288. 8, 10);
  289. if (tid != RT_NULL)
  290. {
  291. rt_thread_startup(tid);
  292. }
  293. return RT_EOK;
  294. }
  295. INIT_APP_EXPORT(DMScanerInit);