AppFunc.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699
  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. GetDIOState();
  240. if (MotorControlCmd == 0) //可进入调试模式
  241. {
  242. if (MotorDebugCmd == 1)
  243. {
  244. if (getbit(MotorControlEnable, 0) == 1)
  245. {
  246. MotorControlFunc(0, 1);
  247. return;
  248. }
  249. else if (getbit(MotorControlEnable, 1) == 1)
  250. {
  251. MotorControlFunc(1, 1);
  252. return;
  253. }
  254. else if (getbit(MotorControlEnable, 2) == 1)
  255. {
  256. MotorControlFunc(2, 1);
  257. return;
  258. }
  259. else if (getbit(MotorControlEnable, 3) == 1)
  260. {
  261. MotorControlFunc(3, 1);
  262. return;
  263. }
  264. else
  265. {
  266. return;
  267. }
  268. }
  269. else if (MotorDebugCmd == 2)
  270. {
  271. if (getbit(MotorControlEnable, 0) == 1)
  272. {
  273. MotorControlFunc(0, 2);
  274. return;
  275. }
  276. else if (getbit(MotorControlEnable, 1) == 1)
  277. {
  278. MotorControlFunc(1, 2);
  279. return;
  280. }
  281. else if (getbit(MotorControlEnable, 2) == 1)
  282. {
  283. MotorControlFunc(2, 2);
  284. return;
  285. }
  286. else if (getbit(MotorControlEnable, 3) == 1)
  287. {
  288. MotorControlFunc(3, 2);
  289. return;
  290. }
  291. else
  292. {
  293. return;
  294. }
  295. }
  296. else
  297. {
  298. MotorControlFunc(0, 0xF1);
  299. LockMotorNum = -1;
  300. unLockMotorNum = -1;
  301. return;
  302. }
  303. }
  304. else if (MotorControlCmd == 1) //控制锁紧的自动流程
  305. {
  306. switch (LockMotorNum)
  307. {
  308. case -1:
  309. {
  310. MotorControlFunc(0, 0xF1);
  311. LockMotorNum = 0;
  312. break;
  313. }
  314. case 0:
  315. {
  316. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  317. {
  318. MotorControlFunc(LockMotorNum, 0xF1);
  319. LockMotorNum = 1;
  320. MotorRunTimer = 0;
  321. MotorLockReadyTimer = 0;
  322. }
  323. else
  324. {
  325. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  326. {
  327. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  328. }
  329. MotorControlFunc(LockMotorNum, 1);
  330. MotorRunTimer = MotorRunTimer + 10;
  331. }
  332. break;
  333. }
  334. case 1:
  335. {
  336. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  337. {
  338. MotorControlFunc(LockMotorNum, 0xF1);
  339. LockMotorNum = 2;
  340. MotorRunTimer = 0;
  341. MotorLockReadyTimer = 0;
  342. }
  343. else
  344. {
  345. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  346. {
  347. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  348. }
  349. MotorControlFunc(LockMotorNum, 1);
  350. MotorRunTimer = MotorRunTimer + 10;
  351. }
  352. break;
  353. }
  354. case 2:
  355. {
  356. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  357. {
  358. MotorControlFunc(LockMotorNum, 0xF1);
  359. LockMotorNum = 3;
  360. MotorRunTimer = 0;
  361. MotorLockReadyTimer = 0;
  362. }
  363. else
  364. {
  365. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  366. {
  367. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  368. }
  369. MotorControlFunc(LockMotorNum, 1);
  370. MotorRunTimer = MotorRunTimer + 10;
  371. }
  372. break;
  373. }
  374. case 3:
  375. {
  376. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= LockDelay) || getbit(MotorControlEnable, LockMotorNum) != 1)
  377. {
  378. MotorControlFunc(LockMotorNum, 0xF1);
  379. LockMotorNum = 4;
  380. unLockMotorNum = -1;
  381. MotorRunTimer = 0;
  382. MotorLockReadyTimer = 0;
  383. }
  384. else
  385. {
  386. if (getbit(ebcd_st_lockSensor, LockMotorNum) == 1)
  387. {
  388. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  389. }
  390. MotorControlFunc(LockMotorNum, 1);
  391. MotorRunTimer = MotorRunTimer + 10;
  392. }
  393. break;
  394. }
  395. default:
  396. break;
  397. }
  398. }
  399. else if (MotorControlCmd == 2) //控制解锁的自动流程
  400. {
  401. switch (unLockMotorNum)
  402. {
  403. case -1:
  404. {
  405. MotorControlFunc(0, 0xF2);
  406. unLockMotorNum = 0;
  407. break;
  408. }
  409. case 0:
  410. {
  411. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  412. {
  413. MotorControlFunc(unLockMotorNum, 0xF2);
  414. unLockMotorNum = 1;
  415. MotorRunTimer = 0;
  416. MotorLockReadyTimer = 0;
  417. }
  418. else
  419. {
  420. if (getbit(ebcd_st_unlockSensor, unLockMotorNum) == 1)
  421. {
  422. MotorLockReadyTimer = MotorLockReadyTimer + 10;
  423. }
  424. MotorControlFunc(unLockMotorNum, 2);
  425. MotorRunTimer = MotorRunTimer + 10;
  426. }
  427. break;
  428. }
  429. case 1:
  430. {
  431. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  432. {
  433. MotorControlFunc(unLockMotorNum, 0xF2);
  434. unLockMotorNum = 2;
  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 2:
  450. {
  451. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  452. {
  453. MotorControlFunc(unLockMotorNum, 0xF2);
  454. unLockMotorNum = 3;
  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 3:
  470. {
  471. if ((MotorRunTimer >= RunFailedDelay) || (MotorLockReadyTimer >= 1) || getbit(MotorControlEnable, unLockMotorNum) != 1)
  472. {
  473. MotorControlFunc(unLockMotorNum, 0xF2);
  474. unLockMotorNum = 4;
  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 4:
  490. {
  491. MotorControlFunc(0, 0xF1);
  492. unLockMotorNum = 5;
  493. LockMotorNum = -1;
  494. break;
  495. }
  496. default:
  497. break;
  498. }
  499. }
  500. }
  501. void MotorControlFunc(UINT8 MotorIdx, UINT8 RotateDirec) // MotorIdx 0-3 表示四个电机,RotateDirec F1停止正转,F2表示反转停止,1表示正转,2表示反转
  502. {
  503. switch (MotorIdx)
  504. {
  505. case 0:
  506. {
  507. switch (RotateDirec)
  508. {
  509. case 0xF1:
  510. {
  511. PSwtDrv_Interface(_M1_C, 0);
  512. PSwtDrv_Interface(_M2_C, 0);
  513. PSwtDrv_Interface(_M3_C, 0);
  514. PSwtDrv_Interface(_M4_C, 0);
  515. PSwtDrv_Interface(_M_D_C, 0);
  516. break;
  517. }
  518. case 0xF2:
  519. {
  520. PSwtDrv_Interface(_M1_C, 1);
  521. PSwtDrv_Interface(_M2_C, 1);
  522. PSwtDrv_Interface(_M3_C, 1);
  523. PSwtDrv_Interface(_M4_C, 1);
  524. PSwtDrv_Interface(_M_D_C, 1);
  525. break;
  526. }
  527. case 1:
  528. {
  529. PSwtDrv_Interface(_M1_C, 0);
  530. PSwtDrv_Interface(_M_D_C, 0);
  531. PSwtDrv_Interface(_M1_C, 1);
  532. break;
  533. }
  534. case 2:
  535. {
  536. PSwtDrv_Interface(_M1_C, 1);
  537. PSwtDrv_Interface(_M_D_C, 1);
  538. PSwtDrv_Interface(_M1_C, 0);
  539. break;
  540. }
  541. default:
  542. break;
  543. }
  544. break;
  545. }
  546. case 1:
  547. {
  548. switch (RotateDirec)
  549. {
  550. case 0xF1:
  551. {
  552. PSwtDrv_Interface(_M1_C, 0);
  553. PSwtDrv_Interface(_M2_C, 0);
  554. PSwtDrv_Interface(_M3_C, 0);
  555. PSwtDrv_Interface(_M4_C, 0);
  556. PSwtDrv_Interface(_M_D_C, 0);
  557. break;
  558. }
  559. case 0xF2:
  560. {
  561. PSwtDrv_Interface(_M1_C, 1);
  562. PSwtDrv_Interface(_M2_C, 1);
  563. PSwtDrv_Interface(_M3_C, 1);
  564. PSwtDrv_Interface(_M4_C, 1);
  565. PSwtDrv_Interface(_M_D_C, 1);
  566. break;
  567. }
  568. case 0:
  569. {
  570. PSwtDrv_Interface(_M2_C, 0);
  571. PSwtDrv_Interface(_M_D_C, 0);
  572. break;
  573. }
  574. case 1:
  575. {
  576. PSwtDrv_Interface(_M2_C, 0);
  577. PSwtDrv_Interface(_M_D_C, 0);
  578. PSwtDrv_Interface(_M2_C, 1);
  579. break;
  580. }
  581. case 2:
  582. {
  583. PSwtDrv_Interface(_M2_C, 1);
  584. PSwtDrv_Interface(_M_D_C, 1);
  585. PSwtDrv_Interface(_M2_C, 0);
  586. break;
  587. }
  588. default:
  589. break;
  590. }
  591. break;
  592. }
  593. case 2:
  594. {
  595. switch (RotateDirec)
  596. {
  597. case 0xF1:
  598. {
  599. PSwtDrv_Interface(_M1_C, 0);
  600. PSwtDrv_Interface(_M2_C, 0);
  601. PSwtDrv_Interface(_M3_C, 0);
  602. PSwtDrv_Interface(_M4_C, 0);
  603. PSwtDrv_Interface(_M_D_C, 0);
  604. break;
  605. }
  606. case 0xF2:
  607. {
  608. PSwtDrv_Interface(_M1_C, 1);
  609. PSwtDrv_Interface(_M2_C, 1);
  610. PSwtDrv_Interface(_M3_C, 1);
  611. PSwtDrv_Interface(_M4_C, 1);
  612. PSwtDrv_Interface(_M_D_C, 1);
  613. break;
  614. }
  615. case 0:
  616. {
  617. PSwtDrv_Interface(_M3_C, 0);
  618. PSwtDrv_Interface(_M_D_C, 0);
  619. break;
  620. }
  621. case 1:
  622. {
  623. PSwtDrv_Interface(_M3_C, 0);
  624. PSwtDrv_Interface(_M_D_C, 0);
  625. PSwtDrv_Interface(_M3_C, 1);
  626. break;
  627. }
  628. case 2:
  629. {
  630. PSwtDrv_Interface(_M3_C, 1);
  631. PSwtDrv_Interface(_M_D_C, 1);
  632. PSwtDrv_Interface(_M3_C, 0);
  633. break;
  634. }
  635. default:
  636. break;
  637. }
  638. break;
  639. }
  640. case 3:
  641. {
  642. switch (RotateDirec)
  643. {
  644. case 0xF1:
  645. {
  646. PSwtDrv_Interface(_M1_C, 0);
  647. PSwtDrv_Interface(_M2_C, 0);
  648. PSwtDrv_Interface(_M3_C, 0);
  649. PSwtDrv_Interface(_M4_C, 0);
  650. PSwtDrv_Interface(_M_D_C, 0);
  651. break;
  652. }
  653. case 0xF2:
  654. {
  655. PSwtDrv_Interface(_M1_C, 1);
  656. PSwtDrv_Interface(_M2_C, 1);
  657. PSwtDrv_Interface(_M3_C, 1);
  658. PSwtDrv_Interface(_M4_C, 1);
  659. PSwtDrv_Interface(_M_D_C, 1);
  660. break;
  661. }
  662. case 0:
  663. {
  664. PSwtDrv_Interface(_M4_C, 0);
  665. PSwtDrv_Interface(_M_D_C, 0);
  666. break;
  667. }
  668. case 1:
  669. {
  670. PSwtDrv_Interface(_M4_C, 0);
  671. PSwtDrv_Interface(_M_D_C, 0);
  672. PSwtDrv_Interface(_M4_C, 1);
  673. break;
  674. }
  675. case 2:
  676. {
  677. PSwtDrv_Interface(_M4_C, 1);
  678. PSwtDrv_Interface(_M_D_C, 1);
  679. PSwtDrv_Interface(_M4_C, 0);
  680. break;
  681. }
  682. default:
  683. break;
  684. }
  685. break;
  686. }
  687. default:
  688. break;
  689. }
  690. }
  691. #endif