soft_eft.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. #include "soft_eft.h"
  2. #include "common.h"
  3. #include "soft_p_2_c.h"
  4. #include "string.h"
  5. #include "soft_seed_device.h"
  6. #include "soft_version.h"
  7. uint8_t seed_output_mode = 1;
  8. eft eft_info;
  9. short tppwm_value = 1000;
  10. short sow_rotate_value = 1000;
  11. /**
  12. * @file EftCanRecvHookFunction
  13. * @brief EFT信息接收
  14. * @param
  15. * @details
  16. * @author Zhang Sir
  17. **/
  18. _Temp_sensor Temp_sensor;
  19. _mimo_lackloss mimo_lackloss;
  20. _mimo_lackloss DM_lackloss;
  21. void EftCanRecvHookFunction(uint32_t cellCanID, uint8_t data[], uint8_t len)
  22. {
  23. switch (cellCanID)
  24. {
  25. case REVE_EFT_INFO_1:
  26. //eft是大端
  27. eft_info.valve_angel = data[0];
  28. eft_info.warn_status = data[1];
  29. eft_info.can_enable = data[2];
  30. eft_info.speed_rpm = data[5];
  31. Dev.Seed_Link.connect_status = COMP_NORMAL;
  32. Dev.Seed.facid = FAC_EFT;
  33. Dev.Seed_Link.recv_time = HAL_GetTick();
  34. break;
  35. case REVE_EFT_INFO:
  36. eft_info.enginearm_lock = data[0];
  37. eft_info.weight = data[1] * 256 + data[2];
  38. eft_info.pump1_rpm = data[4];
  39. eft_info.pump2_rpm = data[3];
  40. eft_info.cent1_rpm = data[5];
  41. eft_info.cent2_rpm = data[6];
  42. eft_info.watering_warn_status = data[7];
  43. Dev.Weight_Link.connect_status = COMP_NORMAL;
  44. Dev.Weight.facid = FAC_EFT;
  45. Dev.Weight_Link.recv_time = HAL_GetTick();
  46. Dev.Pump_Link.connect_status = COMP_NORMAL;
  47. Dev.Pump.facid = FAC_EFT;
  48. Dev.Pump_Link.recv_time = HAL_GetTick();
  49. Dev.Nozzle_Link.connect_status = COMP_NORMAL;
  50. Dev.Nozzle.facid = FAC_EFT;
  51. Dev.Nozzle_Link.recv_time = HAL_GetTick();
  52. Dev.Arm_Link.connect_status = COMP_NORMAL;
  53. Dev.Arm.facid = FAC_EFT;
  54. Dev.Arm_Link.recv_time = HAL_GetTick();
  55. break;
  56. case REVE_EFT_LOW:
  57. if(data[0] == 0x03)
  58. {
  59. Dev.Lackloss_Link.connect_status = COMP_NORMAL;
  60. Dev.Lackloss_Link.recv_time = HAL_GetTick();
  61. mimo_lackloss.distance = data[2] + data[1] * 256;
  62. mimo_lackloss.strength = data[4] + data[3] * 256;
  63. mimo_lackloss.status = data[7];
  64. }
  65. break;
  66. case REVE_EFT_ACK:
  67. switch (data[0])
  68. {
  69. case 0xFA:
  70. break;
  71. case 0xF5:
  72. pmu_set_ack(_MSGID_SET,25,Cal_Seed_Back,0);
  73. break;
  74. case 0xF6:
  75. pmu_set_ack(_MSGID_SET,25,Cal_Remove_Peel,0);
  76. break;
  77. case 0xF7:
  78. pmu_set_ack(_MSGID_SET,25,Cal_Weight,0);
  79. break;
  80. case 0xf8:
  81. for(uint8_t i = 0;i < 4;i++)
  82. {
  83. eft_info.sn[i*2] = ((data[i+1] >> 4) & 0xf) + '0';
  84. eft_info.sn[i*2+1] = (data[i+1] & 0xf) + '0';
  85. }
  86. eft_info.sn[8] = ((data[7] >> 4) & 0xf) + '0';
  87. eft_info.sn[9] = (data[7] & 0xf) + '0';
  88. //Dev_info.dev_connect.dev_flag.seed = true;
  89. break;
  90. case 0xF9:
  91. eft_info.version[0] = data[1] + '0';
  92. eft_info.version[1] = data[2] + '0';
  93. //Dev_info.dev_connect.dev_flag.seed = true;
  94. break;
  95. case 0xFC:
  96. eft_info.seed_k[weight_order.order_con1 - 1] = weight_order.order_con2 & 0xff;
  97. pmu_set_ack(_MSGID_SET,MSGID_SET_WEIGHT_K,0,0);
  98. break;
  99. case 0xFD:
  100. memcpy(&eft_info.seed_k[0],&data[1],3);
  101. weight_init_eft.step.read_k_flag = 0;
  102. break;
  103. default:
  104. break;
  105. }
  106. break;
  107. case BMS_LINE_TEMP:
  108. Temp_sensor.Positive_pole = data[0] * 256 + data[1];
  109. Temp_sensor.Negative_pole = data[2] * 256 + data[3];
  110. Dev.Temp_Sensor_Link.connect_status = COMP_NORMAL;
  111. Dev.Temp_sensor.facid = FAC_EFT;
  112. Dev.Temp_Sensor_Link.recv_time = HAL_GetTick();
  113. regist_dev_info(&dev_tempSensor,DEVICE_TEMP_SENSOR,false,NULL,0,NULL,0,NULL,0,"EFT",4);
  114. break;
  115. default:
  116. break;
  117. }
  118. }
  119. /**
  120. * @file can_sendmsg_eft
  121. * @brief 发送信息给EFT
  122. * @param
  123. * @details
  124. * @author Zhang Sir
  125. **/
  126. void can_sendmsg_eft(void)
  127. {
  128. static int eft_count = 0;
  129. uint8_t eft_canbuf[8] = {0};
  130. if(Dev.Seed_Link.connect_status == COMP_NORMAL && Dev.Seed.facid == FAC_EFT)
  131. {
  132. seed_init_send_info(SEED_DEVICE,"EFT");
  133. Set_Seed_Weight_Par(SEED_DEVICE,"EFT");
  134. if(seed_output_mode == 1)
  135. {
  136. if(HAL_GetTick() < 5000) //初始化自检
  137. {
  138. tppwm_value = 1000;
  139. sow_rotate_value = 1000;
  140. }
  141. //发送转速 和阀门
  142. eft_canbuf[0] = 0xf1;
  143. eft_canbuf[1] = (tppwm_value >> 8) & 0xff;
  144. eft_canbuf[2] = tppwm_value & 0xff;
  145. eft_canbuf[3] = (sow_rotate_value >> 8) & 0xff;
  146. eft_canbuf[4] = sow_rotate_value & 0xff;
  147. eft_canbuf[5] = 0xf1;
  148. eft_canbuf[6] = 0xf3;
  149. eft_canbuf[7] = eft_count;
  150. can_send_msg_normal((unsigned char *)&eft_canbuf, 8, SEND_EFT_INFO);
  151. eft_count++;
  152. if(eft_count >= 256)
  153. {
  154. eft_count = 0;
  155. }
  156. }
  157. }
  158. if((Dev.Weight_Link.connect_status == COMP_NORMAL && Dev.Weight.facid == FAC_EFT))
  159. {
  160. seed_init_send_info(WEIGHT_DEVICE,"EFT");
  161. Set_Seed_Weight_Par(WEIGHT_DEVICE,"EFT");
  162. }
  163. if(planep.UAV_type == AG_EFTZ)
  164. {
  165. eft_canbuf[0] = 0xE1;
  166. eft_canbuf[1] = (pmu_pin.aux_light & 0x1) > 0? (planep.lock_status > 3? (pmu_pin.aux_light >> 2 & 0x7f) : 20) : 0;
  167. eft_canbuf[2] = (pmu_pin.aux_light & 0x2) > 0? (planep.lock_status > 3? (pmu_pin.aux_light >> 9 & 0x7f) : 20) : 0;
  168. eft_canbuf[3] = 0;
  169. eft_canbuf[4] = 0;
  170. eft_canbuf[5] = 0xf1;
  171. eft_canbuf[6] = 0xf3;
  172. eft_canbuf[7] = 0;
  173. can_send_msg_normal((unsigned char *)&eft_canbuf, 8, SEND_EFT_INFO);
  174. }
  175. }
  176. void DMlacklossCanRecvFunction(uint32_t cellCanID, uint8_t data[], uint8_t len)//电目断料计接收函数
  177. {
  178. /*if(cellCanID==CAN_MSGID_DM_LACKLOSS)
  179. {
  180. uint32_t DMLackloss_recvtime=0;
  181. Dev.DM_Lackloss_Link.connect_status=COMP_NORMAL;
  182. Dev.DM_Lackloss_Link.recv_time = HAL_GetTick();
  183. DMLackloss_recvtime=Dev.DM_Lackloss_Link.recv_time;
  184. DM_lackloss.status=(data[0] ^ 1);
  185. DM_lackloss.distance=DMLackloss_recvtime & 0xFFFF;
  186. DM_lackloss.strength=(DMLackloss_recvtime >> 16) & 0xFFFF;
  187. }*/
  188. switch (data[0])
  189. {
  190. case 0XA0:
  191. Dev.Checklow.facid = FAC_DM_CHECKLOW;
  192. Dev.Lackloss_Link.connect_status= COMP_NORMAL;
  193. Dev.Lackloss_Link.recv_time = HAL_GetTick();
  194. DM_lackloss.status = 0;
  195. break;
  196. case 0XA1:
  197. Dev.Checklow.facid = FAC_DM_CHECKLOW;
  198. Dev.Lackloss_Link.connect_status = COMP_NORMAL;
  199. Dev.Lackloss_Link.recv_time = HAL_GetTick();
  200. DM_lackloss.status = 1;
  201. break;
  202. case 0XB0:
  203. pmu_set_ack(_MSGID_SET,MSGID_SET_LACKLOSS_CAL,0x01,0x00);
  204. break;
  205. case 0XB1 ... 0XB2:
  206. pmu_set_ack(_MSGID_SET,MSGID_SET_LACKLOSS_CAL,0x02,0x00);
  207. break;
  208. default:
  209. break;
  210. }
  211. }