hdf.c 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. #include "hdf.h"
  2. void TOUCHUAN_UART_NUM(uint8_t* pTx) ;
  3. void Get_ZN_hdf_data(void) ;
  4. HDF_Inf hdf_inf[SENSOR_DEEP];
  5. Tank_Inf tank_inf;
  6. uint16_t Uart_len_TouChuan= 0;
  7. uint8_t Get_DFState(uint8_t Cang_Num) //查询仓底阀状态
  8. {
  9. HDF_Inf* phdf = hdf_inf;
  10. return !phdf[Cang_Num].HDF_OFData[0];
  11. }
  12. GPIO_PinState Get_Pin(int Pin_No)
  13. {
  14. GPIO_PinState Pin_sts;
  15. switch (Pin_No)
  16. {
  17. case 0:
  18. Pin_sts = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_14);
  19. break;
  20. case 1:
  21. Pin_sts = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_15);
  22. break;
  23. case 2:
  24. Pin_sts = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_6);
  25. break;
  26. case 3:
  27. Pin_sts = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_7);
  28. break;
  29. case 4:
  30. Pin_sts = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_8);
  31. break;
  32. case 5:
  33. Pin_sts = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_9);
  34. break;
  35. case 6:
  36. Pin_sts = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_8);
  37. break;
  38. case 7:
  39. Pin_sts = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_11);
  40. break;
  41. default:
  42. break;
  43. }
  44. return Pin_sts;
  45. }
  46. /**
  47. ***************************************
  48. * mcu的IO口采集的一种连续性滤波式的认可机制
  49. * 原理为: 某一代号的管脚的输入电平,连续几次
  50. * 检查都是相同值,才认可检查
  51. * 输入:pinNo, 管脚代号,范围0-7
  52. * 输入:pstatus,存放查询当前的管脚输入值
  53. * 返回: 0-不认可,1-认可
  54. ***************************************
  55. */
  56. int DoPinIoHitSame(uint8_t pinNo, uint8_t *pstatus)
  57. {
  58. uint8_t status = 0;
  59. static struct pin_same {
  60. GPIO_PinState status;
  61. uint16_t same_count;
  62. }pin_cache[8];
  63. if(pinNo > 7) return 0;
  64. status = Get_Pin(pinNo);
  65. *pstatus = status;
  66. if(pin_cache[pinNo].status == status) {
  67. pin_cache[pinNo].same_count++;
  68. if(pin_cache[pinNo].same_count >= cang_inf.pinIOHitSameParam){
  69. pin_cache[pinNo].same_count = 0;
  70. return 1;
  71. }
  72. }else {
  73. pin_cache[pinNo].status = status;
  74. pin_cache[pinNo].same_count = 0;
  75. }
  76. return 0;
  77. }
  78. void DF_State(uint8_t Cang_Num) //查询仓底阀状态
  79. {
  80. Cang_Inf* pcang = &cang_inf;
  81. XYF_Inf* pxyf = xyf_inf;
  82. RKG_Inf* prkg = rkg_inf;
  83. HDF_Inf* phdf = hdf_inf;
  84. uint8_t i = 0,j = 0,HDF_MAX = 3,PinNo;
  85. uint8_t status = 0, hit = 0;
  86. if(pcang->HDF_Type == 0) //底阀监测器
  87. {
  88. if(i < HDF_BUF_DEP)
  89. {
  90. PinNo = 0;
  91. //if (pcang->XYF_Type == 2)
  92. if (pcang->XYF_Type == 0) // 是二合一, 用IO 模拟有油无油状态 for showtable
  93. {
  94. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  95. {
  96. HDF_MAX += pcang->XYF_Num[j];
  97. }
  98. for (j = 0; j < HDF_MAX; ++j)
  99. {
  100. hit = DoPinIoHitSame(PinNo++, &status);
  101. if(hit){
  102. pxyf[j + 1].XYF_State2 = status==0?1:0;
  103. }
  104. }
  105. }
  106. if (pcang->RKG_Type == 2)
  107. {
  108. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  109. {
  110. HDF_MAX += pcang->RKG_Num[j];
  111. }
  112. for (j = 0; j < HDF_MAX; ++j)
  113. {
  114. hit = DoPinIoHitSame(PinNo++, &status);
  115. if(hit){
  116. prkg[1 + j].RKDG_State = status;
  117. }
  118. }
  119. }
  120. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  121. {
  122. HDF_MAX += pcang->HDF_Num[j];
  123. }
  124. for (j = 0; j < HDF_MAX; ++j)
  125. {
  126. hit = DoPinIoHitSame(PinNo++, &status);
  127. if(hit){
  128. phdf[1 + j].HDF_OFData[i] = status;
  129. }
  130. }
  131. i++;
  132. }
  133. if(i >= HDF_BUF_DEP)
  134. i = 0;
  135. }
  136. else if(pcang->HDF_Type == 1) //其他底阀监测
  137. {
  138. phdf[1].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_14);
  139. phdf[2].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_15);
  140. phdf[3].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_6);
  141. phdf[4].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_7);
  142. phdf[5].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_8);
  143. phdf[6].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_9);
  144. phdf[7].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_8);
  145. phdf[8].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_11);
  146. /* for(j = 1;j <= HDF_MAX;j++) //SLM HDF_MAX
  147. {
  148. if(phdf[j].HDF_ErrorCnt > phdf->HDF_StateKeepNum)
  149. phdf[j].HDF_Error = 1;
  150. }*/
  151. }
  152. // 门磁 & 人脸授权
  153. hit = DoPinIoHitSame(6, &status);
  154. if(hit){
  155. tank_inf.Door_Status = status==0?1:0;
  156. }
  157. hit = DoPinIoHitSame(7, &status);
  158. if(hit){
  159. tank_inf.Facial_Auth = status==0?1:0;
  160. }
  161. }
  162. void Get_ZN_hdf_data(void)
  163. {
  164. uint8_t receive_error = 0;
  165. // uint16_t ModbusCRC = 0;
  166. // Cang_Inf* pcang = &cang_inf;
  167. HDF_Inf* phdf = hdf_inf;
  168. phdf[USART1_RX_BUF002[0]-0x20].RTData_Num = 1;
  169. if(USART3_RX_BUF002[0]==0x21||USART3_RX_BUF002[0]==0x22)
  170. {
  171. if(USART3_RX_BUF002[1]!=0x03&&USART3_RX_BUF002[1]!=0x06) //校验读写属性
  172. {
  173. receive_error = 1;
  174. }
  175. /* else if(ModbusCRC != LIB_CRC_MODBUS(USART3_RX_BUF002,6)) //校验CRC
  176. {
  177. receive_error = 0;
  178. }*/
  179. if((USART3_RX_BUF002[1] == 0x03)&&(receive_error == 0)) //读取数据返回
  180. {
  181. phdf[USART3_RX_BUF002[0]-0x20].HDF_ErrorCnt = 0;
  182. phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1;
  183. // if(pcang->HDF_Type == 1)
  184. // phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1; //海底阀开关数据
  185. phdf[USART3_RX_BUF002[0]-0x20].HDF_OFData[0] = USART3_RX_BUF002[3] ;
  186. // phdf[USART3_RX_BUF002[0]-0x20].HDF_OFState = USART3_RX_BUF002[4] ;
  187. __NOP();
  188. }
  189. else if((USART3_RX_BUF002[1] == 0x06)&&(receive_error == 0))
  190. {
  191. USART3_RX_BUF002[3] = USART3_RX_BUF002[3] ;
  192. }
  193. }
  194. else if(USART3_RX_BUF002[0]==0x23||USART3_RX_BUF002[0]==0x24)
  195. {
  196. if(USART3_RX_BUF002[1]!=0x03&&USART3_RX_BUF002[1]!=0x06) //校验读写属性
  197. {
  198. receive_error = 1;
  199. }
  200. /* else if(ModbusCRC != LIB_CRC_MODBUS(USART3_RX_BUF002,6)) //校验CRC
  201. {
  202. receive_error = 0;
  203. }*/
  204. if((USART3_RX_BUF002[1] == 0x03)&&(receive_error == 0)) //读取数据返回
  205. {
  206. phdf[USART3_RX_BUF002[0]-0x20].HDF_ErrorCnt = 0;
  207. phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1;
  208. // if(pcang->HDF_Type == 1)
  209. // phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1; //海底阀开关数据
  210. phdf[USART3_RX_BUF002[0]-0x22].HDF_Data[1] = 1;//USART3_RX_BUF002[3] ;
  211. phdf[USART3_RX_BUF002[0]-0x22].HDF_OFState1 = 1;//USART3_RX_BUF002[4] ;
  212. __NOP();
  213. }
  214. else if((USART3_RX_BUF002[1] == 0x06)&&(receive_error == 0))
  215. {
  216. USART3_RX_BUF002[3] = USART3_RX_BUF002[3] ;
  217. }
  218. }
  219. }
  220. void TOUCHUAN_UART_NUM(uint8_t* pTx)
  221. {
  222. KZQ_Inf* pkzq = &kzq_inf;
  223. int retry;
  224. // Cang_Inf* pcang = &cang_inf;
  225. // uint8_t i = 0;
  226. // uint16_t ModBusCRC = 0;
  227. // uint8_t receive_error = 0;
  228. // uint16_t ModbusCRC = 0;
  229. // HDF_Inf* phdf = hdf_inf;
  230. uint16_t Uart_num = 0;
  231. Uart_num=USART2_RX_BUF002[18];
  232. Uart_num = Uart_num << 8;
  233. Uart_num |= USART2_RX_BUF002[19];
  234. if(Uart_num == 1)
  235. {//if(Uart_num == 0x0001)
  236. if(pkzq->USE_XYF == 0)
  237. {//if(pkzq->USE_XYF == 0)
  238. if(pkzq->data_buf[7] == 0x06)
  239. {//if(pkzq->data_buf[7] == 0x06)
  240. pkzq->USE_XYF = 1;
  241. Uart_len_TouChuan=USART2_RX_BUF002[20];
  242. Uart_len_TouChuan = Uart_len_TouChuan << 8;
  243. Uart_len_TouChuan |= USART2_RX_BUF002[21];
  244. memcpy(XYF_TxBuf,&USART2_RX_BUF002[22],Uart_len_TouChuan);
  245. //osDelay(50);
  246. for(retry=0;retry<300;++retry)
  247. {
  248. if(flagU3Rx && (pkzq->USE_XYF==0))
  249. break;
  250. osDelay(1);
  251. }
  252. if(flagU3Rx)
  253. {
  254. pTx[20] = (data_lengthU3>>8)&0xff;
  255. pTx[21] = data_lengthU3&0xff;
  256. memcpy(pTx+22,USART3_RX_BUF002,data_lengthU3);
  257. flagU1Rx=0;
  258. }
  259. else
  260. {
  261. pTx[20] = 0;
  262. pTx[21] = 0;
  263. }
  264. }//if(pkzq->data_buf[7] == 0x06)
  265. }//if(pkzq->USE_XYF == 0)
  266. }//if(Uart_num == 0x0001)
  267. if(Uart_num == 0)
  268. {//if(Uart_num == 0x0001)
  269. if(pkzq->USE_RKG == 0)
  270. {//if(pkzq->USE_XYF == 0)
  271. if(pkzq->data_buf[7] == 0x06)
  272. {//if(pkzq->data_buf[7] == 0x06)
  273. pkzq->USE_RKG = 1;
  274. Uart_len_TouChuan=USART2_RX_BUF002[20];
  275. Uart_len_TouChuan = Uart_len_TouChuan << 8;
  276. Uart_len_TouChuan |= USART2_RX_BUF002[21];
  277. memcpy(RKG_TxBuf,&USART2_RX_BUF002[22],Uart_len_TouChuan);
  278. //osDelay(50);
  279. for(retry=0;retry<300;++retry)
  280. {
  281. if(flagU1Rx && (pkzq->USE_RKG == 0))
  282. break;
  283. osDelay(1);
  284. }
  285. if(flagU1Rx)
  286. {
  287. pTx[20] = (data_lengthU1>>8)&0xff;
  288. pTx[21] = data_lengthU1&0xff;
  289. memcpy(pTx+22,USART1_RX_BUF002,data_lengthU1);
  290. flagU1Rx=0;
  291. }
  292. else
  293. {
  294. pTx[20] = 0;
  295. pTx[21] = 0;
  296. }
  297. }//if(pkzq->data_buf[7] == 0x06)
  298. }//if(pkzq->USE_XYF == 0)
  299. }//if(Uart_num == 0x0001)
  300. }