soft_seed_device.c 37 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138
  1. #include "soft_seed_device.h"
  2. #include "common.h"
  3. #include "string.h"
  4. #include "soft_p_2_c.h"
  5. #include "soft_eft.h"
  6. #include "soft_flow.h"
  7. #include "soft_water_device.h"
  8. #include "soft_uart.h"
  9. #include "soft_terrain.h"
  10. #include "soft_obstacle.h"
  11. #include "soft_bms.h"
  12. #include "soft_okcell.h"
  13. #include "soft_version.h"
  14. #include "math.h"
  15. #include "qingxie_bms.h"
  16. weight weight_vkinfo;
  17. seed seed_vkinfo;
  18. send_seed_device seed_dev;
  19. Weight_cal weight_order;
  20. /**
  21. * @file Weight_recieved_hookfuction
  22. * @brief VK协议称重传感器
  23. * @param none
  24. * @details
  25. * @author Zhang Sir
  26. **/
  27. void Weight_recieved_hookfuction(uint32_t CanID, uint8_t data[], uint8_t len)
  28. {
  29. switch (CanID)
  30. {
  31. //称重传感器
  32. case 0x81320:
  33. memcpy(&weight_vkinfo.sensor_status,&data[0],8);
  34. if(weight_vkinfo.weight < 0)
  35. {
  36. weight_vkinfo.weight = abs(weight_vkinfo.weight);
  37. }
  38. Dev.Weight.facid = FAC_VK;
  39. Dev.Weight_Link.connect_status = COMP_NORMAL;
  40. Dev.Weight_Link.recv_time = HAL_GetTick();
  41. break;
  42. //称重传感器设置回馈
  43. case 0x81322:
  44. switch (data[0])
  45. {
  46. //去皮校准ack
  47. case 0xf1:
  48. pmu_set_ack(_MSGID_SET,25,Cal_Remove_Peel,0);
  49. break;
  50. //称重校准ack
  51. case 0xf2:
  52. pmu_set_ack(_MSGID_SET,25,Cal_Weight,0);
  53. break;
  54. //恢复出厂设置ack
  55. case 0xf4:
  56. pmu_set_ack(_MSGID_SET,25,Cal_Seed_Back,0);
  57. break;
  58. case 0xf5:
  59. break;
  60. case 0xf6:
  61. {
  62. char ver_buf[8] = {0};
  63. int ver_temp32 = 0;
  64. memcpy(&ver_temp32,&data[1],4);
  65. Int2String(ver_temp32,&ver_buf[2],6);
  66. ver_buf[0] = '0';
  67. ver_buf[1] = data[7] + '0';
  68. regist_dev_info(&dev_weight,DEVICE_WEIGHT,false,NULL,0,(char *)&ver_buf[0],8,NULL,0,"weight",7);
  69. break;
  70. }
  71. //厂家编号
  72. case 0xf7:
  73. if(data[1] == 'Q' && data[2] == 'F') //0x 51 46
  74. {
  75. weight_vkinfo.serial_num = 3;
  76. Dev.Weight.facid = FAC_QIFEI;
  77. }
  78. else
  79. {
  80. weight_vkinfo.serial_num = 0;
  81. }
  82. weight_init_vk.step.fac_num_flag = 0;
  83. weight_init_count = 10;
  84. //memcpy(&weight_vkinfo.serial_num, &data[1],4);
  85. break;
  86. //读取传感器K值
  87. case 0xe1:
  88. if(data[7] == 0x1)
  89. {
  90. memcpy(&weight_vkinfo.senor_k[0],&data[1],4);
  91. }
  92. else if(data[7] == 0x2)
  93. {
  94. memcpy(&weight_vkinfo.senor_k[2],&data[1],4);
  95. }
  96. weight_init_vk.step.read_k_flag = 0;
  97. break;
  98. //设置传感器K值ack
  99. case 0xe2:
  100. pmu_set_ack(_MSGID_SET,Cal_Set_Sensor_K,0,0);
  101. weight_vkinfo.senor_k[data[7]] = data[1] + (data[2] << 8);
  102. break;
  103. //称重传感器模式读取
  104. case 0xe3:
  105. weight_vkinfo.mode = data[1];
  106. weight_init_vk.step.weight_mode_flag = 0;
  107. weight_init_count = 10;
  108. break;
  109. //称重传感器模式ack
  110. case 0xe4:
  111. pmu_set_ack(_MSGID_SET,Cal_Set_Sensor_Mode,0,0);
  112. weight_vkinfo.mode = data[1];
  113. break;
  114. //最大下药率读取
  115. case 0xe5:
  116. memcpy(&weight_vkinfo.dose_rate,&data[1],2);
  117. weight_init_vk.step.dose_rate_flag = 0;
  118. weight_init_count = 10;
  119. break;
  120. //最高下药率ack
  121. case 0xe6:
  122. pmu_set_ack(_MSGID_EFT_CON,Cal_Set_Doserate,0,0);
  123. weight_vkinfo.dose_rate = data[1] + (data[2] << 8);
  124. break;
  125. default:
  126. break;
  127. }
  128. break;
  129. //播撒器
  130. case 0x81323:
  131. memcpy(&seed_vkinfo,&data[0],7);
  132. Dev.Seed_Link.connect_status = COMP_NORMAL;
  133. Dev.Seed_Link.recv_time = HAL_GetTick();
  134. break;
  135. //播撒器回馈
  136. case 0x81325:
  137. switch (data[0])
  138. {
  139. case 0xf5:
  140. break;
  141. case 0xf6:
  142. break;
  143. case 0xf7:
  144. if(data[1] == 'Q' && data[2] == 'F')
  145. {
  146. seed_vkinfo.serial_num = 3;
  147. Dev.Seed.facid = FAC_QIFEI;
  148. }
  149. break;
  150. default:
  151. break;
  152. }
  153. break;
  154. case 0x81326:
  155. memcpy(&weight_vkinfo.Single_sensor[0],&data[0],8);
  156. break;
  157. default:
  158. break;
  159. }
  160. }
  161. //上电初始化发送的参数
  162. //device_type : 1 称重
  163. // : 2 播撒
  164. /**
  165. * @file seed_init_send_info
  166. * @brief 上电初始化发送的参数
  167. * @param 1 称重
  168. 2 播撒
  169. * @details
  170. * @author Zhang Sir
  171. **/
  172. Dev_weight_init weight_init_eft = {.step.read_k_flag = 1};
  173. Dev_weight_init weight_init_vk = {.step.dose_rate_flag = 1,
  174. .step.weight_mode_flag = 1,
  175. .step.read_k_flag = 1,
  176. .step.verison = 1,
  177. .step.fac_num_flag = 1};
  178. Dev_seed_init seed_init;
  179. bool recv_fmu_seed_info = false;
  180. uint8_t weight_init_count = 10;
  181. void seed_init_send_info(uint8_t device_type,char *factory)
  182. {
  183. uint8_t vk_canbuf[8] = {0,0,0,0,0,0XFE,0XFE,0};
  184. static uint8_t spread_init_count = 10;
  185. int vk_can_id = 0;
  186. if(strcmp(factory,"VK") == 0)
  187. {
  188. switch (device_type)
  189. {
  190. //称重
  191. case WEIGHT_DEVICE:
  192. vk_can_id = 0x81321;
  193. if(weight_init_vk.status != 0)
  194. {
  195. if(weight_init_vk.step.read_k_flag != 0)
  196. {
  197. vk_canbuf[0] = 0xE1;
  198. }
  199. else if(weight_init_vk.step.fac_num_flag != 0 && weight_init_count > 0)
  200. {
  201. vk_canbuf[0] = 0xF7;
  202. weight_init_count--;
  203. if(weight_init_count == 0)
  204. {
  205. weight_init_count = 10;
  206. weight_init_vk.step.fac_num_flag = 0;
  207. }
  208. }
  209. else if(weight_init_vk.step.verison != 0 && weight_init_count > 0)
  210. {
  211. vk_canbuf[0] = 0xF6;
  212. weight_init_count--;
  213. if(weight_init_count == 0)
  214. {
  215. weight_init_count = 10;
  216. weight_init_vk.step.verison = 0;
  217. }
  218. }
  219. else if (weight_init_vk.step.weight_mode_flag != 0 && weight_init_count > 0)
  220. {
  221. vk_canbuf[0] = 0xE3;
  222. weight_init_count--;
  223. if(weight_init_count == 0)
  224. {
  225. weight_init_count = 10;
  226. weight_init_vk.step.weight_mode_flag = 0;
  227. }
  228. }
  229. else if (weight_init_vk.step.dose_rate_flag != 0 && weight_init_count > 0)
  230. {
  231. vk_canbuf[0] = 0xE5;
  232. weight_init_count--;
  233. if(weight_init_count == 0)
  234. {
  235. weight_init_count = 10;
  236. weight_init_vk.step.dose_rate_flag = 0;
  237. }
  238. }
  239. // else if (weight_init_vk.step.dose_rate_flag != 0) //序列号和固件版本
  240. // {
  241. // vk_canbuf[0] = 0xf6;;
  242. // }
  243. // else if (weight_init_vk.step.dose_rate_flag != 0)
  244. // {
  245. // vk_canbuf[0] = 0xf5;
  246. // }
  247. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  248. }
  249. break;
  250. //播撒
  251. case SEED_DEVICE:
  252. vk_can_id = 0x81324;
  253. if(spread_init_count > 0)
  254. {
  255. //获取厂家信息
  256. vk_canbuf[0] = 0xf7;
  257. spread_init_count--;
  258. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  259. }
  260. break;
  261. default:
  262. break;
  263. }
  264. }
  265. else if (strcmp(factory,"EFT") == 0)
  266. {
  267. vk_can_id = SEND_EFT_INFO;
  268. switch (device_type)
  269. {
  270. case WEIGHT_DEVICE:
  271. if(weight_init_eft.status != 0)
  272. {
  273. if(weight_init_eft.step.read_k_flag != 0)
  274. {
  275. vk_canbuf[0] = 0xFD;
  276. vk_canbuf[5] = 0xf1;
  277. vk_canbuf[6] = 0xf3;
  278. }
  279. // else if(weight_init.step.sn_flag != 0) //EFT前板没有反馈。SN和版本
  280. // {
  281. // vk_canbuf[0] = 0xF8;
  282. // vk_canbuf[5] = 0xf1;
  283. // vk_canbuf[6] = 0xf3;
  284. // }
  285. // else if(weight_init.step.version_flag != 0)
  286. // {
  287. // vk_canbuf[0] = 0xf9;
  288. // vk_canbuf[5] = 0xf1;
  289. // vk_canbuf[6] = 0xf3;
  290. // }
  291. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  292. }
  293. break;
  294. case SEED_DEVICE:
  295. if(seed_init.status != 0)
  296. {
  297. if(seed_init.step.sn_flag != 0)
  298. {
  299. }
  300. else if(seed_init.step.version_flag != 0)
  301. {
  302. }
  303. //can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  304. }
  305. break;
  306. default:
  307. break;
  308. }
  309. }
  310. }
  311. /**
  312. * @file Set_Seed_Weight_Par
  313. * @brief 设置称重播撒参数
  314. * @param 1 称重
  315. 2 播撒
  316. * @details
  317. * @author Zhang Sir
  318. **/
  319. void Set_Seed_Weight_Par(uint8_t device_type,char *factory)
  320. {
  321. uint8_t can_buf[8] = {0};
  322. if(strcmp(factory,"VK") == 0)
  323. {
  324. switch (device_type)
  325. {
  326. case WEIGHT_DEVICE:
  327. if(weight_order.type != 0)
  328. {
  329. can_buf[1] = 0x00; //D1 - D4
  330. can_buf[2] = 0x00;
  331. can_buf[3] = 0x00;
  332. can_buf[4] = 0x00;
  333. can_buf[5] = 0xFE;
  334. can_buf[6] = 0xFE;
  335. can_buf[7] = 0x00; //D5
  336. switch (weight_order.type)
  337. {
  338. //去皮校准
  339. case Weight_Peer:
  340. can_buf[0] = 0xF1;
  341. break;
  342. //重量校准
  343. case Weight_Kg:
  344. can_buf[0] = 0xF2;
  345. memcpy(&can_buf[1], &weight_order.order_con2,2);
  346. break;
  347. case Weight_Reserve:
  348. break;
  349. //恢复出厂设置
  350. case Weight_Bcak:
  351. can_buf[0] = 0xF4;
  352. break;
  353. //称重传感器K值
  354. case Weight_Set_K:
  355. can_buf[0] = 0xE2;
  356. can_buf[1] = weight_order.order_con2 & 0xff;
  357. can_buf[2] = (weight_order.order_con2 >> 8) & 0xff;
  358. can_buf[7] = weight_order.order_con1 - 1; //VK协议传感器编号是0-3
  359. break;
  360. //称重传感器模式
  361. case Weight_Mode:
  362. can_buf[0] = 0xE4;
  363. can_buf[1] = weight_order.order_con1 & 0xff;
  364. break;
  365. //最高下药率
  366. case Weight_Drug_Rate:
  367. can_buf[0] = 0xE6;
  368. can_buf[1] = weight_order.order_con1 & 0xff;
  369. can_buf[2] = (weight_order.order_con1 >> 8) & 0xff;
  370. break;
  371. default:
  372. break;
  373. }
  374. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x81321);
  375. weight_order.type = 0;
  376. }
  377. break;
  378. case SEED_DEVICE:
  379. //更换信号输出方式 0 PWM 1 CAN
  380. if((seed_vkinfo.output != seed_output_mode) && recv_fmu_seed_info == true)
  381. {
  382. can_buf[0] = 0xF2;
  383. can_buf[1] = seed_output_mode;
  384. can_buf[2] = 0x00;
  385. can_buf[3] = 0x00;
  386. can_buf[4] = 0x00;
  387. can_buf[5] = 0xFE;
  388. can_buf[6] = 0xFE;
  389. can_buf[7] = 0;
  390. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x81324);
  391. }
  392. break;
  393. default:
  394. break;
  395. }
  396. }
  397. else if (strcmp(factory,"EFT") == 0)
  398. {
  399. switch (device_type)
  400. {
  401. case SEED_DEVICE:
  402. //更换信号输出方式 0 PWM 1 CAN
  403. if((eft_info.can_enable != seed_output_mode) && recv_fmu_seed_info == true)
  404. {
  405. can_buf[0] = 0xF2;
  406. can_buf[1] = seed_output_mode;
  407. can_buf[2] = 0x00;
  408. can_buf[3] = 0x00;
  409. can_buf[4] = 0x00;
  410. can_buf[5] = 0xf1;
  411. can_buf[6] = 0xf3;
  412. can_buf[7] = 0;
  413. can_send_msg_normal((unsigned char *)&can_buf, 8, SEND_EFT_INFO);
  414. HAL_Delay(10);
  415. }
  416. break;
  417. case WEIGHT_DEVICE:
  418. if(weight_order.type != 0)
  419. {
  420. can_buf[1] = 0x00;
  421. can_buf[2] = 0x00;
  422. can_buf[3] = 0x00;
  423. can_buf[4] = 0x00;
  424. can_buf[5] = 0xf1;
  425. can_buf[6] = 0xf3;
  426. can_buf[7] = 0;
  427. switch (weight_order.type)
  428. {
  429. case Weight_Peer:
  430. can_buf[0] = 0xF6;
  431. break;
  432. case Weight_Kg:
  433. can_buf[0] = 0xF7;
  434. can_buf[1] = (weight_order.order_con2 >> 8) & 0xff;
  435. can_buf[2] = weight_order.order_con2 & 0xff;
  436. break;
  437. case Weight_Reserve:
  438. break;
  439. case Weight_Bcak:
  440. can_buf[0] = 0xF5;
  441. break;
  442. case Weight_Set_K:
  443. can_buf[0] = 0xFC;
  444. can_buf[1] = eft_info.seed_k[0];
  445. can_buf[2] = eft_info.seed_k[1];
  446. can_buf[3] = eft_info.seed_k[2];
  447. can_buf[weight_order.order_con1] = weight_order.order_con2 & 0xff;
  448. break;
  449. default:
  450. break;
  451. }
  452. can_send_msg_normal((unsigned char *)&can_buf, 8, SEND_EFT_INFO);
  453. HAL_Delay(10);
  454. weight_order.type = 0;
  455. }
  456. break;
  457. default:
  458. break;
  459. }
  460. }
  461. }
  462. /**
  463. * @file can_sendmsg_VK
  464. * @brief 播撒常发数据包
  465. * @param
  466. * @details
  467. * @author Zhang Sir
  468. **/
  469. void can_sendmsg_VK(void)
  470. {
  471. static uint8_t vk_count = 0;
  472. uint8_t vk_canbuf[8] = {0};
  473. if(Dev.Weight_Link.connect_status == COMP_NORMAL && (Dev.Weight.facid == FAC_VK ||
  474. Dev.Weight.facid == FAC_QIFEI) && HAL_GetTick() > 3000)
  475. {
  476. seed_init_send_info(WEIGHT_DEVICE,"VK");
  477. Set_Seed_Weight_Par(WEIGHT_DEVICE,"VK");
  478. }
  479. if(Dev.Seed_Link.connect_status == COMP_NORMAL && (Dev.Seed.facid == FAC_VK ||
  480. Dev.Seed.facid == FAC_QIFEI) && HAL_GetTick() > 2000)
  481. {
  482. seed_init_send_info(SEED_DEVICE,"VK");
  483. Set_Seed_Weight_Par(SEED_DEVICE,"VK");
  484. if(seed_output_mode == 1 )
  485. {
  486. if(HAL_GetTick() < 5000) //初始化自检
  487. {
  488. tppwm_value = 1000;
  489. sow_rotate_value = 1000;
  490. }
  491. //发送转速 和阀门
  492. vk_canbuf[0] = 0xf1;
  493. vk_canbuf[1] = tppwm_value & 0xff;
  494. vk_canbuf[2] = (tppwm_value >> 8) & 0xff;
  495. vk_canbuf[3] = sow_rotate_value & 0xff;
  496. vk_canbuf[4] = (sow_rotate_value >> 8) & 0xff;
  497. vk_canbuf[5] = 0xfe;
  498. vk_canbuf[6] = 0xfe;
  499. vk_canbuf[7] = vk_count;
  500. vk_count++;
  501. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, 0x81324);
  502. }
  503. if(vk_count >= 255)
  504. {
  505. vk_count = 0;
  506. }
  507. }
  508. }
  509. Device_type Dev;
  510. comp_status seed_dev_link_status = COMP_NOEXIST;
  511. void check_dev_type_link(void )
  512. {
  513. int error_time = 0;
  514. error_time = HAL_GetTick() - Dev.Seed_Link.recv_time;
  515. if(Dev.Seed_Link.connect_status == COMP_NORMAL && error_time > 5000)
  516. {
  517. Dev.Seed_Link.connect_status = COMP_LOST;
  518. memset(&Dev.Seed.facid, 0, 7);
  519. }
  520. error_time = HAL_GetTick() - Dev.Weight_Link.recv_time;
  521. if(Dev.Pump_Link.connect_status == COMP_NORMAL && error_time > 5000)
  522. {
  523. Dev.Pump_Link.connect_status = COMP_LOST;
  524. memset(&Dev.Weight.facid, 0, 16);
  525. }
  526. error_time = HAL_GetTick() - Dev.Pump_Link.recv_time;
  527. if(Dev.Pump_Link.connect_status == COMP_NORMAL && error_time > 5000)
  528. {
  529. Dev.Pump_Link.connect_status = COMP_LOST;
  530. memset(&Dev.Pump.facid, 0, 11);
  531. }
  532. //
  533. error_time = HAL_GetTick() - Dev.Nozzle_Link.recv_time;
  534. if(Dev.Nozzle_Link.connect_status == COMP_NORMAL && error_time > 5000)
  535. {
  536. Dev.Nozzle_Link.connect_status = COMP_LOST;
  537. memset(&Dev.Nozzle.facid, 0, 11);
  538. }
  539. //
  540. error_time = HAL_GetTick() - Dev.Arm_Link.recv_time;
  541. if(Dev.Arm_Link.connect_status == COMP_NORMAL && error_time > 5000)
  542. {
  543. Dev.Arm_Link.connect_status = COMP_LOST;
  544. memset(&Dev.Arm.facid, 0, 2);
  545. }
  546. }
  547. void DM_obs_test( void )
  548. {
  549. static uint32_t time_50hz = 0;
  550. static uint32_t time_49hz = 0;
  551. static uint32_t time_48hz = 0;
  552. static uint32_t time_47hz = 0;
  553. uint8_t can_buf[8] = {0};
  554. if(Check_Timer_Ready(&time_50hz,20))
  555. {
  556. memcpy(&can_buf[0],&planep.QuaterQ0,4);
  557. memcpy(&can_buf[4],&planep.QuaterQ1,4);
  558. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2345);
  559. }
  560. if(Check_Timer_Ready(&time_49hz,20))
  561. {
  562. memcpy(&can_buf[0],&planep.QuaterQ2,4);
  563. memcpy(&can_buf[4],&planep.QuaterQ3,4);
  564. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2346);
  565. }
  566. if(Check_Timer_Ready(&time_48hz,50))
  567. {
  568. memcpy(&can_buf[0],&planep.pos_x,4);
  569. memcpy(&can_buf[4],&planep.pos_y,4);
  570. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2347);
  571. }
  572. if(Check_Timer_Ready(&time_47hz,50))
  573. {
  574. memcpy(&can_buf[0],&planep.pos_z,4);
  575. memcpy(&can_buf[4],&planep.pos_flag,4);
  576. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2348);
  577. }
  578. }
  579. /**
  580. * @file update_device_type_data
  581. * @brief 更新设备信息
  582. * @param
  583. * @details
  584. * @author Zhang Sir
  585. **/
  586. void update_device_type_data(void)
  587. {
  588. //50hz更新 5hz发送
  589. static uint32_t time_1hz = 0;
  590. static uint32_t time_330hz = 0;
  591. static uint32_t time_5hz = 0;
  592. static uint32_t time_50hz = 0;
  593. if(Check_Timer_Ready(&time_1hz,_1_HZ_))
  594. {
  595. Check_dev_link(&Dev.Seed_Link,5000,(char *)&Dev.Seed.facid,sizeof(Seed_info));
  596. Check_dev_link(&Dev.Weight_Link,5000,(char *)&Dev.Weight.facid,sizeof(Weight_info));
  597. Check_dev_link(&Dev.Pump_Link,5000,(char *)&Dev.Pump.facid,sizeof(Pump_info));
  598. Check_dev_link(&Dev.Nozzle_Link,5000,(char *)&Dev.Nozzle.facid,sizeof(Nozzle_info));
  599. Check_dev_link(&Dev.Arm_Link,5000,(char *)&Dev.Arm.facid,sizeof(Arm_info));
  600. Check_dev_link(&Dev.Flow_Link1,5000,(char *)&Dev.Flow.facid,sizeof(Flow_info));
  601. Check_dev_link(&Dev.Checklow_Link,5000,(char *)&Dev.Checklow.facid,sizeof(CheckLow_info));
  602. Check_dev_link(&Distributor_Link,5000,(char *)&distributor.arm_sensor1,sizeof(distributor_info));
  603. Check_dev_link(&Dev.Current_Link,5000,(char *)&Dev.Current.facid,sizeof(Current_info));
  604. Check_dev_link(&Dev.Lackloss_Link,5000,NULL,0);
  605. Check_dev_link(&Dev.L_pump1_Link,5000,(char *)&Dev.L_pump1.facid,sizeof(Linear_pump_info));
  606. Check_dev_link(&Dev.L_pump2_Link,5000,(char *)&Dev.L_pump2.facid,sizeof(Linear_pump_info));
  607. check_radar_link_status();
  608. }
  609. if(Check_Timer_Ready(&time_330hz,330))
  610. {
  611. //EFT播撒称重
  612. can_sendmsg_eft();
  613. }
  614. if(Check_Timer_Ready(&time_5hz,_5_HZ_))
  615. {
  616. //VK播撒称重
  617. can_sendmsg_VK();
  618. //流量计
  619. can_sendmsg_flow();
  620. //分电板
  621. Can_sendmsg_to_distributor();
  622. }
  623. if(Check_Timer_Ready(&time_50hz,_50_HZ_))
  624. {
  625. //tes_mmm();
  626. //好盈电调水泵
  627. Hobbywing_esc_func();
  628. //播撒器
  629. if(Dev.Seed_Link.connect_status == COMP_NORMAL)
  630. {
  631. switch (Dev.Seed.facid)
  632. {
  633. case FAC_VK:
  634. Dev.Seed.angle = 0;
  635. Dev.Seed.speed = 0;
  636. Dev.Seed.caplow = 0;
  637. Dev.Seed.warn = 0;
  638. break;
  639. case FAC_EFT:
  640. Dev.Seed.angle = eft_info.valve_angel;
  641. Dev.Seed.speed = eft_info.speed_rpm * 10;
  642. Dev.Seed.caplow = eft_info.warn_status & 0x1;
  643. Dev.Seed.warn = eft_info.warn_status >> 1;
  644. break;
  645. case FAC_QIFEI:
  646. Dev.Seed.angle = 0;
  647. Dev.Seed.speed = 0;
  648. Dev.Seed.caplow = 0;
  649. Dev.Seed.warn = 0;//weight_vkinfo.warn_status;
  650. break;
  651. default:
  652. break;
  653. }
  654. }
  655. //称重
  656. if(Dev.Weight_Link.connect_status == COMP_NORMAL)
  657. {
  658. switch (Dev.Weight.facid)
  659. {
  660. case FAC_VK:
  661. Dev.Weight.mode = weight_vkinfo.mode;
  662. Dev.Weight.kg = weight_vkinfo.weight / 10;
  663. Dev.Weight.rate = weight_vkinfo.weight_rate;
  664. Dev.Weight.k1 = weight_vkinfo.senor_k[0];
  665. Dev.Weight.k2 = weight_vkinfo.senor_k[1];
  666. Dev.Weight.k3 = weight_vkinfo.senor_k[2];
  667. Dev.Weight.k4 = weight_vkinfo.senor_k[3];
  668. Dev.Weight.warn = weight_vkinfo.warn_status;
  669. Dev.Weight.single_sensor[0] = weight_vkinfo.Single_sensor[0];
  670. Dev.Weight.single_sensor[1] = weight_vkinfo.Single_sensor[1];
  671. Dev.Weight.single_sensor[2] = weight_vkinfo.Single_sensor[2];
  672. Dev.Weight.single_sensor[3] = weight_vkinfo.Single_sensor[3];
  673. break;
  674. case FAC_EFT:
  675. Dev.Weight.mode = 0;
  676. Dev.Weight.kg = eft_info.weight / 10;
  677. Dev.Weight.rate = 0;
  678. Dev.Weight.k1 = eft_info.seed_k[0];
  679. Dev.Weight.k2 = eft_info.seed_k[1];
  680. Dev.Weight.k3 = eft_info.seed_k[2];
  681. Dev.Weight.k4 = 0;
  682. Dev.Weight.warn = eft_info.watering_warn_status >> 4 & 0xff;
  683. break;
  684. case FAC_QIFEI:
  685. Dev.Weight.mode = weight_vkinfo.mode;
  686. Dev.Weight.kg = weight_vkinfo.weight / 10;
  687. Dev.Weight.rate = weight_vkinfo.weight_rate;
  688. Dev.Weight.k1 = weight_vkinfo.senor_k[0];
  689. Dev.Weight.k2 = weight_vkinfo.senor_k[1];
  690. Dev.Weight.k3 = weight_vkinfo.senor_k[2];
  691. Dev.Weight.k4 = weight_vkinfo.senor_k[3];
  692. Dev.Weight.warn = weight_vkinfo.warn_status;
  693. Dev.Weight.dose_rate = weight_vkinfo.dose_rate;
  694. break;
  695. default:
  696. break;
  697. }
  698. }
  699. //水泵
  700. if(Dev.Pump_Link.connect_status == COMP_NORMAL)
  701. {
  702. switch (Dev.Pump.facid)
  703. {
  704. case FAC_VK:
  705. break;
  706. case FAC_EFT:
  707. Dev.Pump.rpm1 = eft_info.pump1_rpm * 60;
  708. Dev.Pump.rpm2 = eft_info.pump2_rpm * 60;
  709. Dev.Pump.rpm3 = 0;
  710. Dev.Pump.rpm4 = 0;
  711. if( (eft_info.watering_warn_status & 0x3) != 0)
  712. {
  713. Dev.Pump.warn = (eft_info.watering_warn_status & 0x3) + (eft_info.watering_warn_status & 0xf0);
  714. }
  715. else if((eft_info.watering_warn_status & 0x3) == 0)
  716. {
  717. Dev.Pump.warn = 0;
  718. }
  719. Dev.Pump.warn = 0; //屏蔽报警
  720. break;
  721. // case FAC_HW_ESC:
  722. // Dev.Pump.rpm1 = EscMsg[1].motorRPM;
  723. // Dev.Pump.rpm2 = EscMsg[2].motorRPM;
  724. // Dev.Pump.rpm3 = 0;
  725. // Dev.Pump.rpm4 = 0;
  726. // Dev.Pump.warn = EscMsg[1].warn_flag;
  727. // break;
  728. default:
  729. break;
  730. }
  731. }
  732. //离心喷头
  733. if(Dev.Nozzle_Link.connect_status == COMP_NORMAL)
  734. {
  735. switch (Dev.Nozzle.facid)
  736. {
  737. case FAC_VK:
  738. break;
  739. case FAC_EFT:
  740. Dev.Nozzle.rpm1 = eft_info.cent1_rpm * 60;
  741. Dev.Nozzle.rpm2 = eft_info.cent2_rpm * 60;
  742. Dev.Nozzle.rpm3 = 0;
  743. Dev.Nozzle.rpm4 = 0;
  744. if( (eft_info.watering_warn_status & 0xc) != 0)
  745. {
  746. Dev.Nozzle.warn = ((eft_info.watering_warn_status >> 2) & 0x3) + (eft_info.watering_warn_status & 0xf0);
  747. }
  748. else if((eft_info.watering_warn_status & 0xc) == 0)
  749. {
  750. Dev.Nozzle.warn = 0;
  751. }
  752. Dev.Nozzle.warn = 0; //屏蔽报警
  753. break;
  754. default:
  755. break;
  756. }
  757. }
  758. //机臂传感器
  759. if(Dev.Arm_Link.connect_status == COMP_NORMAL)
  760. {
  761. switch (Dev.Arm.facid)
  762. {
  763. case FAC_VK:
  764. break;
  765. case FAC_EFT:
  766. Dev.Arm.status = eft_info.enginearm_lock;
  767. break;
  768. case FAC_VK_ALLINONE:
  769. Dev.Arm.status = (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_12 ) & 0x1) << 3) | \
  770. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_13 ) & 0x1) << 2) | \
  771. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_14 ) & 0x1)) | \
  772. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_15 ) & 0x1) << 1);
  773. break;
  774. default:
  775. break;
  776. }
  777. }
  778. //线性水泵
  779. if(Dev.L_pump1_Link.connect_status == COMP_NORMAL)
  780. {
  781. switch (Dev.L_pump1.facid)
  782. {
  783. case FAC_VK:
  784. break;
  785. case FAC_EFT:
  786. break;
  787. case FAC_HW_ESC:
  788. Dev.L_pump1.warn = EscMsg[1].warn_flag;
  789. Dev.L_pump1.rpm = EscMsg[1].motorRPM;
  790. break;
  791. default:
  792. break;
  793. }
  794. }
  795. if(Dev.L_pump2_Link.connect_status == COMP_NORMAL)
  796. {
  797. switch (Dev.L_pump2.facid)
  798. {
  799. case FAC_VK:
  800. break;
  801. case FAC_EFT:
  802. break;
  803. case FAC_HW_ESC:
  804. Dev.L_pump2.warn = EscMsg[2].warn_flag;
  805. Dev.L_pump2.rpm = EscMsg[2].motorRPM;
  806. break;
  807. default:
  808. break;
  809. }
  810. }
  811. // if(Dev.L_pump2_Link.connect_status == COMP_NORMAL)
  812. // {
  813. // switch (Dev.L_pump2.facid)
  814. // {
  815. // case FAC_VK:
  816. // break;
  817. // case FAC_HW_ESC:
  818. // Dev.L_pump2.warn = EscMsg[1].warn_flag;
  819. // Dev.L_pump2.rpm = EscMsg[1].motorRPM;
  820. // break;
  821. // default:
  822. // break;
  823. // }
  824. // }
  825. //智能电池
  826. if(Dev.Bms_Link.connect_status == COMP_NORMAL)
  827. {
  828. Dev.Bms.index = 0;
  829. Dev.Bms.facid = bms_data.serial_num;
  830. bms_data.bms_version[0] = 'V';
  831. bms_data.bms_version[1] = 'K';
  832. bms_data.bms_version[2] = '3';
  833. bms_data.bms_group = group_num;
  834. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data.bms_version,5 + bms_data.bms_num * 2);
  835. Dev.Bms.index += (5 + bms_data.bms_num * 2);
  836. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data.bms_ids,43);
  837. Dev.Bms.index += 43;
  838. memset(&Dev.Bms.buf[Dev.Bms.index],0,2); //EFT协议新加插头问题
  839. Dev.Bms.index += 2;
  840. if(bms_data.bms_group == 2)
  841. {
  842. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data2.bms_num,1 + bms_data2.bms_num * 2);
  843. Dev.Bms.index += (1 + bms_data2.bms_num * 2);
  844. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data2.bms_ids,43);
  845. Dev.Bms.index += 43;
  846. memset(&Dev.Bms.buf[Dev.Bms.index],0,2); //EFT协议新加插头问题
  847. Dev.Bms.index += 2;
  848. }
  849. }
  850. if(_Aqx_bms_link.connect_status == COMP_NORMAL)
  851. {
  852. Dev.Bms.facid = FAC_QX_BMS;
  853. Dev.Bms.buf[0] = 0;//电池串数
  854. Dev.Bms.index = 0;
  855. Dev.Bms.index++;
  856. for(uint8_t i = 0; i < 4; i++)
  857. {
  858. if(_qx_bms_link[i].connect_status == COMP_NORMAL)
  859. {
  860. Dev.Bms.buf[0]++;
  861. memcpy(&Dev.Bms.buf[Dev.Bms.index],&_qx_bms[i].bat_voltage,sizeof(qingxie_bms_status_t));
  862. Dev.Bms.index += sizeof(qingxie_bms_status_t);
  863. }
  864. }
  865. }
  866. //流量计、断料记、雷达数据一直发
  867. if(true/*Dev.Flow_Link1.connect_status == COMP_NORMAL*/)
  868. {
  869. switch (Dev.Flow.facid)
  870. {
  871. case FAC_VK:
  872. Dev.Flow.speed1 = flow_dev1.speed;
  873. Dev.Flow.speed2 = flow_dev2.speed;
  874. Dev.Flow.ml1 = flow_dev1.irq_count;
  875. Dev.Flow.ml2 = flow_dev2.irq_count;
  876. Dev.Flow.warn1 = 0;
  877. Dev.Flow.warn2 = 0;
  878. Dev.Flow.k1 = 0;
  879. Dev.Flow.k2 = 0;
  880. break;
  881. case FAC_MIMO_SIG:// APP需要识别单双管
  882. Dev.Flow.speed1 = flow_mimo1.flow_speed;
  883. Dev.Flow.speed2 = flow_mimo2.flow_speed;
  884. Dev.Flow.ml1 = (flow_mimo1.total_ml + 65535 * flow_mimo1.overturn_count) * FlOW_KP * 60 / 1000;
  885. Dev.Flow.ml2 = (flow_mimo2.total_ml + 65535 * flow_mimo2.overturn_count) * FlOW_KP * 60 / 1000;
  886. Dev.Flow.warn1 = flow_mimo1.status;
  887. Dev.Flow.warn2 = flow_mimo2.status;
  888. Dev.Flow.k1 = flow_mimo1.flow_k;
  889. Dev.Flow.k2 = flow_mimo2.flow_k;
  890. break;
  891. case FAC_MIMO_DOU:
  892. Dev.Flow.speed1 = flow_mimo1.flow_speed;
  893. Dev.Flow.speed2 = flow_mimo2.flow_speed;
  894. Dev.Flow.ml1 = (flow_mimo1.total_ml + 65535 * flow_mimo1.overturn_count) * FlOW_KP * 60 / 1000;
  895. Dev.Flow.ml2 = (flow_mimo2.total_ml + 65535 * flow_mimo2.overturn_count) * FlOW_KP * 60 / 1000;
  896. Dev.Flow.warn1 = flow_mimo1.status;
  897. Dev.Flow.warn2 = flow_mimo2.status;
  898. Dev.Flow.k1 = flow_mimo1.flow_k;
  899. Dev.Flow.k2 = flow_mimo2.flow_k;
  900. break;
  901. case FAC_QIFEI_SIG:
  902. Dev.Flow.speed1 = flow_inf.ch1.speed;
  903. Dev.Flow.speed2 = flow_inf.ch2.speed;
  904. Dev.Flow.ml1 = (flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  905. Dev.Flow.ml2 = (flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  906. Dev.Flow.warn1 = flow_inf.ch1.warn;
  907. Dev.Flow.warn2 = flow_inf.ch2.warn;
  908. Dev.Flow.k1 = flow_inf.ch1.k;
  909. Dev.Flow.k2 = flow_inf.ch2.k;
  910. break;
  911. case FAC_QIFEI_DOU: // 12做个调换
  912. Dev.Flow.speed1 = flow_inf.ch2.speed;
  913. Dev.Flow.speed2 = flow_inf.ch1.speed;
  914. Dev.Flow.ml1 = (flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  915. Dev.Flow.ml2 = (flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  916. Dev.Flow.warn1 = flow_inf.ch2.warn;
  917. Dev.Flow.warn2 = flow_inf.ch1.warn;
  918. Dev.Flow.k1 = flow_inf.ch2.k;
  919. Dev.Flow.k2 = flow_inf.ch1.k;
  920. break;
  921. case FAC_HW_ESC:
  922. Dev.Flow.speed1 = EscMsg[1].motorRPM / FlOW_KP;
  923. Dev.Flow.speed2 = EscMsg[2].motorRPM / FlOW_KP;
  924. Dev.Flow.ml1 = 0;//(flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  925. Dev.Flow.ml2 = 0;//(flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  926. Dev.Flow.warn1 = 0;
  927. Dev.Flow.warn2 = 0;
  928. Dev.Flow.k1 = 0;
  929. Dev.Flow.k2 = 0;
  930. break;
  931. default:
  932. break;
  933. }
  934. switch (Dev.Checklow.facid)
  935. {
  936. case FAC_VK:
  937. Dev.Checklow.L1_status = (uint16_t)L3_status;
  938. Dev.Checklow.L2_status = (uint16_t)L4_status;
  939. Dev.Checklow.liquid_persent = decode_liquid_info();
  940. Dev.Checklow.seed_lackloss = mimo_lackloss.status;
  941. Dev.Checklow.warn = 0;
  942. Dev.Checklow.lack_distance = mimo_lackloss.distance / 10; //cm
  943. Dev.Checklow.lack_power = mimo_lackloss.strength;
  944. break;
  945. case FAC_DM_CHECKLOW:
  946. Dev.Checklow.L1_status = (uint16_t)L3_status;
  947. Dev.Checklow.L2_status = (uint16_t)L4_status;
  948. Dev.Checklow.liquid_persent = decode_liquid_info();
  949. Dev.Checklow.seed_lackloss = DM_lackloss.status;
  950. Dev.Checklow.warn = 0;
  951. Dev.Checklow.lack_distance = DM_lackloss.distance;
  952. Dev.Checklow.lack_power = DM_lackloss.strength;
  953. break;
  954. default:
  955. break;
  956. }
  957. //雷达
  958. Dev.Radar.height_T = get_radar_info(MSGID_SET_T_RADAR,0);
  959. Dev.Radar.distance_F_Y = get_radar_info(MSGID_SET_F_RADAR,OBS_Y);
  960. Dev.Radar.distance_F_Y_ori = Dev.Radar.distance_F_Y;
  961. // if((Dev.Radar.distance_F_Y > 0) && (Fobs_handle_function() == false))
  962. // Dev.Radar.distance_F_Y = 0;
  963. Dev.Radar.distance_F_X = get_radar_info(MSGID_SET_F_RADAR,OBS_X);
  964. Dev.Radar.signal_F_qulity = mimo_f_info.signal_qulity;
  965. Dev.Radar.distance_B_Y = get_radar_info(MSGID_SET_B_RADAR,OBS_Y);
  966. Dev.Radar.distance_B_Y_ori = Dev.Radar.distance_B_Y;
  967. // if((Dev.Radar.distance_B_Y > 0) && (Bobs_handle_function() == false))
  968. // Dev.Radar.distance_B_Y = 0;
  969. Dev.Radar.distance_B_X = get_radar_info(MSGID_SET_B_RADAR,OBS_X);
  970. Dev.Radar.signal_B_qulity = mimo_b_info.signal_qulity;
  971. terrain_is_link = Dev.Radar.height_T > -1? true:false;
  972. obs_f_is_link = Dev.Radar.distance_F_Y > -1? true:false;
  973. obs_b_is_link = Dev.Radar.distance_B_Y > -1? true:false;
  974. }
  975. if(Dev.Current_Link.connect_status == COMP_NORMAL)
  976. {
  977. Dev.Current.facid = FAC_VK;
  978. Dev.Current.tempture = power_BatteryInfo.temperature * 10;
  979. Dev.Current.voltage = power_BatteryInfo.voltage * 10;
  980. Dev.Current.current = power_BatteryInfo.current * 10;
  981. }
  982. if(Dev.Part_Tradar_Link.connect_status == COMP_NORMAL)
  983. {
  984. Dev.Part_radarT.height_part1 = T_radar[0].Distance * 0.05f * 100 * cos(T_radar[0].Amuzith * 0.1f / RAD);
  985. Dev.Part_radarT.height_part2 = T_radar[1].Distance * 0.05f * 100 * cos(T_radar[1].Amuzith * 0.1f / RAD);
  986. Dev.Part_radarT.height_part3 = T_radar[2].Distance * 0.05f * 100 * cos(T_radar[2].Amuzith * 0.1f / RAD);
  987. }
  988. if(Dev.Temp_Sensor_Link.connect_status == COMP_NORMAL)
  989. {
  990. switch (Dev.Temp_sensor.facid)
  991. {
  992. case FAC_EFT:
  993. Dev.Temp_sensor.Positive_pole = Temp_sensor.Positive_pole;
  994. Dev.Temp_sensor.Negative_pole = Temp_sensor.Negative_pole;
  995. break;
  996. default:
  997. break;
  998. }
  999. }
  1000. }
  1001. }
  1002. comp_status QIFEI_link_status = COMP_NOEXIST;
  1003. uint32_t get_QIFEI_time = 0;
  1004. volatile char get_QIFEI_time_sem = 0;
  1005. unsigned int get_QIFEI_time_err = 0;
  1006. void QIFEI_recieved_hookfuction(uint32_t CanID, uint8_t data[], uint8_t len)
  1007. {
  1008. uint8_t id = 0;
  1009. QIFEI_link_status = COMP_NORMAL;
  1010. get_QIFEI_time = HAL_GetTick();
  1011. id = data[0];
  1012. switch (CanID)
  1013. {
  1014. case 0x0AD2:
  1015. break;
  1016. case 0x0AD0:
  1017. switch (id)
  1018. {
  1019. case 0x01:
  1020. break;
  1021. default:
  1022. break;
  1023. }
  1024. break;
  1025. default:
  1026. break;
  1027. }
  1028. }