hdf.c 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. #include "hdf.h"
  2. #include "cmsis_os.h"
  3. void TOUCHUAN_UART_NUM(uint8_t* pTx) ;
  4. void Get_ZN_hdf_data(void) ;
  5. HDF_Inf hdf_inf[SENSOR_DEEP];
  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. GPIO_PinState status = GPIO_PIN_RESET;
  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 = (uint8_t)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. {
  93. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  94. {
  95. HDF_MAX += pcang->XYF_Num[j];
  96. }
  97. for (j = 0; j < HDF_MAX; ++j)
  98. {
  99. hit = DoPinIoHitSame(PinNo++, &status);
  100. if(hit){
  101. pxyf[j + 1].XYF_State1 = status;
  102. }
  103. }
  104. }
  105. if (pcang->RKG_Type == 2)
  106. {
  107. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  108. {
  109. HDF_MAX += pcang->RKG_Num[j];
  110. }
  111. for (j = 0; j < HDF_MAX; ++j)
  112. {
  113. hit = DoPinIoHitSame(PinNo++, &status);
  114. if(hit){
  115. prkg[1 + j].RKDG_State = status;
  116. }
  117. }
  118. }
  119. for (j = 0, HDF_MAX = 0; j < pcang->Cang_Num; ++j)
  120. {
  121. HDF_MAX += pcang->HDF_Num[j];
  122. }
  123. for (j = 0; j < HDF_MAX; ++j)
  124. {
  125. hit = DoPinIoHitSame(PinNo++, &status);
  126. if(hit){
  127. phdf[1 + j].HDF_OFData[i] = status;
  128. }
  129. }
  130. i++;
  131. }
  132. if(i >= HDF_BUF_DEP)
  133. i = 0;
  134. }
  135. else if(pcang->HDF_Type == 1) //其他底阀监测
  136. {
  137. phdf[1].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_14);
  138. phdf[2].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_15);
  139. phdf[3].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_6);
  140. phdf[4].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_7);
  141. phdf[5].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_8);
  142. phdf[6].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_9);
  143. phdf[7].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_8);
  144. phdf[8].HDF_OFData[0] = HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_11);
  145. /* for(j = 1;j <= HDF_MAX;j++) //SLM HDF_MAX
  146. {
  147. if(phdf[j].HDF_ErrorCnt > phdf->HDF_StateKeepNum)
  148. phdf[j].HDF_Error = 1;
  149. }*/
  150. }
  151. }
  152. void Get_ZN_hdf_data(void)
  153. {
  154. uint8_t receive_error = 0;
  155. // uint16_t ModbusCRC = 0;
  156. // Cang_Inf* pcang = &cang_inf;
  157. HDF_Inf* phdf = hdf_inf;
  158. phdf[USART1_RX_BUF002[0]-0x20].RTData_Num = 1;
  159. if(USART3_RX_BUF002[0]==0x21||USART3_RX_BUF002[0]==0x22)
  160. {
  161. if(USART3_RX_BUF002[1]!=0x03&&USART3_RX_BUF002[1]!=0x06) //校验读写属性
  162. {
  163. receive_error = 1;
  164. }
  165. /* else if(ModbusCRC != LIB_CRC_MODBUS(USART3_RX_BUF002,6)) //校验CRC
  166. {
  167. receive_error = 0;
  168. }*/
  169. if((USART3_RX_BUF002[1] == 0x03)&&(receive_error == 0)) //读取数据返回
  170. {
  171. phdf[USART3_RX_BUF002[0]-0x20].HDF_ErrorCnt = 0;
  172. phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1;
  173. // if(pcang->HDF_Type == 1)
  174. // phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1; //海底阀开关数据
  175. phdf[USART3_RX_BUF002[0]-0x20].HDF_OFData[0] = USART3_RX_BUF002[3] ;
  176. // phdf[USART3_RX_BUF002[0]-0x20].HDF_OFState = USART3_RX_BUF002[4] ;
  177. __NOP();
  178. }
  179. else if((USART3_RX_BUF002[1] == 0x06)&&(receive_error == 0))
  180. {
  181. USART3_RX_BUF002[3] = USART3_RX_BUF002[3] ;
  182. }
  183. }
  184. else if(USART3_RX_BUF002[0]==0x23||USART3_RX_BUF002[0]==0x24)
  185. {
  186. if(USART3_RX_BUF002[1]!=0x03&&USART3_RX_BUF002[1]!=0x06) //校验读写属性
  187. {
  188. receive_error = 1;
  189. }
  190. /* else if(ModbusCRC != LIB_CRC_MODBUS(USART3_RX_BUF002,6)) //校验CRC
  191. {
  192. receive_error = 0;
  193. }*/
  194. if((USART3_RX_BUF002[1] == 0x03)&&(receive_error == 0)) //读取数据返回
  195. {
  196. phdf[USART3_RX_BUF002[0]-0x20].HDF_ErrorCnt = 0;
  197. phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1;
  198. // if(pcang->HDF_Type == 1)
  199. // phdf[USART3_RX_BUF002[0]-0x20].RTData_Num = 1; //海底阀开关数据
  200. phdf[USART3_RX_BUF002[0]-0x22].HDF_Data[1] = 1;//USART3_RX_BUF002[3] ;
  201. phdf[USART3_RX_BUF002[0]-0x22].HDF_OFState1 = 1;//USART3_RX_BUF002[4] ;
  202. __NOP();
  203. }
  204. else if((USART3_RX_BUF002[1] == 0x06)&&(receive_error == 0))
  205. {
  206. USART3_RX_BUF002[3] = USART3_RX_BUF002[3] ;
  207. }
  208. }
  209. }
  210. void TOUCHUAN_UART_NUM(uint8_t* pTx)
  211. {
  212. KZQ_Inf* pkzq = &kzq_inf;
  213. int retry;
  214. // Cang_Inf* pcang = &cang_inf;
  215. // uint8_t i = 0;
  216. // uint16_t ModBusCRC = 0;
  217. // uint8_t receive_error = 0;
  218. // uint16_t ModbusCRC = 0;
  219. // HDF_Inf* phdf = hdf_inf;
  220. uint16_t Uart_num = 0;
  221. Uart_num=USART2_RX_BUF002[18];
  222. Uart_num = Uart_num << 8;
  223. Uart_num |= USART2_RX_BUF002[19];
  224. if(Uart_num == 1)
  225. {//if(Uart_num == 0x0001)
  226. if(pkzq->USE_XYF == 0)
  227. {//if(pkzq->USE_XYF == 0)
  228. if(pkzq->data_buf[7] == 0x06)
  229. {//if(pkzq->data_buf[7] == 0x06)
  230. pkzq->USE_XYF = 1;
  231. Uart_len_TouChuan=USART2_RX_BUF002[20];
  232. Uart_len_TouChuan = Uart_len_TouChuan << 8;
  233. Uart_len_TouChuan |= USART2_RX_BUF002[21];
  234. memcpy(XYF_TxBuf,&USART2_RX_BUF002[22],Uart_len_TouChuan);
  235. //osDelay(50);
  236. for(retry=0;retry<300;++retry)
  237. {
  238. if(flagU3Rx && (pkzq->USE_XYF==0))
  239. break;
  240. osDelay(1);
  241. }
  242. if(flagU3Rx)
  243. {
  244. pTx[20] = (data_lengthU3>>8)&0xff;
  245. pTx[21] = data_lengthU3&0xff;
  246. memcpy(pTx+22,USART3_RX_BUF002,data_lengthU3);
  247. flagU1Rx=0;
  248. }
  249. else
  250. {
  251. pTx[20] = 0;
  252. pTx[21] = 0;
  253. }
  254. }//if(pkzq->data_buf[7] == 0x06)
  255. }//if(pkzq->USE_XYF == 0)
  256. }//if(Uart_num == 0x0001)
  257. if(Uart_num == 0)
  258. {//if(Uart_num == 0x0001)
  259. if(pkzq->USE_RKG == 0)
  260. {//if(pkzq->USE_XYF == 0)
  261. if(pkzq->data_buf[7] == 0x06)
  262. {//if(pkzq->data_buf[7] == 0x06)
  263. pkzq->USE_RKG = 1;
  264. Uart_len_TouChuan=USART2_RX_BUF002[20];
  265. Uart_len_TouChuan = Uart_len_TouChuan << 8;
  266. Uart_len_TouChuan |= USART2_RX_BUF002[21];
  267. memcpy(RKG_TxBuf,&USART2_RX_BUF002[22],Uart_len_TouChuan);
  268. //osDelay(50);
  269. for(retry=0;retry<300;++retry)
  270. {
  271. if(flagU1Rx && (pkzq->USE_RKG == 0))
  272. break;
  273. osDelay(1);
  274. }
  275. if(flagU1Rx)
  276. {
  277. pTx[20] = (data_lengthU1>>8)&0xff;
  278. pTx[21] = data_lengthU1&0xff;
  279. memcpy(pTx+22,USART1_RX_BUF002,data_lengthU1);
  280. flagU1Rx=0;
  281. }
  282. else
  283. {
  284. pTx[20] = 0;
  285. pTx[21] = 0;
  286. }
  287. }//if(pkzq->data_buf[7] == 0x06)
  288. }//if(pkzq->USE_XYF == 0)
  289. }//if(Uart_num == 0x0001)
  290. }