AppFunc.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  1. /*
  2. * @Author : ChenJie
  3. * @Date : 2021-12-15 10:40:06
  4. * @Version : V3.0
  5. * @LastEditors : ChenJie
  6. * @LastEditTime : 2022-05-17 19:27:00
  7. * @Description : AppFunc
  8. * @FilePath : \undefinedd:\1_WorkFiles\2_Software\10_ReplaceBatteryControl\ECTEK_ToolChain\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. #define Lock 0
  18. #define Unlock 1
  19. #define LockCtrl() PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, Lock)
  20. #define UnlockCtrl() PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, Unlock)
  21. void LockAndUnlockCtrl()
  22. {
  23. static uint16 LockDelay = 0;
  24. static uint16 UnlockDelay = 0;
  25. static uint16 BleConCounter = 0;
  26. static uint16 battSwpeModeCounter = 0;
  27. if (ebcd_flg_ebcManCtrlEn) //手动控制使能
  28. {
  29. if (ebcd_flg_ebcManCtrlMode == 1) //循环控制模式
  30. {
  31. if (ebcd_st_lockSensor == 1) //处于锁紧状态,传感器判定一个
  32. {
  33. LockDelay = LockDelay + 10;
  34. if (LockDelay > LockDelayTime) //锁紧状态超时就解锁
  35. {
  36. ManuControlTimes++;
  37. LockDelay = 0;
  38. ebcd_st_SwitchCtrlFlg = Unlock;
  39. }
  40. }
  41. else if (ebcd_st_unlockSensor == 1) //处于解锁状态,传感器判定一个
  42. {
  43. UnlockDelay = UnlockDelay + 10;
  44. if (UnlockDelay > UnlockDelayTime)
  45. {
  46. UnlockDelay = 0;
  47. ebcd_st_SwitchCtrlFlg = Lock;
  48. }
  49. }
  50. }
  51. else if (ebcd_flg_ebcManCtrlMode == 2) //控制锁紧
  52. {
  53. ebcd_st_SwitchCtrlFlg = Lock;
  54. }
  55. else if (ebcd_flg_ebcManCtrlMode == 3) //控制解锁
  56. {
  57. ebcd_st_SwitchCtrlFlg = Unlock;
  58. }
  59. }
  60. else //正常工作模式
  61. {
  62. switch (ebcd_st_ebcWork)
  63. {
  64. case DriveMode: //行车状态,自动进入,默认状态
  65. {
  66. PSwtDrv_Interface(_PSWT_INDEX_EBCLEDCONTROL, 0); //行车状态换电指示灯关闭
  67. if (bled_flg_handShake == 1)
  68. {
  69. ebcd_st_ebcWork = CommuMode; //进入通讯状态
  70. bled_flg_handShake = 0;
  71. break;
  72. }
  73. break;
  74. }
  75. case CommuMode: //通讯状态,握手才能进入
  76. {
  77. BleConCounter = BleConCounter + 10;
  78. if ((BleConCounter % 1000) < 500) //换电指示灯闪烁
  79. {
  80. PSwtDrv_Interface(_PSWT_INDEX_EBCLEDCONTROL, 1);
  81. }
  82. else
  83. {
  84. PSwtDrv_Interface(_PSWT_INDEX_EBCLEDCONTROL, 0);
  85. }
  86. if (BleConCounter >= 60 * 1000 || bled_flg_backToDrv == 1)
  87. {
  88. ebcd_st_ebcWork = DriveMode; //切换到行车状态
  89. BleConCounter = 0;
  90. bled_flg_backToDrv = 0;
  91. break;
  92. }
  93. else if (BattCD_stWakeupU.B.bLogic == 0 && BattCD_stWakeupU.B.bWkpSig1 == 1)
  94. {
  95. ebcd_st_ebcWork = SwapMode; //切换到换电状态
  96. BleConCounter = 0;
  97. break;
  98. }
  99. if (bled_st_dataTrans == 1)
  100. {
  101. BleConCounter = 0;
  102. bled_st_dataTrans = 0;
  103. }
  104. break;
  105. }
  106. case SwapMode: //换电状态
  107. {
  108. PSwtDrv_Interface(_PSWT_INDEX_EBCLEDCONTROL, 1); //换电状态换电指示灯常亮
  109. battSwpeModeCounter = battSwpeModeCounter + 10;
  110. if (bled_flg_swapBattDone == 1)
  111. {
  112. ebcd_Nr_swapBatt++;
  113. ebcd_Nr_swapSucBatt++;
  114. bled_flg_swapBattDone = 0;
  115. ebcd_st_ebcWork = CommuMode; //切换到通讯状态
  116. break;
  117. }
  118. else if (battSwpeModeCounter >= 60 * 1000)
  119. {
  120. ebcd_Nr_swapBatt++;
  121. battSwpeModeCounter = DriveMode; //切换到行车状态
  122. ebcd_st_ebcWork = 0;
  123. break;
  124. }
  125. if (bled_st_dataTrans == 1)
  126. {
  127. battSwpeModeCounter = 0;
  128. bled_st_dataTrans = 0;
  129. }
  130. if (bled_flg_unlockCmdForce)
  131. {
  132. ebcd_st_SwitchCtrlFlg = Unlock;
  133. bled_flg_unlockCmdForce = 0;
  134. }
  135. if (bled_flg_lockCmdForce)
  136. {
  137. ebcd_st_SwitchCtrlFlg = Lock;
  138. bled_flg_lockCmdForce = 0;
  139. }
  140. break;
  141. }
  142. }
  143. }
  144. //锁紧解锁执行
  145. if (ebcd_st_SwitchCtrlFlg == Unlock)
  146. {
  147. UnlockCtrl();
  148. }
  149. else
  150. {
  151. LockCtrl();
  152. }
  153. }
  154. /**
  155. * @brief : 互锁检测函数
  156. * @param {*}
  157. * @return {*}
  158. */
  159. void GetHVLockState(void)
  160. {
  161. // PWM输出,互锁1检测,频率100HZ,占空比30%
  162. uint16 VehCo_fTestUI = 1000;
  163. uint16 VehCo_rTestUW = 3000;
  164. uint32 PwmFreAcq = 0;
  165. uint16 PwmDutyAcq = 0;
  166. PPWMDrv_Interface(_PPWM_INDEX_HVLOCK2, VehCo_fTestUI, VehCo_rTestUW);
  167. PulseAcqDrv_GetChanFreq(_PULSEACQ_INDEX_HVLOCK2, &PwmFreAcq, &PwmDutyAcq);
  168. if (abs(PwmFreAcq - VehCo_fTestUI) < 100 && abs(PwmDutyAcq - VehCo_rTestUW) < 500)
  169. {
  170. m_flg_HVlock1 = 1;
  171. }
  172. else
  173. {
  174. m_flg_HVlock1 = 1;
  175. }
  176. //互锁2检测,高有效,悬空为0则未接入,高电平为1则接入,
  177. m_flg_HVlock2 = DINDrv_GetChanState(_DIN_INDEX_PLUGHVLOCK);
  178. }
  179. /**
  180. * @brief : 数字量传感器信号检测函数
  181. * @param {*}
  182. * @return {*}
  183. */
  184. void GetDIOState(void)
  185. {
  186. uint8 temp[4];
  187. //松开传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  188. memset(temp, 0x00, 4);
  189. ebcd_st_unlockSensor = 0;
  190. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR1, 1, 4095U);
  191. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR2, 1, 4095U);
  192. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR3, 1, 4095U);
  193. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR4, 1, 4095U);
  194. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR1);
  195. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR2);
  196. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR3);
  197. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR4);
  198. ebcd_st_unlockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  199. //夹紧传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  200. memset(temp, 0x00, 4);
  201. ebcd_st_lockSensor = 0;
  202. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR1, 1, 4095U);
  203. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR2, 1, 4095U);
  204. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR3, 1, 4095U);
  205. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR4, 1, 4095U);
  206. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR1);
  207. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR2);
  208. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR3);
  209. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR4);
  210. temp[0] = 1;
  211. temp[1] = 1;
  212. temp[2] = 1;
  213. temp[3] = 1;
  214. ebcd_st_lockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  215. //落座传感器检测,高有效,悬空为0则未接入,高电平为1则接入
  216. memset(temp, 0x00, 4);
  217. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_READYSENSOR1);
  218. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_READYSENSOR2);
  219. ebcd_st_pedstSensor = (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  220. }
  221. /**
  222. * @brief : 获取模拟量输入值,并进行转换
  223. * @param {*}
  224. * @return {*}
  225. */
  226. void GetAIOValue(void)
  227. {
  228. uint16 AirPressureTemp_Vol = 0;
  229. uint16 PluginTemp1_Vol = 0;
  230. uint32 PluginTemp1_R = 0;
  231. uint16 PluginTemp2_Vol = 0;
  232. uint32 PluginTemp2_R = 0;
  233. uint16 PluginTemp3_Vol = 0;
  234. uint32 PluginTemp3_R = 0;
  235. uint16 PluginTemp4_Vol = 0;
  236. uint32 PluginTemp4_R = 0;
  237. AirPressureTemp_Vol = ATDDrv_GetChanResult(_ATD_INDEX_AIRPRESSURE);
  238. AirPressureTemp_Vol = (uint16)(AirPressureTemp_Vol * 1000 / 4095.0);
  239. Test_LockPressure = AirPressureTemp_Vol; //锁紧力测试变量
  240. /*气压数据转换*/
  241. AirPressureTemp_Vol = MAX(AirPressureTemp_Vol, 500);
  242. AirPressureTemp_Vol = MIN(AirPressureTemp_Vol, 4500);
  243. ebcd_P_airSensor = (uint8)((AirPressureTemp_Vol - 500) / 40);
  244. /*温度采集获取*/
  245. PluginTemp1_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP1);
  246. PluginTemp2_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP2);
  247. PluginTemp3_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP3);
  248. PluginTemp4_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP4);
  249. PluginTemp1_R = (uint32)((PluginTemp1_Vol / (5.0 * 4095 - PluginTemp1_Vol)) * 1000.0);
  250. PluginTemp2_R = (uint32)((PluginTemp2_Vol / (5.0 * 4095 - PluginTemp2_Vol)) * 1000.0);
  251. PluginTemp3_R = (uint32)((PluginTemp3_Vol / (5.0 * 4095 - PluginTemp3_Vol)) * 1000.0);
  252. PluginTemp4_R = (uint32)((PluginTemp4_Vol / (5.0 * 4095 - PluginTemp4_Vol)) * 1000.0);
  253. ebcd_T_plugin[0] = (uint8)Look1_u32u8(PluginTemp1_R, R_table, T_table, 240);
  254. ebcd_T_plugin[1] = (uint8)Look1_u32u8(PluginTemp2_R, R_table, T_table, 240);
  255. ebcd_T_plugin[2] = (uint8)Look1_u32u8(PluginTemp3_R, R_table, T_table, 240);
  256. ebcd_T_plugin[3] = (uint8)Look1_u32u8(PluginTemp4_R, R_table, T_table, 240);
  257. }
  258. /**
  259. * @brief : lookUp Table Fun
  260. * @param {uint32} u0 x
  261. * @param {uint32} bp0 x_table
  262. * @param {uint16} table y_table
  263. * @param {uint16} maxIndex
  264. * @return {*}
  265. */
  266. uint16 Look1_u32u8(uint32 u0, uint32 *bp0, uint8 *table, uint16 MaxLen)
  267. {
  268. uint32 bpIdx = 0;
  269. uint32 iLeft = 0;
  270. uint32 iRght = 0;
  271. uint16 y = 0;
  272. uint32 yL_0d0 = 0;
  273. uint32 yR_0d0 = 0;
  274. uint32 maxIndex = MaxLen - 1;
  275. if (u0 <= bp0[0U])
  276. {
  277. iLeft = 0U;
  278. iRght = 0U;
  279. }
  280. else if (u0 < bp0[maxIndex])
  281. {
  282. //对折法寻找u0的位置
  283. bpIdx = maxIndex >> 1U;
  284. iLeft = 0U;
  285. iRght = maxIndex;
  286. while ((iRght - iLeft) > 1)
  287. {
  288. if (u0 < bp0[bpIdx])
  289. {
  290. iRght = bpIdx;
  291. }
  292. else
  293. {
  294. iLeft = bpIdx;
  295. }
  296. bpIdx = (iRght + iLeft) >> 1U;
  297. }
  298. }
  299. else
  300. {
  301. iLeft = maxIndex;
  302. iRght = maxIndex;
  303. }
  304. //找到位置以后计算插值
  305. if (iLeft != iRght)
  306. {
  307. //线性插值
  308. yR_0d0 = table[iLeft + 1U];
  309. yL_0d0 = table[iLeft];
  310. if (yR_0d0 >= yL_0d0)
  311. {
  312. y = (uint16)(((uint32)(u0 - bp0[iLeft]) * (yR_0d0 - yL_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]) + yL_0d0);
  313. }
  314. else
  315. {
  316. y = (uint16)(yL_0d0 - ((uint32)(u0 - bp0[iLeft]) * (yL_0d0 - yR_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]));
  317. }
  318. }
  319. else
  320. {
  321. y = (uint16)table[iLeft];
  322. }
  323. return y;
  324. }
  325. /**
  326. * @brief : 故障诊断函数,运行时间100ms
  327. * @param {*}
  328. * @return {*}
  329. */
  330. void FaultDiagnosisFunc(void)
  331. {
  332. UINT8 ErrorNumTemp = 0, ErrRank = 0;
  333. static BOOL FuncFirstRun = TRUE;
  334. static BOOL sfmd_flg_Temp1Over2;
  335. static BOOL sfmd_flg_Temp2Over2;
  336. static BOOL sfmd_flg_Temp3Over2;
  337. static BOOL sfmd_flg_Temp4Over2;
  338. static BOOL sfmd_flg_Temp1Over3;
  339. static BOOL sfmd_flg_Temp2Over3;
  340. static BOOL sfmd_flg_Temp3Over3;
  341. static BOOL sfmd_flg_Temp4Over3;
  342. BOOL sfmd_flg_Temp1Openflt = FALSE;
  343. BOOL sfmd_flg_Temp2Openflt = FALSE;
  344. BOOL sfmd_flg_Temp3Openflt = FALSE;
  345. BOOL sfmd_flg_Temp4Openflt = FALSE;
  346. if (FuncFirstRun)
  347. {
  348. FuncFirstRun = FALSE;
  349. sfmd_flg_Temp1Over2 = FALSE;
  350. sfmd_flg_Temp2Over2 = FALSE;
  351. sfmd_flg_Temp3Over2 = FALSE;
  352. sfmd_flg_Temp4Over2 = FALSE;
  353. sfmd_flg_Temp1Over3 = getbit(sfmv_Num_FltEEsave, 0);
  354. sfmd_flg_Temp2Over3 = getbit(sfmv_Num_FltEEsave, 1);
  355. sfmd_flg_Temp3Over3 = getbit(sfmv_Num_FltEEsave, 2);
  356. sfmd_flg_Temp4Over3 = getbit(sfmv_Num_FltEEsave, 3);
  357. }
  358. /*锁紧与解锁诊断*/
  359. if (ebcd_st_SwitchCtrlFlg == Unlock) //解锁诊断
  360. {
  361. if (ebcd_st_unlockSensor == 0x0F)
  362. {
  363. ebcd_st_unlockSucJug = 1;
  364. }
  365. else if (ebcd_st_unlockSensor == 0x00)
  366. {
  367. ebcd_st_unlockSucJug = 0;
  368. }
  369. else
  370. {
  371. ebcd_st_unlockSucJug = 2;
  372. }
  373. }
  374. else //锁紧诊断
  375. {
  376. if (ebcd_st_lockSensor == 0x0F)
  377. {
  378. ebcd_st_lockSucJug = 1;
  379. }
  380. else if (ebcd_st_lockSensor == 0x00)
  381. {
  382. ebcd_st_lockSucJug = 0;
  383. }
  384. else
  385. {
  386. ebcd_st_lockSucJug = 2;
  387. }
  388. }
  389. /*底座到位判断*/
  390. if (ebcd_st_pedstSucJug == 0x03)
  391. {
  392. ebcd_st_pedstSucJug = 1;
  393. }
  394. else if (ebcd_st_pedstSucJug == 0x00)
  395. {
  396. ebcd_st_pedstSucJug = 0;
  397. }
  398. else
  399. {
  400. ebcd_st_pedstSucJug = 2;
  401. }
  402. /*温度传感器开路诊断*/
  403. sfmd_flg_Temp1Openflt = JudgeTimeSystem(1U, (ebcd_T_plugin[0] == 0), (UINT16 *)&DiagErrFaulNum.DiagErrFaulN25, 5U);
  404. sfmd_flg_Temp2Openflt = JudgeTimeSystem(1U, (ebcd_T_plugin[1] == 0), (UINT16 *)&DiagErrFaulNum.DiagErrFaulN26, 5U);
  405. sfmd_flg_Temp3Openflt = JudgeTimeSystem(1U, (ebcd_T_plugin[2] == 0), (UINT16 *)&DiagErrFaulNum.DiagErrFaulN27, 5U);
  406. sfmd_flg_Temp4Openflt = JudgeTimeSystem(1U, (ebcd_T_plugin[3] == 0), (UINT16 *)&DiagErrFaulNum.DiagErrFaulN28, 5U);
  407. /*温度传感器三级过温诊断*/
  408. sfmd_flg_Temp1Over3 = DiagThrSystem1(1, !sfmd_flg_Temp1Openflt, ebcd_T_plugin[0], sfmd_Th_Temp1Over3Faul, sfmd_Th_Temp1Over3Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN17, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN17, sfmd_flg_Temp1Over3);
  409. sfmd_flg_Temp2Over3 = DiagThrSystem1(1, !sfmd_flg_Temp2Openflt, ebcd_T_plugin[1], sfmd_Th_Temp2Over3Faul, sfmd_Th_Temp2Over3Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN18, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN18, sfmd_flg_Temp2Over3);
  410. sfmd_flg_Temp3Over3 = DiagThrSystem1(1, !sfmd_flg_Temp3Openflt, ebcd_T_plugin[2], sfmd_Th_Temp3Over3Faul, sfmd_Th_Temp3Over3Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN19, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN19, sfmd_flg_Temp3Over3);
  411. sfmd_flg_Temp4Over3 = DiagThrSystem1(1, !sfmd_flg_Temp4Openflt, ebcd_T_plugin[3], sfmd_Th_Temp4Over3Faul, sfmd_Th_Temp4Over3Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN20, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN20, sfmd_flg_Temp4Over3);
  412. /*温度传感器二级过温诊断*/
  413. sfmd_flg_Temp1Over2 = DiagThrSystem1(1, !sfmd_flg_Temp1Over3 && !sfmd_flg_Temp1Openflt, ebcd_T_plugin[0], sfmd_Th_Temp1Over2Faul, sfmd_Th_Temp1Over2Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN9, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN9, sfmd_flg_Temp1Over2);
  414. sfmd_flg_Temp2Over2 = DiagThrSystem1(1, !sfmd_flg_Temp2Over3 && !sfmd_flg_Temp2Openflt, ebcd_T_plugin[1], sfmd_Th_Temp2Over2Faul, sfmd_Th_Temp2Over2Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN10, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN10, sfmd_flg_Temp2Over2);
  415. sfmd_flg_Temp3Over2 = DiagThrSystem1(1, !sfmd_flg_Temp3Over3 && !sfmd_flg_Temp3Openflt, ebcd_T_plugin[2], sfmd_Th_Temp3Over2Faul, sfmd_Th_Temp3Over2Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN11, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN11, sfmd_flg_Temp3Over2);
  416. sfmd_flg_Temp4Over2 = DiagThrSystem1(1, !sfmd_flg_Temp4Over3 && !sfmd_flg_Temp4Openflt, ebcd_T_plugin[3], sfmd_Th_Temp4Over2Faul, sfmd_Th_Temp4Over2Reco, 30, 30, (UINT16 *)&DiagErrFaulNum.DiagErrFaulN12, (UINT16 *)&DiagErrRecoNum.DiagErrRecoN12, sfmd_flg_Temp4Over2);
  417. sfmv_Num_FltEEsave = ((sfmd_flg_Temp4Over3 & 0x01) << 3) | ((sfmd_flg_Temp3Over3 & 0x01) << 2) | ((sfmd_flg_Temp2Over3 & 0x01) << 1) | (sfmd_flg_Temp1Over3);
  418. /*故障代码写入*/
  419. if (sfmd_flg_Temp1Openflt)
  420. {
  421. ErrorNumTemp = 25;
  422. ErrRank = 2;
  423. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  424. }
  425. if (sfmd_flg_Temp2Openflt)
  426. {
  427. ErrorNumTemp = 26;
  428. ErrRank = 2;
  429. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  430. }
  431. if (sfmd_flg_Temp3Openflt)
  432. {
  433. ErrorNumTemp = 27;
  434. ErrRank = 2;
  435. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  436. }
  437. if (sfmd_flg_Temp4Openflt)
  438. {
  439. ErrorNumTemp = 28;
  440. ErrRank = 2;
  441. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  442. }
  443. if (sfmd_flg_Temp1Over3)
  444. {
  445. ErrorNumTemp = 17;
  446. ErrRank = 3;
  447. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  448. }
  449. if (sfmd_flg_Temp2Over3)
  450. {
  451. ErrorNumTemp = 18;
  452. ErrRank = 3;
  453. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  454. }
  455. if (sfmd_flg_Temp3Over3)
  456. {
  457. ErrorNumTemp = 19;
  458. ErrRank = 3;
  459. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  460. }
  461. if (sfmd_flg_Temp4Over3)
  462. {
  463. ErrorNumTemp = 20;
  464. ErrRank = 3;
  465. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  466. }
  467. if (sfmd_flg_Temp1Over2)
  468. {
  469. ErrorNumTemp = 9;
  470. ErrRank = 2;
  471. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  472. }
  473. if (sfmd_flg_Temp2Over2)
  474. {
  475. ErrorNumTemp = 10;
  476. ErrRank = 2;
  477. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  478. }
  479. if (sfmd_flg_Temp3Over2)
  480. {
  481. ErrorNumTemp = 11;
  482. ErrRank = 2;
  483. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  484. }
  485. if (sfmd_flg_Temp4Over2)
  486. {
  487. ErrorNumTemp = 12;
  488. ErrRank = 2;
  489. PutErrorNum(ErrArray, sizeof(ErrArray) / 2, ErrorNumTemp + ErrRank * 1000);
  490. }
  491. }
  492. /**
  493. * @brief : 故障判断函数
  494. * @param {BOOL} Enable 使能状态
  495. * @param {BOOL} Input 判断输入
  496. * @param {UINT16} *N 判断次数累计
  497. * @param {UINT16} Thr 判断次数阈值
  498. * @return {*}
  499. */
  500. BOOL JudgeTimeSystem(BOOL Enable, BOOL Input, UINT16 *N, UINT16 Thr)
  501. {
  502. BOOL Flg = FALSE;
  503. if (Input && Enable)
  504. {
  505. *N = (*N + 1) > 2000 ? 2000 : (*N + 1);
  506. }
  507. else
  508. {
  509. *N = 0;
  510. }
  511. if (*N > Thr && Enable)
  512. {
  513. Flg = TRUE;
  514. }
  515. else
  516. {
  517. Flg = FALSE;
  518. }
  519. return Flg;
  520. }
  521. BOOL DiagThrSystem1(BOOL Enable, BOOL precondition, UINT16 Input, UINT16 fltThr, UINT16 recThr, UINT16 fltNumThr, UINT16 recNumThr, UINT16 *fltNum, UINT16 *recNum, UINT8 *fitFlg)
  522. {
  523. if (Enable && precondition && Input > fltThr)
  524. {
  525. *fltNum = (*fltNum + 1) > 20000 ? 20000 : (*fltNum + 1);
  526. }
  527. else
  528. {
  529. *fltNum = 0;
  530. }
  531. if (Enable && precondition && Input < recThr)
  532. {
  533. *recNum = (*recNum + 1) > 20000 ? 20000 : (*recNum + 1);
  534. }
  535. else
  536. {
  537. *recNum = 0;
  538. }
  539. if ((*fltNum > fltNumThr || (*fitFlg && *recNum < recNumThr)) && precondition)
  540. {
  541. *fitFlg = TRUE;
  542. }
  543. else
  544. {
  545. *fitFlg = FALSE;
  546. }
  547. return *fitFlg;
  548. }
  549. /**
  550. * @brief : 获取故障码函数,从故障数组中获取故障码,并将之前的故障码向前移动
  551. * @param {UINT16} *ErrorArray
  552. * @param {UINT8} Errorlen
  553. * @return {*}
  554. */
  555. UINT16 GetErrorNum(UINT16 *ErrorArray, UINT8 Errorlen)
  556. {
  557. UINT16 OutNum;
  558. OutNum = *(ErrorArray);
  559. for (UINT8 i = 0; i < Errorlen - 1; i++)
  560. {
  561. *(ErrorArray + i) = *(ErrorArray + i + 1);
  562. if (*(ErrorArray + i + 1) == 0)
  563. break;
  564. }
  565. return OutNum;
  566. }
  567. /**
  568. * @brief : 故障码注入函数,将故障码写入到故障数组中,如果存在则不写入,如果存在则不写入
  569. * @param {UINT16} *ErrorArray
  570. * @param {UINT8} Errorlen
  571. * @param {UINT16} ErrorNum
  572. * @return {*}
  573. */
  574. UINT8 PutErrorNum(UINT16 *ErrorArray, UINT8 Errorlen, UINT16 ErrorNum)
  575. {
  576. for (UINT8 i = 0; i < Errorlen; i++)
  577. {
  578. if (*(ErrorArray + i) == 0)
  579. {
  580. *(ErrorArray + i) = ErrorNum;
  581. return 0;
  582. }
  583. else
  584. {
  585. if (*(ErrorArray + i) == ErrorNum)
  586. {
  587. return 1;
  588. }
  589. else
  590. {
  591. continue;
  592. }
  593. }
  594. }
  595. return 2;
  596. }