soft_engine.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723
  1. #include "soft_engine.h"
  2. #include "soft_crc.h"
  3. #include "crc.h"
  4. #include "string.h"
  5. #include "soft_p_2_c.h"
  6. #include "soft_test.h"
  7. #include "soft_uart.h"
  8. struct ENGINE_DATA engine_data;
  9. //串口接收奥安发动机数据
  10. AOAN_TYPE aoan_data = {0, .engin_warn = 0xffff};
  11. Connect_check aoan_engine_Link;
  12. //解析奥安油电混传感器数据
  13. short decode_aoan_engine(uint8_t *pdata, uint16_t length)
  14. {
  15. short rst = 0;
  16. if (pdata[0] == 0x5A && pdata[1] == 0xA5 && pdata[2] == 0x1A && pdata[3] == 0x02)
  17. {
  18. unsigned char dNum = pdata[2];
  19. //校验通过。
  20. if (Get_Crc16(pdata, dNum + 5) == 0)
  21. {
  22. rst = 1;
  23. aoan_engine_Link.connect_status = COMP_NORMAL;
  24. //赋值数据
  25. memcpy(&aoan_data, &pdata[3], dNum);
  26. aoan_engine_Link.recv_time = HAL_GetTick();
  27. }
  28. }
  29. return rst;
  30. }
  31. // //串口接收VKV3发动机数据
  32. VKV3_TYPE vkv3_data = {0, .engin_warn = 0xffff};
  33. // VKV3_TYPE vkv3_data2 = {0, .engin_warn = 0xffff};
  34. Connect_check vkv3_engine_link;
  35. // Connect_check vkv3_engine2_link;
  36. //解析V3协议油电混传感器数据
  37. short decode_vkv3_engine(uint8_t *pdata, uint16_t length)
  38. {
  39. short rst = 0;
  40. uint32_t engine_sn_temp = 0;
  41. static uint32_t engine_sn1 = 0;
  42. VKV3_TYPE *ptr = NULL;
  43. if (pdata[0] == 0x5A && pdata[1] == 0xA5 && pdata[2] == 0X27 && pdata[4] == 0X03)
  44. {
  45. unsigned char dLEN = pdata[2];
  46. unsigned char comID = pdata[3];
  47. //校验通过。
  48. if (Get_Crc16(pdata, dLEN + 6) == 0)
  49. {
  50. memcpy(&engine_sn_temp, &pdata[12], 4);
  51. rst = 1;
  52. if(engine_sn1 == 0 || engine_sn_temp == engine_sn1)
  53. {
  54. ptr = &vkv3_data;
  55. vkv3_engine_link.connect_status = COMP_NORMAL;
  56. vkv3_engine_link.recv_time = HAL_GetTick();
  57. if(engine_sn1 == 0)
  58. engine_sn1 = engine_sn_temp;
  59. }
  60. else
  61. {
  62. // ptr = &vkv3_data2;
  63. // vkv3_engine2_link.connect_status = COMP_NORMAL;
  64. // vkv3_engine2_link.recv_time = HAL_GetTick();
  65. }
  66. switch (comID)
  67. {
  68. case 0X01:
  69. //赋值数据
  70. memcpy(&ptr->engin_ver, &pdata[4], dLEN);
  71. break;
  72. default:
  73. break;
  74. }
  75. }
  76. }
  77. return rst;
  78. }
  79. bool geely_set_tcd = false,geely_set_tcd_re = false,
  80. geely_set_tlock = false, geely_set_tlock_re = false, geely_set_protect = false,
  81. geely_send_BJtime = false,geely_get_version = false,geely_get_time = false;
  82. GEELY2 geely_data2;
  83. //解析吉利发动机
  84. GEELY geely_data = {0};
  85. GEELY_MONI geely_moni = {0};
  86. Connect_check geely_engin_link;
  87. void EngGeelyCanRecvHookFunction(uint32_t cellCanID, uint8_t data[], uint8_t len)
  88. {
  89. if(cellCanID == 0x100) //第二版协议识别
  90. {
  91. geely_engin_link.connect_status = COMP_NORMAL;
  92. geely_engin_link.recv_time = HAL_GetTick();
  93. }
  94. else if (cellCanID == 0x1c0)
  95. {
  96. memcpy(&geely_data.engine_ver, &data[0], len);
  97. }
  98. else if (cellCanID == 0x1c1)
  99. {
  100. //木牛防地雷达会异常进入发动机识别
  101. geely_engin_link.connect_status = COMP_NORMAL;
  102. memcpy(&geely_data.engine_rev, &data[0], len);
  103. }
  104. else if (cellCanID == 0x1c2)
  105. {
  106. memcpy(&geely_data.engine_vol, &data[0], len);
  107. }
  108. else if (cellCanID == 0x1c3)
  109. {
  110. uint8_t checkSum = 0;
  111. for (uint8_t i = 0; i < 8; i++)
  112. {
  113. checkSum += data[i];
  114. }
  115. geely_moni.recv_1c3++;
  116. if (checkSum == 0)
  117. {
  118. memcpy(&geely_data.engine_control, &data[0], len);
  119. if (geely_moni.msg1c3_last + 1 != geely_data.engine_counts)
  120. {
  121. geely_moni.msg1c3_indexerr++;
  122. }
  123. geely_moni.msg1c3_last = geely_data.engine_counts;
  124. if(geely_data.engine_set == 0x11)
  125. {
  126. //接收保养时间反馈
  127. if(geely_set_tcd == true)
  128. {
  129. geely_set_tcd = false;
  130. geely_set_counts = 0;
  131. geely_set_tcd_re = true;
  132. }
  133. }
  134. if(geely_data.engine_set == 0x12)
  135. {
  136. //接收保养时间复位反馈
  137. if(geely_set_tcd_re == true)
  138. {
  139. geely_set_tcd_re = false;
  140. geely_set_counts = 0;
  141. }
  142. }
  143. if(geely_data.engine_set == 0x14)
  144. {
  145. //接收锁机时间反馈
  146. if(geely_set_tlock == true)
  147. {
  148. geely_set_tlock = false;
  149. geely_set_counts = 0;
  150. geely_set_tlock_re = true;
  151. }
  152. }
  153. if(geely_data.engine_set == 0x15)
  154. {
  155. //接收锁机时间复位反馈
  156. if(geely_set_tlock_re == true)
  157. {
  158. geely_set_tlock_re = false;
  159. geely_set_counts = 0;
  160. }
  161. }
  162. if(geely_data.engine_set == 0x17)
  163. {
  164. }
  165. }
  166. else
  167. {
  168. geely_moni.msg1c3_sumerr++;
  169. }
  170. }
  171. else if (cellCanID == 0x1c4)
  172. {
  173. memcpy(&geely_data.engine_runtime, &data[0], len);
  174. }
  175. else
  176. {
  177. if(cellCanID >= 0x1E1 && cellCanID <= 0x1EF)
  178. {
  179. geely_engin_link.connect_status = COMP_NORMAL;
  180. if(geely_data2.version2_flag != true)
  181. {
  182. geely_data2.version2_flag = true;
  183. } //作为第二版协议标志
  184. }
  185. //第二版协议
  186. switch (cellCanID)
  187. {
  188. case 0x031:
  189. geely_send_BJtime = true;
  190. break;
  191. case 0x1E1:
  192. break;
  193. case 0x1E2:
  194. geely_get_version = true;
  195. geely_count = 10;
  196. memcpy(&geely_data2.engine_ver,&data[0],8);
  197. break;
  198. case 0x1E3:
  199. geely_get_time = true;
  200. //geely_count = 10;
  201. memcpy(&geely_data2.engine_runtime,&data[0],8);
  202. break;
  203. case 0x1E4:
  204. memcpy(&geely_data2.Bit1E4,&data[0],6);
  205. break;
  206. case 0x1E8:
  207. memcpy(&geely_data2.engine_time,&data[0],8);
  208. geely_data2.engine_time = ((data[4] >> 6) & 0x3);
  209. break;
  210. case 0x1E9:
  211. memcpy(&geely_data2.engine_rev,&data[0],8);
  212. break;
  213. case 0x1EA:
  214. memcpy(&geely_data2.Bit1EA,&data[0],8);
  215. break;
  216. case 0x1EB:
  217. memcpy(&geely_data2.FuelConsumption,&data[0],8);
  218. break;
  219. case 0x1EC:
  220. memcpy(&geely_data2.EmgST0,&data[0],2);
  221. break;
  222. case 0x1ED:
  223. memcpy(&geely_data2.AlmST0,&data[0],8);
  224. break;
  225. case 0x1EE:
  226. memcpy(&geely_data2.Gear1Position,&data[0],7);
  227. break;
  228. default:
  229. break;
  230. }
  231. }
  232. geely_engin_link.recv_time = HAL_GetTick();
  233. }
  234. short geely_set_counts = 0;
  235. #pragma pack(1)
  236. typedef struct
  237. {
  238. uint32_t time;
  239. uint8_t nodecode:4;
  240. uint8_t message_conut0:4;
  241. int8_t check_sum0;
  242. uint8_t client_cmd;
  243. uint8_t syscontrol;
  244. uint8_t reserve0;
  245. uint8_t reserve1;
  246. uint32_t reserve2:20;
  247. uint8_t message_conut1:4;
  248. int8_t check_sum1;
  249. }geely_info2;
  250. geely_info2 geely_sendinfo2;
  251. #pragma pack()
  252. uint8_t geely_count = 15;
  253. uint8_t start_engine = 0; // 0x80启动 0停止
  254. void Geely_version2_init(void)
  255. {
  256. uint8_t can_buf[8] = {0};
  257. static uint8_t geely_init_count = 15;
  258. if(geely_data2.version2_flag != true && geely_init_count > 1)
  259. {
  260. geely_sendinfo2.client_cmd = 0x10;
  261. geely_sendinfo2.syscontrol = 0;
  262. geely_sendinfo2.check_sum1 = geely_sendinfo2.client_cmd + geely_sendinfo2.syscontrol + (geely_sendinfo2.message_conut1 << 4);
  263. memcpy(&can_buf[0],&geely_sendinfo2.client_cmd,8);
  264. geely_sendinfo2.message_conut1++;
  265. can_send_msg_normalstd(&can_buf[0],8,0x1E0);
  266. geely_init_count--;
  267. }
  268. }
  269. void Geely_version2_send_info( void )
  270. {
  271. uint8_t can_buf[8] = {0};
  272. //发送北京时间
  273. // if(geely_send_BJtime == false && (beijing_time.ui8Year != 0)) //上点发送,CANID不在过滤器中 不等反馈
  274. // {
  275. // geely_sendinfo2.time += beijing_time.ui8Second / 2;
  276. // geely_sendinfo2.time += beijing_time.ui8Minute *( 0x1 << 4);
  277. // geely_sendinfo2.time += beijing_time.ui8Hour *( 0x1 << 10);
  278. // geely_sendinfo2.time += beijing_time.ui8DayOfMonth *( 0x1 << 15);
  279. // geely_sendinfo2.time += beijing_time.ui8Month *( 0x1 << 20);
  280. // geely_sendinfo2.time += beijing_time.ui8Year *( 0x1 << 24);
  281. // geely_sendinfo2.nodecode = 0;
  282. // geely_sendinfo2.check_sum0 = geely_sendinfo2.time + geely_sendinfo2.nodecode + (geely_sendinfo2.message_conut0 << 4);
  283. // geely_sendinfo2.check_sum0 = 0 - geely_sendinfo2.check_sum0;
  284. // memcpy(&can_buf[0],&geely_sendinfo2,6);
  285. // geely_sendinfo2.message_conut0++;
  286. // can_send_msg_normalstd(&can_buf[0],6,0x030);
  287. // }
  288. //上电读取信息
  289. if(geely_get_version == false || geely_get_time == false)
  290. {
  291. if(geely_get_version == false)
  292. {
  293. geely_sendinfo2.client_cmd = 0x16;
  294. }
  295. else if(geely_get_time == false)
  296. {
  297. geely_sendinfo2.client_cmd = 0x17;
  298. }
  299. geely_sendinfo2.syscontrol = 0;
  300. geely_sendinfo2.check_sum1 = geely_sendinfo2.client_cmd + geely_sendinfo2.syscontrol + geely_sendinfo2.message_conut1;
  301. geely_sendinfo2.check_sum1 = 0 - geely_sendinfo2.check_sum1;
  302. memcpy(&can_buf[0],&geely_sendinfo2.client_cmd,8);
  303. geely_sendinfo2.message_conut1++;
  304. can_send_msg_normalstd(&can_buf[0],8,0x1E0);
  305. geely_count--;
  306. if(geely_count == 0)
  307. {
  308. geely_count = 10;
  309. if(geely_get_version == false)
  310. {
  311. geely_get_version = true;
  312. }
  313. else if(geely_get_time == false)
  314. {
  315. geely_get_time = true;
  316. }
  317. }
  318. }
  319. //控制发动机启停
  320. else
  321. {
  322. geely_sendinfo2.client_cmd = 0x12;
  323. geely_sendinfo2.syscontrol = start_engine;
  324. geely_sendinfo2.check_sum1 = geely_sendinfo2.client_cmd + geely_sendinfo2.syscontrol + (geely_sendinfo2.message_conut1 << 4) ;
  325. geely_sendinfo2.check_sum1 = 0 - geely_sendinfo2.check_sum1;
  326. memcpy(&can_buf[0],&geely_sendinfo2.client_cmd,8);
  327. geely_sendinfo2.message_conut1++;
  328. can_send_msg_normalstd(&can_buf[0],8,0x1E0);
  329. }
  330. // else
  331. // {
  332. // geely_sendinfo2.client_cmd = 0x11;
  333. // geely_sendinfo2.syscontrol = 0;
  334. // geely_sendinfo2.check_sum1 = geely_sendinfo2.client_cmd + geely_sendinfo2.syscontrol + (geely_sendinfo2.message_conut1 << 4);
  335. // geely_sendinfo2.check_sum1 = 0 - geely_sendinfo2.check_sum1;
  336. // memcpy(&can_buf[0],&geely_sendinfo2.client_cmd,8);
  337. // geely_sendinfo2.message_conut1++;
  338. // can_send_msg_normalstd(&can_buf[0],8,0x1E0);
  339. // }
  340. }
  341. #define SENDTO_GEELY_STATUS_ID (0X1A0)
  342. STO_GEELY sendto_geely = {.ExtenderControl = 0,
  343. .ExtenderSetting = 0x10,
  344. .SettingParameter = 0,
  345. .ExtenderBak = 0,
  346. .MessageCount = 0
  347. };
  348. uint32_t sendto_geely_lasttime = 0;
  349. uint8_t vkv3_buf[20] = {0};
  350. void send_msg_to_vk3(void)
  351. {
  352. if(vkv3_engine_link.connect_status == COMP_NORMAL &&
  353. uart_send_is_ok(USART_3) == true)
  354. {
  355. uint16_t crc = 0;
  356. uint8_t index = 0;
  357. vkv3_buf[index++] = 0x5A;
  358. vkv3_buf[index++] = 0xA5;
  359. vkv3_buf[index++] = 4;
  360. vkv3_buf[index++] = 0x0A;
  361. if(start_engine == 0x80)
  362. {
  363. vkv3_buf[index++] = 1;
  364. }
  365. else
  366. {
  367. vkv3_buf[index++] = 0;
  368. }
  369. vkv3_buf[index++] = planep.lock_status;
  370. vkv3_buf[index++] = planep.thr_pwm;
  371. vkv3_buf[index++] = planep.thr_pwm >> 8;
  372. crc = Get_Crc16(vkv3_buf, index);
  373. memcpy(&vkv3_buf[index], &crc, 2);
  374. index +=2;
  375. uart3_send_msg(vkv3_buf,index);
  376. }
  377. }
  378. void send_msg_to_geely(void)
  379. {
  380. if (geely_engin_link.connect_status == COMP_NORMAL && HAL_GetTick() - sendto_geely_lasttime > 100)
  381. {
  382. uint8_t geely[8] = {0};
  383. sendto_geely_lasttime = HAL_GetTick();
  384. Geely_version2_init();
  385. if(geely_data2.version2_flag == true)
  386. {
  387. Geely_version2_send_info();
  388. }
  389. else
  390. {
  391. sendto_geely.ExtenderBak = planep.thr_pwm;
  392. sendto_geely.DroneStatus = (planep.lock_status == 4? 1: 0); //(thr_lock_status == LOCKED ? 0 : 1);
  393. sendto_geely.MessageCount++;
  394. if(geely_set_tcd == true)
  395. {
  396. geely_set_counts++;
  397. if(geely_set_counts > 5){
  398. geely_set_tcd = false;
  399. geely_set_counts = 0;
  400. }
  401. sendto_geely.ExtenderSetting = 0x11;
  402. //sendto_geely.SettingParameter = 0;
  403. }
  404. else if(geely_set_tcd_re == true)
  405. {
  406. geely_set_counts++;
  407. if(geely_set_counts > 5){
  408. geely_set_tcd_re = false;
  409. geely_set_counts = 0;
  410. }
  411. sendto_geely.ExtenderSetting = 0x12;
  412. sendto_geely.SettingParameter = 0;
  413. }
  414. else if(geely_set_tlock == true)
  415. {
  416. geely_set_counts++;
  417. if(geely_set_counts > 5){
  418. geely_set_tlock = false;
  419. geely_set_counts = 0;
  420. }
  421. sendto_geely.ExtenderSetting = 0x14;
  422. //sendto_geely.SettingParameter = 0;
  423. }
  424. else if(geely_set_tlock_re == true)
  425. {
  426. geely_set_counts++;
  427. if(geely_set_counts > 5){
  428. geely_set_tlock_re = false;
  429. geely_set_counts = 0;
  430. }
  431. sendto_geely.ExtenderSetting = 0x15;
  432. sendto_geely.SettingParameter = 0;
  433. }
  434. else if(geely_set_protect == true)
  435. {
  436. geely_set_counts++;
  437. if(geely_set_counts > 5){
  438. geely_set_protect = false;
  439. geely_set_counts = 0;
  440. }
  441. sendto_geely.ExtenderSetting = 0x17;
  442. sendto_geely.SettingParameter = 0;
  443. }
  444. else
  445. {
  446. sendto_geely.ExtenderSetting = 0x10;
  447. sendto_geely.SettingParameter = 0;
  448. geely_set_counts = 0;
  449. }
  450. memcpy(geely, (uint8_t *)&sendto_geely.ExtenderControl, 7);
  451. sendto_geely.CheckSum = 0;
  452. for (uint8_t i = 0; i < 7; i++)
  453. {
  454. sendto_geely.CheckSum += geely[i];
  455. }
  456. sendto_geely.CheckSum = -sendto_geely.CheckSum;
  457. can_send_msg_normalstd(&sendto_geely.ExtenderControl, sizeof(sendto_geely), SENDTO_GEELY_STATUS_ID);
  458. geely_moni.send_1a0++;
  459. }
  460. }
  461. }
  462. comp_status engine_link_status = COMP_NOEXIST;
  463. struct ENGINE_DATA engine_data = {0, 0};
  464. /*
  465. 发动机类型 uint8 1-瑞深 2-中飞
  466. 发动机转速 uint16_t RPM
  467. 发动机油门 uint16_t
  468. 发动机电压 uint16_t 0.1v
  469. 充电电流 uint16_t 0.1A
  470. 发动机运行时间 uint32_t Min 总运行时间不清零
  471. 剩余保养时间 uint16_t Min 保养后清零
  472. 剩余锁机时间 uint16_t Min 锁机倒计时
  473. 运行状态 uint8_t 0:停止,1:等待,2:运行, 3:锁机
  474. 报警信息 uint16_t 按位来表示可同时容纳16种警报
  475. 剩余油量 uint8_t % 0%-100%
  476. 气缸1温度 uint16_t ℃ 0℃~300℃
  477. 气缸2温度 uint16_t ℃ 0℃~300℃
  478. PCB温度 uint8_t ℃ 0℃~255℃
  479. */
  480. /*
  481. 检查智能电池的连接及数据获取,主要解决兼容多厂家设备接入时的选用优先级问题。
  482. 更新速度至少要 5hz
  483. 缺少放电电流数据
  484. */
  485. void update_engine_data(void)
  486. {
  487. //监测中飞发动机
  488. Check_dev_link(&aoan_engine_Link,5000,(char *)&aoan_data,sizeof(AOAN_TYPE));
  489. //监测VKV3的发动机
  490. Check_dev_link(&vkv3_engine_link,5000,(char *)&vkv3_data,sizeof(VKV3_TYPE));
  491. //监测VKV3 2的发动机
  492. //Check_dev_link(&vkv3_engine2_link,5000,(char *)&vkv3_data,sizeof(VKV3_TYPE));
  493. //检测GEELY发动机
  494. Check_dev_link(&geely_engin_link,5000,(char *)&geely_data,sizeof(GEELY));
  495. if (aoan_engine_Link.connect_status == COMP_NORMAL)
  496. {
  497. engine_link_status = COMP_NORMAL;
  498. //数字显示,显示9位数
  499. engine_data.engine_type = 2;
  500. engine_data.engine_rev = aoan_data.engin_rev;
  501. engine_data.engine_thr = aoan_data.engin_thr;
  502. engine_data.engine_vol = aoan_data.engin_vol;
  503. engine_data.engine_elect = aoan_data.engin_elect;
  504. engine_data.engine_rtime = aoan_data.engin_rtime;
  505. engine_data.engine_tcd = aoan_data.engin_tcd;
  506. engine_data.engine_lcd = aoan_data.engin_lcd;
  507. engine_data.engine_rsta = aoan_data.engin_rsta;
  508. engine_data.engine_warn = aoan_data.engin_warn;
  509. engine_data.engine_roil = aoan_data.engin_roil;
  510. engine_data.engine_cyl1temp = aoan_data.engin_cyl1temp;
  511. engine_data.engine_cyl2temp = aoan_data.engin_cyl2temp;
  512. engine_data.engine_pcbtemp = aoan_data.engin_pcbtemp;
  513. memcpy(engine_data.engine_brand, "AOAN", 4);
  514. }
  515. else if (vkv3_engine_link.connect_status == COMP_NORMAL)
  516. {
  517. engine_link_status = COMP_NORMAL;
  518. //数字显示,显示9位数
  519. engine_data.engine_type = 3;
  520. engine_data.engine_rev = vkv3_data.engin_rev;
  521. engine_data.engine_thr = vkv3_data.engin_thr;
  522. engine_data.engine_vol = vkv3_data.engin_vol;
  523. engine_data.engine_elect = vkv3_data.engin_elect;
  524. engine_data.engine_rtime = vkv3_data.engin_rtime;
  525. engine_data.engine_tcd = vkv3_data.engin_tcd;
  526. engine_data.engine_lcd = vkv3_data.engin_lcd;
  527. engine_data.engine_rsta = vkv3_data.engin_rsta;
  528. engine_data.engine_warn = vkv3_data.engin_warn;
  529. engine_data.engine_roil = vkv3_data.engin_roil;
  530. engine_data.engine_cyl1temp = vkv3_data.engin_cyl1temp;
  531. engine_data.engine_cyl2temp = vkv3_data.engin_cyl2temp;
  532. engine_data.engine_pcbtemp = vkv3_data.engin_pcbtemp;
  533. engine_data.engine_sn = vkv3_data.engin_sn;
  534. memcpy(engine_data.engine_brand, vkv3_data.engin_brand, 8);
  535. // if(vkv3_engine2_link.connect_status == COMP_NORMAL)
  536. // {
  537. // }
  538. }
  539. else if (geely_engin_link.connect_status == COMP_NORMAL)
  540. {
  541. engine_link_status = COMP_NORMAL;
  542. engine_data.engine_type = 4;
  543. //数字显示,显示9位数
  544. if(geely_data2.version2_flag != true)
  545. {
  546. engine_data.engine_rev = geely_data.engine_rev;
  547. engine_data.engine_thr = geely_data.engine_thrposition * 0.1f;
  548. engine_data.engine_vol = geely_data.engine_vol * 2;
  549. engine_data.engine_elect = (short)(geely_data.engine_elect - 1000) * 2;
  550. engine_data.engine_rtime = geely_data.engine_runtime;
  551. engine_data.engine_tcd = geely_data.engine_tcd;
  552. engine_data.engine_lcd = geely_data.engine_tlock;
  553. engine_data.engine_rsta = geely_data.engine_status;
  554. engine_data.engine_warn = geely_data.engine_warn & 0xffef;//屏蔽总线系统异常
  555. engine_data.engine_roil = geely_data.engine_fuelposition * 0.5f;
  556. engine_data.engine_cyl1temp = geely_data.engine_cyltemp - 40;
  557. engine_data.engine_cyl2temp = 0;
  558. engine_data.engine_pcbtemp = geely_data.engine_cooltemp - 40;
  559. memcpy(engine_data.engine_brand, geely_data.engine_brand, 3);
  560. memcpy(&engine_data.engine_brand[3],"-", 1);
  561. snprintf((char *)&engine_data.engine_brand[4],4,"%d",(int)geely_data.engine_ver);
  562. engine_data.engine_sn = geely_data.engine_sn[0] * 10000000 + geely_data.engine_sn[1] * 100000 +
  563. geely_data.engine_sn[2] * 1000 + geely_data.engine_sn[3];
  564. engine_data.engine_lockstatus = geely_data.engine_control;
  565. engine_data.engine_fault = geely_data.engine_fault;
  566. }
  567. else
  568. {
  569. engine_data.engine_type = 4;
  570. engine_data.engine_rev = geely_data2.engine_rev;
  571. engine_data.engine_thr = geely_data2.Bit1EA.engine_ATP1 * 0.05f;
  572. engine_data.engine_vol = geely_data2.engine_vol * 0.1f;
  573. engine_data.engine_elect = (short)(geely_data2.engine_elect * 0.05f - 400) * 10;
  574. engine_data.engine_rtime = geely_data2.engine_runtime;
  575. engine_data.engine_tcd = geely_data2.engine_tcd;
  576. engine_data.engine_lcd = geely_data2.engine_tlock;
  577. engine_data.engine_rsta = geely_data2.engine_state;
  578. engine_data.engine_warn = geely_data2.EmgST0;
  579. engine_data.engine_roil = geely_data2.GPS * 0.5f;
  580. engine_data.engine_cyl1temp = geely_data2.engine_cooltemp - 40;
  581. engine_data.engine_cyl2temp = geely_data2. engine_cooltemp1 - 40;
  582. engine_data.engine_pcbtemp = geely_data2.engine_GWT - 40;
  583. memcpy(engine_data.engine_brand, geely_data2.engine_brand, 3);
  584. memcpy(&engine_data.engine_brand[3],"-", 1);
  585. snprintf((char *)&engine_data.engine_brand[4],4,"%d",(int)geely_data2.engine_ver);
  586. engine_data.engine_sn = geely_data2.engine_sn[0] * 10000000 + geely_data2.engine_sn[1] * 100000 +
  587. geely_data2.engine_sn[2] * 1000 + geely_data2.engine_sn[3];
  588. //engine_data.engine_lockstatus = geely_data2.engine_state == 0? 0 : 1;
  589. engine_data.engine_lockstatus = geely_data2.engine_controlcmd;
  590. //engine_data.engine_fault = geely_data2.engine_fault;
  591. }
  592. }
  593. else
  594. {
  595. if (engine_link_status == COMP_NORMAL)
  596. {
  597. engine_link_status = COMP_LOST;
  598. memset(&engine_data, 0, sizeof(engine_data));
  599. //状态未置异常
  600. engine_data.engine_type = 0xFF;
  601. }
  602. }
  603. }
  604. /******************void engine_function(void)********************
  605. * ****************发动机检测函数*********************************
  606. * **************************************************************/
  607. void engine_function(void)
  608. {
  609. static uint32_t engine_time = 0;
  610. if(Check_Timer_Ready(&engine_time,_10_HZ_))
  611. {
  612. update_engine_data();
  613. //发送飞控状态给发动机
  614. send_msg_to_vk3();
  615. }
  616. //给吉利发动机发送信息
  617. send_msg_to_geely();
  618. }