AppFunc.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725
  1. /*
  2. * @Author : ChenJie
  3. * @Date : 2021-12-15 10:40:06
  4. * @Version : V3.0
  5. * @LastEditors : ChenJie
  6. * @LastEditTime : 2022-01-11 18:14:41
  7. * @Description : AppFunc
  8. * @FilePath : \VehicleControl\VehicleControl\src\System\Vehicle\AppFunc.c
  9. */
  10. #include "string.h"
  11. #include "stdlib.h"
  12. #include "HardwareLib.h"
  13. #include "CanVar.h"
  14. #include "math.h"
  15. #include "AppFunc.h"
  16. #include "Std_Types.h"
  17. /**
  18. * @brief : 互锁检测函数
  19. * @param {*}
  20. * @return {*}
  21. */
  22. void GetHVLockState(void)
  23. {
  24. UINT8 m_flg_HVlock1 = 0, m_flg_HVlock2 = 0;
  25. // PWM输出,互锁1检测,频率100HZ,占空比30%
  26. uint16 VehCo_fTestUI = 1000;
  27. uint16 VehCo_rTestUW = 3000;
  28. uint32 PwmFreAcq = 0;
  29. uint16 PwmDutyAcq = 0;
  30. PPWMDrv_Interface(_PPWM_INDEX_HVLOCK2, VehCo_fTestUI, VehCo_rTestUW);
  31. PulseAcqDrv_GetChanFreq(_PULSEACQ_INDEX_HVLOCK2, &PwmFreAcq, &PwmDutyAcq);
  32. if (abs(PwmFreAcq - VehCo_fTestUI) < 100 && abs(PwmDutyAcq - VehCo_rTestUW) < 500)
  33. {
  34. m_flg_HVlock1 = 1;
  35. }
  36. else
  37. {
  38. m_flg_HVlock1 = 0;
  39. }
  40. //互锁2检测,配置高有效,悬空为0则未接入,高电平为1则接入,
  41. // DINDrv_SetChanThres(_DIN_INDEX_PLUGHVLOCK, 0, 4095 * 3);
  42. m_flg_HVlock2 = DINDrv_GetChanState(_DIN_INDEX_PLUGHVLOCK);
  43. }
  44. /**
  45. * @brief : 数字量传感器信号检测函数
  46. * @param {*}
  47. * @return {*}
  48. */
  49. void GetDIOState(void)
  50. {
  51. uint8 temp[4];
  52. //松开传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  53. memset(temp, 0x00, 4);
  54. ebcd_st_unlockSensor = 0;
  55. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR1, 1, 4095U);
  56. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR2, 1, 4095U);
  57. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR3, 1, 4095U);
  58. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR4, 1, 4095U);
  59. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR1);
  60. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR2);
  61. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR3);
  62. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR4);
  63. ebcd_st_unlockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  64. //夹紧传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  65. memset(temp, 0x00, 4);
  66. ebcd_st_lockSensor = 0;
  67. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR1, 1, 4095U);
  68. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR2, 1, 4095U);
  69. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR3, 1, 4095U);
  70. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR4, 1, 4095U);
  71. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR1);
  72. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR2);
  73. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR3);
  74. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR4);
  75. ebcd_st_lockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  76. //落座传感器检测,高有效,悬空为0则未接入,高电平为1则接入
  77. memset(temp, 0x00, 4);
  78. // DINDrv_SetChanThres(_DIN_INDEX_READYSENSOR1, 0, 4095 * 3);
  79. // DINDrv_SetChanThres(_DIN_INDEX_READYSENSOR2, 0, 4095 * 3);
  80. temp[0] = DINDrv_GetChanState(_DIN_INDEX_READYSENSOR1);
  81. temp[1] = DINDrv_GetChanState(_DIN_INDEX_READYSENSOR2);
  82. ebcd_st_pedstSensor = (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  83. }
  84. /**
  85. * @brief : 获取模拟量输入值,并进行转换
  86. * @param {*}
  87. * @return {*}
  88. */
  89. void GetAIOValue(void)
  90. {
  91. uint16 AirPressureTemp_Vol = 0;
  92. uint16 PluginTemp1_Vol = 0;
  93. uint32 PluginTemp1_R = 0;
  94. uint16 PluginTemp2_Vol = 0;
  95. uint32 PluginTemp2_R = 0;
  96. uint16 PluginTemp3_Vol = 0;
  97. uint32 PluginTemp3_R = 0;
  98. uint16 PluginTemp4_Vol = 0;
  99. uint32 PluginTemp4_R = 0;
  100. AirPressureTemp_Vol = ATDDrv_GetChanResult(_ATD_INDEX_AIRPRESSURE);
  101. /*气压数据转换*/
  102. ebcd_P_airSensor = (uint16)(AirPressureTemp_Vol * 1000 / 4095.0);
  103. /*温度采集获取*/
  104. PluginTemp1_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP1);
  105. PluginTemp2_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP2);
  106. PluginTemp3_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP3);
  107. PluginTemp4_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP4);
  108. PluginTemp1_R = (uint32)((PluginTemp1_Vol / (5.0 * 4095 - PluginTemp1_Vol)) * 1000.0);
  109. PluginTemp2_R = (uint32)((PluginTemp2_Vol / (5.0 * 4095 - PluginTemp2_Vol)) * 1000.0);
  110. PluginTemp3_R = (uint32)((PluginTemp3_Vol / (5.0 * 4095 - PluginTemp3_Vol)) * 1000.0);
  111. PluginTemp4_R = (uint32)((PluginTemp4_Vol / (5.0 * 4095 - PluginTemp4_Vol)) * 1000.0);
  112. ebcd_T_plugin[0] = (uint8)Look1_u32u16(PluginTemp1_R, R_table, T_table, 240);
  113. ebcd_T_plugin[1] = (uint8)Look1_u32u16(PluginTemp2_R, R_table, T_table, 240);
  114. ebcd_T_plugin[2] = (uint8)Look1_u32u16(PluginTemp3_R, R_table, T_table, 240);
  115. ebcd_T_plugin[3] = (uint8)Look1_u32u16(PluginTemp4_R, R_table, T_table, 240);
  116. }
  117. /**
  118. * @brief : lookUp Table Fun
  119. * @param {uint32} u0 x
  120. * @param {uint32} bp0 x_table
  121. * @param {uint16} table y_table
  122. * @param {uint16} maxIndex
  123. * @return {*}
  124. */
  125. uint16 Look1_u32u16(uint32 u0, uint32 *bp0, uint16 *table, uint16 MaxLen)
  126. {
  127. uint32 bpIdx = 0;
  128. uint32 iLeft = 0;
  129. uint32 iRght = 0;
  130. uint16 y = 0;
  131. uint32 yL_0d0 = 0;
  132. uint32 yR_0d0 = 0;
  133. uint32 maxIndex = MaxLen - 1;
  134. if (u0 <= bp0[0U])
  135. {
  136. iLeft = 0U;
  137. iRght = 0U;
  138. }
  139. else if (u0 < bp0[maxIndex])
  140. {
  141. //对折法寻找u0的位置
  142. bpIdx = maxIndex >> 1U;
  143. iLeft = 0U;
  144. iRght = maxIndex;
  145. while ((iRght - iLeft) > 1)
  146. {
  147. if (u0 < bp0[bpIdx])
  148. {
  149. iRght = bpIdx;
  150. }
  151. else
  152. {
  153. iLeft = bpIdx;
  154. }
  155. bpIdx = (iRght + iLeft) >> 1U;
  156. }
  157. }
  158. else
  159. {
  160. iLeft = maxIndex;
  161. iRght = maxIndex;
  162. }
  163. //找到位置以后计算插值
  164. if (iLeft != iRght)
  165. {
  166. //线性插值
  167. yR_0d0 = table[iLeft + 1U];
  168. yL_0d0 = table[iLeft];
  169. if (yR_0d0 >= yL_0d0)
  170. {
  171. y = (uint16)(((uint32)(u0 - bp0[iLeft]) * (yR_0d0 - yL_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]) + yL_0d0);
  172. }
  173. else
  174. {
  175. y = (uint16)(yL_0d0 - ((uint32)(u0 - bp0[iLeft]) * (yL_0d0 - yR_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]));
  176. }
  177. }
  178. else
  179. {
  180. y = (uint16)table[iLeft];
  181. }
  182. return y;
  183. }
  184. #ifdef _APP_TEST_CODE
  185. void TestDeviceFun(void)
  186. {
  187. uint8 ManuEnable = 0;
  188. //控制算法
  189. AccPedCD_Update();
  190. AccPedCD_Monitor();
  191. PulseAcqDrv_GetChanFreq(_PULSEACQ_INDEX_CP_CHAN, &VehCo_fInputUIA[0], &VehCo_rInputUWA[0]);
  192. // DODrv_SetChanState(_DO_INDEX_CPCTL_CHAN,(uint8)VehCo_bTestCPCtrlUW_C);
  193. uint16 DistenceBufferV[2] = {0, 0}, DistenceBufferR[2] = {0, 0};
  194. //开关1采集
  195. DINDrv_SetChanThres(_DIN_INDEX_BAK1_CHAN, 1, 4095U);
  196. Switch1 = !DINDrv_GetChanState(_DIN_INDEX_BAK1_CHAN);
  197. //手动控制采集
  198. DINDrv_SetChanThres(_DIN_INDEX_BAK2_CHAN, 1, 4095U);
  199. ManuEnable = !DINDrv_GetChanState(_DIN_INDEX_BAK2_CHAN);
  200. //位移量采集
  201. DistenceBufferV[0] = ATDDrv_GetChanResult(_ATD_INDEX_BAK3_CHAN);
  202. DistenceBufferR[0] = (uint16)((DistenceBufferV[0] / (5.0 * 4095 - DistenceBufferV[0])) * 1000.0);
  203. Distence1 = (uint16)((2132 - DistenceBufferR[0]) * (0.1219));
  204. //压力采集
  205. PressureValueBuffer = ATDDrv_GetChanResult(_ATD_INDEX_ACCPED1_CHAN);
  206. PressureValue = (uint32)(PressureValueBuffer * 1000 / 4095.0);
  207. //控制输出
  208. VehCo_ctEEPTestUI += 10;
  209. VehCo_ctEEPTestUB += 10;
  210. if (VehCo_ctEEPTestUI >= 4 * 1000)
  211. {
  212. PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, 1); //输出 解锁持续9-4s
  213. ControlState = 1; //解锁
  214. }
  215. else
  216. {
  217. PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, 0); //不输出
  218. ControlState = 2; //锁定 4 秒
  219. }
  220. if (VehCo_ctEEPTestUI >= 9 * 1000)
  221. {
  222. Control_Times++;
  223. VehCo_ctEEPTestUI = 0;
  224. }
  225. if (ManuEnable == 0)
  226. {
  227. Control_Times = 0;
  228. VehCo_ctEEPTestUI = 0;
  229. }
  230. }
  231. #endif
  232. #ifdef _APP_TEST_MOTOR_CODE
  233. void MotorTestFun(void)
  234. {
  235. static uint32 MotorRunTimer = 0;
  236. static uint16 MotorLockReadyTimer = 0;
  237. static sint8 LockMotorNum = -1;
  238. static sint8 unLockMotorNum = -1;
  239. static uint32 testTimer = 0;
  240. GetDIOState();
  241. GetAIOValue();
  242. testTimer = testTimer + 10;
  243. MotorControlLockNum = LockMotorNum;
  244. MotorControlunLockNum = unLockMotorNum;
  245. if (MotorControlCmd == 0) //可进入调试模式
  246. {
  247. if (MotorDebugCmd == 1)
  248. {
  249. if (getbit(MotorControlEnable, 0) == 1)
  250. {
  251. MotorControlFunc(0, 1);
  252. return;
  253. }
  254. else if (getbit(MotorControlEnable, 1) == 1)
  255. {
  256. MotorControlFunc(1, 1);
  257. return;
  258. }
  259. else if (getbit(MotorControlEnable, 2) == 1)
  260. {
  261. MotorControlFunc(2, 1);
  262. return;
  263. }
  264. else if (getbit(MotorControlEnable, 3) == 1)
  265. {
  266. MotorControlFunc(3, 1);
  267. return;
  268. }
  269. else
  270. {
  271. return;
  272. }
  273. }
  274. else if (MotorDebugCmd == 2)
  275. {
  276. if (getbit(MotorControlEnable, 0) == 1)
  277. {
  278. MotorControlFunc(0, 2);
  279. return;
  280. }
  281. else if (getbit(MotorControlEnable, 1) == 1)
  282. {
  283. MotorControlFunc(1, 2);
  284. return;
  285. }
  286. else if (getbit(MotorControlEnable, 2) == 1)
  287. {
  288. MotorControlFunc(2, 2);
  289. return;
  290. }
  291. else if (getbit(MotorControlEnable, 3) == 1)
  292. {
  293. MotorControlFunc(3, 2);
  294. return;
  295. }
  296. else
  297. {
  298. return;
  299. }
  300. }
  301. else
  302. {
  303. if(MotorLifeTestCmd==1)
  304. {
  305. if(LockMotorNum<4 && testTimer>5000)
  306. {
  307. MotorControlCmd = 1;
  308. }
  309. else if( unLockMotorNum<5&&LockMotorNum==4 && testTimer>5000)
  310. {
  311. MotorControlCmd = 2;
  312. }
  313. }
  314. else
  315. {
  316. MotorControlFunc(0, 0xF1);
  317. LockMotorNum = -1;
  318. unLockMotorNum = -1;
  319. return;
  320. }
  321. }
  322. }
  323. else if (MotorControlCmd == 1) //控制锁紧的自动流程
  324. {
  325. switch (LockMotorNum)
  326. {
  327. case -1:
  328. {
  329. MotorControlFunc(0, 0xF1);
  330. LockMotorNum = 0;
  331. break;
  332. }
  333. case 0:
  334. {
  335. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  336. {
  337. MotorControlFunc(LockMotorNum, 0xF1);
  338. LockMotorNum = 1;
  339. MotorRunTimer = 0;
  340. MotorLockReadyTimer = 0;
  341. }
  342. else
  343. {
  344. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  345. {
  346. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  347. }
  348. MotorControlFunc(LockMotorNum, 1);
  349. MotorRunTimer = MotorRunTimer + 10;
  350. }
  351. break;
  352. }
  353. case 1:
  354. {
  355. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  356. {
  357. MotorControlFunc(LockMotorNum, 0xF1);
  358. LockMotorNum = 2;
  359. MotorRunTimer = 0;
  360. MotorLockReadyTimer = 0;
  361. }
  362. else
  363. {
  364. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  365. {
  366. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  367. }
  368. MotorControlFunc(LockMotorNum, 1);
  369. MotorRunTimer = MotorRunTimer + 10;
  370. }
  371. break;
  372. }
  373. case 2:
  374. {
  375. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  376. {
  377. MotorControlFunc(LockMotorNum, 0xF1);
  378. LockMotorNum = 3;
  379. MotorRunTimer = 0;
  380. MotorLockReadyTimer = 0;
  381. }
  382. else
  383. {
  384. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  385. {
  386. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  387. }
  388. MotorControlFunc(LockMotorNum, 1);
  389. MotorRunTimer = MotorRunTimer + 10;
  390. }
  391. break;
  392. }
  393. case 3:
  394. {
  395. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  396. {
  397. MotorControlFunc(LockMotorNum, 0xF1);
  398. LockMotorNum = 4;
  399. unLockMotorNum = -1;
  400. MotorRunTimer = 0;
  401. MotorLockReadyTimer = 0;
  402. testTimer = 0;
  403. }
  404. else
  405. {
  406. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  407. {
  408. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  409. }
  410. MotorControlFunc(LockMotorNum, 1);
  411. MotorRunTimer = MotorRunTimer + 10;
  412. }
  413. break;
  414. }
  415. default:
  416. break;
  417. }
  418. }
  419. else if (MotorControlCmd == 2) //控制解锁的自动流程
  420. {
  421. switch (unLockMotorNum)
  422. {
  423. case -1:
  424. {
  425. MotorControlFunc(0, 0xF2);
  426. unLockMotorNum = 0;
  427. break;
  428. }
  429. case 0:
  430. {
  431. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  432. {
  433. MotorControlFunc(unLockMotorNum, 0xF2);
  434. unLockMotorNum = 1;
  435. MotorRunTimer = 0;
  436. MotorLockReadyTimer = 0;
  437. }
  438. else
  439. {
  440. if (getbit(ebcd_st_unlockSensor, unLockMotorNum) == 1)
  441. {
  442. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  443. }
  444. MotorControlFunc(unLockMotorNum, 2);
  445. MotorRunTimer = MotorRunTimer + 10;
  446. }
  447. break;
  448. }
  449. case 1:
  450. {
  451. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  452. {
  453. MotorControlFunc(unLockMotorNum, 0xF2);
  454. unLockMotorNum = 2;
  455. MotorRunTimer = 0;
  456. MotorLockReadyTimer = 0;
  457. }
  458. else
  459. {
  460. if (getbit(ebcd_st_unlockSensor, unLockMotorNum) == 1)
  461. {
  462. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  463. }
  464. MotorControlFunc(unLockMotorNum, 2);
  465. MotorRunTimer = MotorRunTimer + 10;
  466. }
  467. break;
  468. }
  469. case 2:
  470. {
  471. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  472. {
  473. MotorControlFunc(unLockMotorNum, 0xF2);
  474. unLockMotorNum = 3;
  475. MotorRunTimer = 0;
  476. MotorLockReadyTimer = 0;
  477. }
  478. else
  479. {
  480. if (getbit(ebcd_st_unlockSensor, unLockMotorNum) == 1)
  481. {
  482. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  483. }
  484. MotorControlFunc(unLockMotorNum, 2);
  485. MotorRunTimer = MotorRunTimer + 10;
  486. }
  487. break;
  488. }
  489. case 3:
  490. {
  491. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  492. {
  493. MotorControlFunc(unLockMotorNum, 0xF2);
  494. unLockMotorNum = 4;
  495. MotorRunTimer = 0;
  496. MotorLockReadyTimer = 0;
  497. }
  498. else
  499. {
  500. if (getbit(ebcd_st_unlockSensor, unLockMotorNum) == 1)
  501. {
  502. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  503. }
  504. MotorControlFunc(unLockMotorNum, 2);
  505. MotorRunTimer = MotorRunTimer + 10;
  506. }
  507. break;
  508. }
  509. case 4:
  510. {
  511. MotorControlFunc(0, 0xF1);
  512. unLockMotorNum = 5;
  513. LockMotorNum = -1;
  514. if(MotorLifeTestCmd==1)
  515. {
  516. LifeTestCounter++;
  517. testTimer = 0;
  518. EEPROMDrv_bSaveInstantUB = 1;
  519. }
  520. break;
  521. }
  522. default:
  523. break;
  524. }
  525. }
  526. }
  527. void MotorControlFunc(UINT8 MotorIdx, UINT8 RotateDirec) // MotorIdx 0-3 表示四个电机,RotateDirec F1停止正转,F2表示反转停止,1表示正转,2表示反转
  528. {
  529. switch (MotorIdx)
  530. {
  531. case 0:
  532. {
  533. switch (RotateDirec)
  534. {
  535. case 0xF1:
  536. {
  537. PSwtDrv_Interface(_M1_C, 0);
  538. PSwtDrv_Interface(_M2_C, 0);
  539. PSwtDrv_Interface(_M3_C, 0);
  540. PSwtDrv_Interface(_M4_C, 0);
  541. PSwtDrv_Interface(_M_D_C, 0);
  542. break;
  543. }
  544. case 0xF2:
  545. {
  546. PSwtDrv_Interface(_M1_C, 1);
  547. PSwtDrv_Interface(_M2_C, 1);
  548. PSwtDrv_Interface(_M3_C, 1);
  549. PSwtDrv_Interface(_M4_C, 1);
  550. PSwtDrv_Interface(_M_D_C, 1);
  551. break;
  552. }
  553. case 1:
  554. {
  555. PSwtDrv_Interface(_M1_C, 0);
  556. PSwtDrv_Interface(_M_D_C, 0);
  557. PSwtDrv_Interface(_M1_C, 1);
  558. break;
  559. }
  560. case 2:
  561. {
  562. PSwtDrv_Interface(_M1_C, 1);
  563. PSwtDrv_Interface(_M_D_C, 1);
  564. PSwtDrv_Interface(_M1_C, 0);
  565. break;
  566. }
  567. default:
  568. break;
  569. }
  570. break;
  571. }
  572. case 1:
  573. {
  574. switch (RotateDirec)
  575. {
  576. case 0xF1:
  577. {
  578. PSwtDrv_Interface(_M1_C, 0);
  579. PSwtDrv_Interface(_M2_C, 0);
  580. PSwtDrv_Interface(_M3_C, 0);
  581. PSwtDrv_Interface(_M4_C, 0);
  582. PSwtDrv_Interface(_M_D_C, 0);
  583. break;
  584. }
  585. case 0xF2:
  586. {
  587. PSwtDrv_Interface(_M1_C, 1);
  588. PSwtDrv_Interface(_M2_C, 1);
  589. PSwtDrv_Interface(_M3_C, 1);
  590. PSwtDrv_Interface(_M4_C, 1);
  591. PSwtDrv_Interface(_M_D_C, 1);
  592. break;
  593. }
  594. case 0:
  595. {
  596. PSwtDrv_Interface(_M2_C, 0);
  597. PSwtDrv_Interface(_M_D_C, 0);
  598. break;
  599. }
  600. case 1:
  601. {
  602. PSwtDrv_Interface(_M2_C, 0);
  603. PSwtDrv_Interface(_M_D_C, 0);
  604. PSwtDrv_Interface(_M2_C, 1);
  605. break;
  606. }
  607. case 2:
  608. {
  609. PSwtDrv_Interface(_M2_C, 1);
  610. PSwtDrv_Interface(_M_D_C, 1);
  611. PSwtDrv_Interface(_M2_C, 0);
  612. break;
  613. }
  614. default:
  615. break;
  616. }
  617. break;
  618. }
  619. case 2:
  620. {
  621. switch (RotateDirec)
  622. {
  623. case 0xF1:
  624. {
  625. PSwtDrv_Interface(_M1_C, 0);
  626. PSwtDrv_Interface(_M2_C, 0);
  627. PSwtDrv_Interface(_M3_C, 0);
  628. PSwtDrv_Interface(_M4_C, 0);
  629. PSwtDrv_Interface(_M_D_C, 0);
  630. break;
  631. }
  632. case 0xF2:
  633. {
  634. PSwtDrv_Interface(_M1_C, 1);
  635. PSwtDrv_Interface(_M2_C, 1);
  636. PSwtDrv_Interface(_M3_C, 1);
  637. PSwtDrv_Interface(_M4_C, 1);
  638. PSwtDrv_Interface(_M_D_C, 1);
  639. break;
  640. }
  641. case 0:
  642. {
  643. PSwtDrv_Interface(_M3_C, 0);
  644. PSwtDrv_Interface(_M_D_C, 0);
  645. break;
  646. }
  647. case 1:
  648. {
  649. PSwtDrv_Interface(_M3_C, 0);
  650. PSwtDrv_Interface(_M_D_C, 0);
  651. PSwtDrv_Interface(_M3_C, 1);
  652. break;
  653. }
  654. case 2:
  655. {
  656. PSwtDrv_Interface(_M3_C, 1);
  657. PSwtDrv_Interface(_M_D_C, 1);
  658. PSwtDrv_Interface(_M3_C, 0);
  659. break;
  660. }
  661. default:
  662. break;
  663. }
  664. break;
  665. }
  666. case 3:
  667. {
  668. switch (RotateDirec)
  669. {
  670. case 0xF1:
  671. {
  672. PSwtDrv_Interface(_M1_C, 0);
  673. PSwtDrv_Interface(_M2_C, 0);
  674. PSwtDrv_Interface(_M3_C, 0);
  675. PSwtDrv_Interface(_M4_C, 0);
  676. PSwtDrv_Interface(_M_D_C, 0);
  677. break;
  678. }
  679. case 0xF2:
  680. {
  681. PSwtDrv_Interface(_M1_C, 1);
  682. PSwtDrv_Interface(_M2_C, 1);
  683. PSwtDrv_Interface(_M3_C, 1);
  684. PSwtDrv_Interface(_M4_C, 1);
  685. PSwtDrv_Interface(_M_D_C, 1);
  686. break;
  687. }
  688. case 0:
  689. {
  690. PSwtDrv_Interface(_M4_C, 0);
  691. PSwtDrv_Interface(_M_D_C, 0);
  692. break;
  693. }
  694. case 1:
  695. {
  696. PSwtDrv_Interface(_M4_C, 0);
  697. PSwtDrv_Interface(_M_D_C, 0);
  698. PSwtDrv_Interface(_M4_C, 1);
  699. break;
  700. }
  701. case 2:
  702. {
  703. PSwtDrv_Interface(_M4_C, 1);
  704. PSwtDrv_Interface(_M_D_C, 1);
  705. PSwtDrv_Interface(_M4_C, 0);
  706. break;
  707. }
  708. default:
  709. break;
  710. }
  711. break;
  712. }
  713. default:
  714. break;
  715. }
  716. }
  717. #endif