soft_seed_device.c 45 KB

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