main.c 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815
  1. /**
  2. * @mainpage
  3. * Project Name:
  4. * Author:
  5. * Complier:
  6. * CPU_TYPE:
  7. * @section Project description:
  8. * -项目详细描述
  9. * @section function description:
  10. * -#功能描述
  11. * @section Usage description:
  12. * -#用法描述
  13. * @attention
  14. * -#注意事项
  15. */
  16. #ifndef _MAIN_C_
  17. #define _MAIN_C_
  18. #endif
  19. /************************************************************************
  20. Included File
  21. *************************************************************************/
  22. #include "syspar.h"
  23. #include "user.h"
  24. #include "TimeTask_Event.h"
  25. #include "FSM_1st.h"
  26. #include "FSM_2nd.h"
  27. #include "can.h"
  28. #include "cmdgennew.h"
  29. #include "canAppl.h"
  30. #include "flash_master.h"
  31. #include "torquesensor.h"
  32. #include "power.h"
  33. #include "STLmain.h"
  34. #include "api.h"
  35. /************************************************************************
  36. Exported Functions:
  37. ************************************************************************/
  38. void AppInit();
  39. void AppLoop();
  40. /***************************************************************
  41. Function: main;
  42. Description:main function
  43. Call by:
  44. Input Variables: N/A
  45. Output/Return Variables: N/A
  46. Subroutine Call: N/A;
  47. Reference: N/A
  48. ****************************************************************/
  49. int main(void) /* parasoft-suppress GJB5369-4_2_1_10 "mismatch" */
  50. {
  51. #ifndef RUN_ARCH_SIM
  52. SCB->VTOR = 0x08003000;
  53. /* Disable all interrupts */
  54. DISABLE_IRQ;
  55. /* MCU Core and GPIO configuration */
  56. hw_voHardwareSetup1();
  57. /* Api Init*/
  58. iRt_Init();
  59. /* Code Para Init */
  60. CodeParaInit();
  61. /* AssitPara Init */
  62. ass_voAssitEEInit();
  63. /* Peripheral configuration */
  64. hw_voHardwareSetup2();
  65. /* PowerInit */
  66. power_voPowerInit();
  67. /* DisplayInit */
  68. display_voDisplayInit();
  69. /* Para Copy */
  70. mn_voParaSet();
  71. //cp_stFlg.ParaFirstSetFlg = 0; //eeprom save test
  72. if(cp_stFlg.ParaFirstSetFlg == 0)
  73. {
  74. flash_voParaInit();
  75. /* Parameter Default Value Write*/
  76. i2c_voDefaultWriteBuffer();
  77. i2c_voInfoWrite2EE(&i2c_stTXCoef, &i2c_stTXOut);
  78. /* Cycling History Info clear */
  79. CodeHistoryParaDelete();
  80. mn_voEEHistoryParaUpdate();
  81. i2c_voHistoryWriteBuffer();
  82. i2c_voHistoryWrite2EE(&i2c_stTXCoef, &i2c_stTXOut);
  83. /* Read EE and Update code para */
  84. mn_voParaSet();
  85. }
  86. Can_voUpdateMC_UpcInfo();
  87. /* System parameter initial */
  88. mn_voSoftwareInit();
  89. /* Timer enable */
  90. hw_voTimEn();
  91. /* Interrupts of peripherals enable*/
  92. hw_voEnInt();
  93. /* Spi Position Comp */
  94. spi_voReadWriteSeneorReg();
  95. /* Error Log Read */
  96. flash_voErrorRead();
  97. /* MCU Self Test Init */
  98. stl_voRunTimeChecksInit();
  99. /* Watchdog 1s */
  100. hw_voIWDGInit(FWDGT_PSC_DIV32,1250);//1s
  101. /* Enable all interrupts */
  102. ENABLE_IRQ;
  103. /* Enter infinite loop */
  104. while (1)
  105. {
  106. /* Control mode FSM reset */
  107. if (!sysfsm_stFlg.blFSMRstOvrFlg)
  108. {
  109. RUN_FSM_voInit();
  110. Switch_speed_FSMInit();
  111. sysfsm_stFlg.blFSMRstOvrFlg = TRUE;
  112. }
  113. /* Control mode variable clear */
  114. if (!sysfsm_stFlg.blCtrlMdVarClcOvrFlg)
  115. {
  116. sysfsm_stFlg.blCtrlMdVarClcOvrFlg = TRUE;
  117. }
  118. CanRx_Process();
  119. ReadFrame_Poll2();
  120. uart_voMainDec();
  121. TimingTaskLoopServer();
  122. if(cp_stFlg.SpiOffsetFirstSetFinishFlg == TRUE && switch_flg.SysRun_Flag == FALSE && cp_stFlg.SpiOffsetFirstSetFlg==0 && FSM2nd_Run_state.state == Exit)
  123. {
  124. DISABLE_IRQ;
  125. MC_UpcInfo.stMContorlInfo.uwSaveFlg = 1;
  126. cp_stFlg.SpiOffsetFirstSetFlg = 1;
  127. mn_voEEUperParaUpdate();
  128. /* Parameter real value write*/
  129. i2c_voParaWriteBuffer();
  130. i2c_voInfoWrite2EE(&i2c_stTXCoef, &i2c_stTXOut);
  131. MC_UpcInfo.stMContorlInfo.uwSaveFlg = 0;
  132. ENABLE_IRQ;
  133. }
  134. if (cp_stFlg.ParaUpdateFlg == TRUE)
  135. {
  136. mn_voParaUpdate();
  137. }
  138. if (power_stPowStateOut.powerstate == POWER_OFF)
  139. {
  140. if (FSM2nd_Run_state.state == Exit)
  141. {
  142. if (cp_stFlg.ParaHistorySaveEEFinishFlg == FALSE)
  143. {
  144. DISABLE_IRQ;
  145. cp_stHistoryPara.uwOpenTimes++;
  146. cp_stHistoryPara.ulODOTime = MC_RideLog.ODO_Time;
  147. cp_stHistoryPara.ulTripSumTime = MC_RideLog.TRIP_Time;
  148. mn_voEEHistoryParaUpdate();
  149. i2c_voHistoryWriteBuffer();
  150. i2c_voHistoryWrite2EE(&i2c_stTXCoef, &i2c_stTXOut);
  151. cp_stFlg.ParaHistorySaveEEFinishFlg = TRUE;
  152. flash_voWrite();
  153. /* Error Log Write */
  154. flash_voErrorWrite();
  155. if (cp_stFlg.ParaSaveEEFlg == TRUE)
  156. {
  157. mn_voEEUperParaUpdate();
  158. /* Parameter real value write*/
  159. i2c_voParaWriteBuffer();
  160. i2c_voInfoWrite2EE(&i2c_stTXCoef, &i2c_stTXOut);
  161. cp_stFlg.ParaSaveEEFinishFlg = TRUE;
  162. cp_stFlg.ParaSaveEEFlg = FALSE;
  163. }
  164. ENABLE_IRQ;
  165. }
  166. }
  167. }
  168. }
  169. return 0;
  170. #endif
  171. }
  172. /***************************************************************
  173. Function: mn_voSoftwareInit;
  174. Description:software intial
  175. Call by:
  176. Input Variables: N/A
  177. Output/Return Variables: N/A
  178. Subroutine Call: N/A;
  179. Reference: N/A
  180. ****************************************************************/
  181. void mn_voParaSet(void)
  182. {
  183. /* Read system parameter*/
  184. i2c_voSysparaReadFromEE(&i2c_stRXCRCOut);
  185. if (i2c_stRXCRCOut.blHistoryParaFltFlg == FALSE)
  186. {
  187. ass_stParaSet.uwAsssistSelectNum = I2C_uwHistoryParaRead[0];
  188. cp_stHistoryPara.uwOpenTimes = I2C_uwHistoryParaRead[1];
  189. cp_stHistoryPara.ulUsedTime = (((ULONG)I2C_uwHistoryParaRead[2]) << 16) + I2C_uwHistoryParaRead[3];
  190. cp_stHistoryPara.uwNTCTempMaxCe = I2C_uwHistoryParaRead[4];
  191. cp_stHistoryPara.uwNTCTempMinCe = I2C_uwHistoryParaRead[5];
  192. cp_stHistoryPara.uwAlamHOcurTimes = I2C_uwHistoryParaRead[6];
  193. cp_stHistoryPara.uwAlamSOcurTimes = I2C_uwHistoryParaRead[7];
  194. cp_stHistoryPara.uwAlamOHeatTimes = I2C_uwHistoryParaRead[8];
  195. cp_stHistoryPara.uwAlamRotorLockTimes = I2C_uwHistoryParaRead[9];
  196. cp_stHistoryPara.uwAlamPhsLossTimes = I2C_uwHistoryParaRead[10];
  197. cp_stHistoryPara.uwAlamOVolTimes = I2C_uwHistoryParaRead[11];
  198. cp_stHistoryPara.uwAlamUVolTimes = I2C_uwHistoryParaRead[12];
  199. cp_stHistoryPara.uwAlamComOTimeTimes = I2C_uwHistoryParaRead[13];
  200. cp_stHistoryPara.uwG1AvgPwrConsumption = I2C_uwHistoryParaRead[14];
  201. cp_stHistoryPara.uwG2AvgPwrConsumption = I2C_uwHistoryParaRead[15];
  202. cp_stHistoryPara.uwG3AvgPwrConsumption = I2C_uwHistoryParaRead[16];
  203. cp_stHistoryPara.uwG4AvgPwrConsumption = I2C_uwHistoryParaRead[17];
  204. cp_stHistoryPara.uwG5AvgPwrConsumption = I2C_uwHistoryParaRead[18];
  205. cp_stHistoryPara.ulODOTrip = (((ULONG)I2C_uwHistoryParaRead[19]) << 16) + I2C_uwHistoryParaRead[20];
  206. cp_stHistoryPara.ulODOTime = (((ULONG)I2C_uwHistoryParaRead[21]) << 16) + I2C_uwHistoryParaRead[22];
  207. cp_stHistoryPara.ulTripSum = (((ULONG)I2C_uwHistoryParaRead[23]) << 16) + I2C_uwHistoryParaRead[24];
  208. cp_stHistoryPara.ulTripSumTime = (((ULONG)I2C_uwHistoryParaRead[25]) << 16) + I2C_uwHistoryParaRead[26];
  209. cp_stHistoryPara.uwTorSensorAlamTimes = I2C_uwHistoryParaRead[27];
  210. cp_stHistoryPara.uwCadSensorAlamTimes = I2C_uwHistoryParaRead[28];
  211. cp_stHistoryPara.uwBikeSpdSensorAlamTimes = I2C_uwHistoryParaRead[29];
  212. cp_stHistoryPara.uwPosSensorAlamTimes = I2C_uwHistoryParaRead[30];
  213. }
  214. else
  215. {}
  216. // peripheral Para Set
  217. cadence_stFreGetCof.uwNumbersPulses = CADENCE_NUMBERS_PULSES;
  218. bikespeed_stFreGetCof.uwNumbersPulses = BIKESPEED_NUMBERS_PULSES;
  219. torsensor_stTorSensorCof.uwMaxSensorTorquePu = ((ULONG)TORQUE_MAX_RANGE << 14) / TORQUEBASE; // Q14
  220. /////////////////////////////////
  221. if (cp_stFlg.ParaUseEEFlg == TRUE)
  222. {
  223. if (i2c_stRXCRCOut.ReadFinishFlg == TRUE)
  224. {
  225. if (i2c_stRXCRCOut.blMotorParaFltFlg == FALSE)
  226. {
  227. cp_stMotorPara.swMotrPolePairs = (SWORD)I2C_uwMotorParaRead[0];
  228. cp_stMotorPara.swRsOhm = (SWORD)I2C_uwMotorParaRead[1];
  229. cp_stMotorPara.swLdmH = (SWORD)I2C_uwMotorParaRead[2];
  230. cp_stMotorPara.swLqmH = (SWORD)I2C_uwMotorParaRead[3];
  231. cp_stMotorPara.swFluxWb = (SWORD)I2C_uwMotorParaRead[4];
  232. cp_stMotorPara.swIdMaxA = (SWORD)I2C_uwMotorParaRead[5];
  233. cp_stMotorPara.swIdMinA = (SWORD)I2C_uwMotorParaRead[6];
  234. cp_stMotorPara.swRSpeedRpm = (SWORD)I2C_uwMotorParaRead[7];
  235. cp_stMotorPara.swRPwrWt = (SWORD)I2C_uwMotorParaRead[8];
  236. cp_stMotorPara.swRIarmsA = (SWORD)I2C_uwMotorParaRead[9];
  237. cp_stMotorPara.swRUdcV = (SWORD)I2C_uwMotorParaRead[10];
  238. cp_stMotorPara.swJD = (SWORD)I2C_uwMotorParaRead[11];
  239. cp_stMotorPara.swTorMax = (SWORD)I2C_uwMotorParaRead[12];
  240. }
  241. else
  242. {}
  243. if (i2c_stRXCRCOut.blBikeParaFltFlg == FALSE)
  244. {
  245. ass_stParaCong.uwWheelPerimeter = I2C_uwBikeParaRead[0];
  246. ass_stParaCong.uwMechRationMotor = I2C_uwBikeParaRead[1];
  247. ass_stParaCong.uwAssistMaxSpdKmH = I2C_uwBikeParaRead[2];
  248. ass_stParaCong.uwThrottleMaxSpdKmH = I2C_uwBikeParaRead[3];
  249. ass_stParaCong.uwNmFrontChainring = I2C_uwBikeParaRead[4];
  250. ass_stParaCong.uwNmBackChainring = I2C_uwBikeParaRead[5];
  251. ass_stParaCong.uwAssistSelect1 = I2C_uwBikeParaRead[6];
  252. ass_stParaCong.uwAssistSelect2 = I2C_uwBikeParaRead[7];
  253. ass_stParaCong.uwLightVoltage = I2C_uwBikeParaRead[8];
  254. ass_stParaCong.swDeltPerimeter = (SWORD)I2C_uwBikeParaRead[9];
  255. ass_stParaCong.uwStartMode = I2C_uwBikeParaRead[10];
  256. ass_stParaCong.uwAutoPowerOffTime = I2C_uwBikeParaRead[11];
  257. }
  258. else
  259. {}
  260. if (i2c_stRXCRCOut.blMControlParaFltFlg == FALSE)
  261. {
  262. cp_stFlg.ParaFirstSetFlg = I2C_uwMControlRead[0];
  263. cp_stFlg.SpiOffsetFirstSetFlg = I2C_uwMControlRead[1];
  264. spi_stResolverOut.swSpiThetaOffsetOrignPu = (SWORD)I2C_uwMControlRead[2];
  265. spi_stResolverOut.swSpiThetaOffsetPu = (SWORD)I2C_uwMControlRead[3];
  266. cp_stMotorPara.swIpeakMaxA = (SWORD)I2C_uwMControlRead[4];
  267. cp_stControlPara.swAlmOverCurrentVal = (SWORD)I2C_uwMControlRead[5];
  268. cp_stControlPara.swAlmOverVolVal3 = (SWORD)I2C_uwMControlRead[6];
  269. cp_stControlPara.swAlmUnderVolVal2 = (SWORD)I2C_uwMControlRead[7];
  270. cp_stControlPara.swAlmOverSpdVal = (SWORD)I2C_uwMControlRead[8];
  271. cp_stControlPara.swAlmOverHeatCeVal = (SWORD)I2C_uwMControlRead[9];
  272. cp_stControlPara.swAlmRecOHeatVal = (SWORD)I2C_uwMControlRead[10];
  273. cp_stControlPara.swAlmPwrLimitStartTempVal = (SWORD)I2C_uwMControlRead[11];
  274. }
  275. else
  276. {
  277. cp_stFlg.RunPermitFlg = FALSE;
  278. }
  279. if (i2c_stRXCRCOut.blSensorParaFltFlg == FALSE)
  280. {
  281. torsensor_stTorSensorCof.uwTorqueOffsetOrign = I2C_uwSensorRead[0];
  282. torsensor_stTorSensorCof.uwTorqueOffsetNow1 = I2C_uwSensorRead[1];
  283. torsensor_stTorSensorCof.uwTorqueOffsetNow2 = I2C_uwSensorRead[2];
  284. torsensor_stTorSensorCof.uwTorqueOffsetNow3 = I2C_uwSensorRead[3];
  285. torsensor_stTorSensorCof.uwTorqueOffsetNow4 = I2C_uwSensorRead[4];
  286. torsensor_stTorSensorCof.uwMaxSensorTorquePu = I2C_uwSensorRead[5];
  287. torsensor_stTorSensorCof.uwBikeTorStep1RealNm = I2C_uwSensorRead[6];
  288. torsensor_stTorSensorCof.uwBikeTorStep1ADC = I2C_uwSensorRead[7];
  289. torsensor_stTorSensorCof.uwBikeTorStep2RealNm = I2C_uwSensorRead[8];
  290. torsensor_stTorSensorCof.uwBikeTorStep2ADC = I2C_uwSensorRead[9];
  291. torsensor_stTorSensorCof.uwBikeTorStep3RealNm = I2C_uwSensorRead[10];
  292. torsensor_stTorSensorCof.uwBikeTorStep3ADC = I2C_uwSensorRead[11];
  293. torsensor_stTorSensorCof.uwBikeTorStep4RealNm = I2C_uwSensorRead[12];
  294. torsensor_stTorSensorCof.uwBikeTorStep4ADC = I2C_uwSensorRead[13];
  295. cadence_stFreGetCof.uwNumbersPulses = I2C_uwSensorRead[14];
  296. bikespeed_stFreGetCof.uwNumbersPulses = I2C_uwSensorRead[15];
  297. }
  298. else
  299. {
  300. cp_stFlg.RunPermitFlg = FALSE;
  301. }
  302. if (i2c_stRXCRCOut.blAssistParaFltFlg == FALSE)
  303. {
  304. ass_stParaSet.uwStartupCoef = I2C_uwAssistParaRead[0];
  305. ass_stParaSet.uwStartupCruiseCoef = I2C_uwAssistParaRead[1];
  306. ass_stParaSet.uwAssistStartNm = I2C_uwAssistParaRead[2];
  307. ass_stParaSet.uwAssistStopNm = I2C_uwAssistParaRead[3];
  308. ass_stParaSet.uwStartUpGainStep = I2C_uwAssistParaRead[4];
  309. ass_stParaSet.uwStartUpCadNm = I2C_uwAssistParaRead[5];
  310. ass_stParaSet.uwTorLPFCadNm = I2C_uwAssistParaRead[6];
  311. ass_stParaSet.uwSpeedAssistSpdRpm = I2C_uwAssistParaRead[7];
  312. ass_stParaSet.uwSpeedAssistIMaxA = I2C_uwAssistParaRead[8];
  313. ass_stParaSet.uwAssistLimitBikeSpdStart = I2C_uwAssistParaRead[9];
  314. ass_stParaSet.uwAssistLimitBikeSpdStop = I2C_uwAssistParaRead[10];
  315. ass_stParaSet.uwCadenceWeight = I2C_uwAssistParaRead[11];
  316. // ass_stParaSet.uwTorWeight = Q12_1 - ass_stParaSet.uwCadenceWeight;
  317. }
  318. else
  319. {}
  320. }
  321. cp_stFlg.ParaUseEEFinishFlg = TRUE;
  322. }
  323. else
  324. {}
  325. }
  326. /***************************************************************
  327. Function: mn_voParaUpdate;
  328. Description:update pra from upper PC
  329. Call by:
  330. Input Variables: N/A
  331. Output/Return Variables: N/A
  332. Subroutine Call: N/A;
  333. Reference: N/A
  334. ****************************************************************/
  335. void mn_voParaUpdate(void)
  336. {
  337. if (cp_stFlg.ParaMInfoUpdateFlg == TRUE)
  338. {
  339. cp_stMotorPara.swMotrPolePairs = (SWORD)MC_UpcInfo.stMotorInfo.uwPolePairs;
  340. cp_stMotorPara.swRsOhm = (SWORD)MC_UpcInfo.stMotorInfo.uwRsmOhm;
  341. cp_stMotorPara.swLdmH = (SWORD)MC_UpcInfo.stMotorInfo.uwLduH;
  342. cp_stMotorPara.swLqmH = (SWORD)MC_UpcInfo.stMotorInfo.uwLquH;
  343. cp_stMotorPara.swFluxWb = (SWORD)MC_UpcInfo.stMotorInfo.uwFluxmWb;
  344. cp_stMotorPara.swIdMaxA = (SWORD)MC_UpcInfo.stMotorInfo.uwIdMaxA;
  345. cp_stMotorPara.swIdMinA = (SWORD)MC_UpcInfo.stMotorInfo.uwIdMinA;
  346. cp_stMotorPara.swRSpeedRpm = (SWORD)MC_UpcInfo.stMotorInfo.uwRSpdRpm;
  347. cp_stMotorPara.swRPwrWt = (SWORD)MC_UpcInfo.stMotorInfo.uwRPwrWt;
  348. cp_stMotorPara.swRIarmsA = (SWORD)MC_UpcInfo.stMotorInfo.uwRCurA;
  349. cp_stMotorPara.swRUdcV = (SWORD)MC_UpcInfo.stMotorInfo.uwRVolV;
  350. cp_stMotorPara.swJD = (SWORD)MC_UpcInfo.stMotorInfo.uwJD;
  351. cp_stMotorPara.swTorMax = (SWORD)MC_UpcInfo.stMotorInfo.uwTorMaxNm;
  352. cp_stFlg.ParaMotorDriveUpdateFinishFlg = TRUE;
  353. cp_stFlg.ParaMInfoUpdateFlg = FALSE;
  354. }
  355. if (cp_stFlg.ParaBikeInfoUpdateFlg == TRUE)
  356. {
  357. ass_stParaCong.uwWheelPerimeter = MC_UpcInfo.stBikeInfo.uwWheelPerimeter;
  358. ass_stParaCong.uwMechRationMotor = MC_UpcInfo.stBikeInfo.uwMechRationMotor;
  359. ass_stParaCong.uwAssistMaxSpdKmH = MC_UpcInfo.stBikeInfo.uwAssistMaxSpdKmH;
  360. ass_stParaCong.uwThrottleMaxSpdKmH = MC_UpcInfo.stBikeInfo.uwThrottleMaxSpdKmH;
  361. ass_stParaCong.uwNmFrontChainring = MC_UpcInfo.stBikeInfo.uwNmFrontChainring;
  362. ass_stParaCong.uwNmBackChainring = MC_UpcInfo.stBikeInfo.uwNmBackChainring;
  363. ass_stParaCong.uwAssistSelect1 = MC_UpcInfo.stBikeInfo.uwAssistSelect1;
  364. ass_stParaCong.uwAssistSelect2 = MC_UpcInfo.stBikeInfo.uwAssistSelect2;
  365. ass_stParaCong.uwLightVoltage = MC_UpcInfo.stBikeInfo.uwLightVoltage;
  366. ass_stParaCong.swDeltPerimeter = MC_UpcInfo.stBikeInfo.swWheelSizeAdjust;
  367. ass_stParaCong.uwStartMode = MC_UpcInfo.stBikeInfo.uwStartMode;
  368. ass_stParaCong.uwAutoPowerOffTime = MC_UpcInfo.stBikeInfo.uwAutoPowerOffTime;
  369. cp_stFlg.ParaAssistUpdateFinishFlg = TRUE;
  370. cp_stFlg.ParaBikeInfoUpdateFlg = FALSE;
  371. }
  372. if (cp_stFlg.ParaMCInfoUpdateFlg == TRUE)
  373. {
  374. cp_stFlg.ParaFirstSetFlg = MC_UpcInfo.stTestParaInfo.uwEEFirstDefaultSetFlg;
  375. cp_stFlg.SpiOffsetFirstSetFlg = MC_UpcInfo.stTestParaInfo.uwSPIOffsetFirstSetFlg;
  376. spi_stResolverOut.swSpiThetaOffsetOrignPu = MC_UpcInfo.stMContorlInfo.uwSPIPosOffsetOrigin;
  377. spi_stResolverOut.swSpiThetaOffsetPu = MC_UpcInfo.stMContorlInfo.uwSPIPosOffsetNow;
  378. cp_stMotorPara.swIpeakMaxA = (SWORD)MC_UpcInfo.stMContorlInfo.uwIPeakMaxA;
  379. cp_stControlPara.swAlmOverCurrentVal = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamOCurA;
  380. cp_stControlPara.swAlmOverVolVal3 = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamOVolV;
  381. cp_stControlPara.swAlmUnderVolVal2 = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamUVolV;
  382. cp_stControlPara.swAlmOverSpdVal = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamOverSpdRpm;
  383. cp_stControlPara.swAlmOverHeatCeVal = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamOverHeatCe;
  384. cp_stControlPara.swAlmRecOHeatVal = (SWORD)MC_UpcInfo.stMContorlInfo.uwAlamRecHeatCe;
  385. cp_stControlPara.swAlmPwrLimitStartTempVal = (SWORD)MC_UpcInfo.stMContorlInfo.uwPwrLimitStartCe;
  386. cp_stFlg.ParaMotorDriveUpdateFinishFlg = TRUE;
  387. cp_stFlg.ParaMCInfoUpdateFlg = FALSE;
  388. }
  389. if (cp_stFlg.ParaSensorInfoUpdateFlg == TRUE)
  390. {
  391. torsensor_stTorSensorCof.uwTorqueOffsetOrign = MC_UpcInfo.stSensorInfo.uwTorSensorOffsetOrigin;
  392. torsensor_stTorSensorCof.uwMaxSensorTorquePu = MC_UpcInfo.stSensorInfo.uwBikeTorMaxNm;
  393. torsensor_stTorSensorCof.uwBikeTorStep1RealNm = MC_UpcInfo.stSensorInfo.uwBikeTor1StepRealNm;
  394. torsensor_stTorSensorCof.uwBikeTorStep1ADC = MC_UpcInfo.stSensorInfo.uwBikeTor1StepADC;
  395. torsensor_stTorSensorCof.uwBikeTorStep2RealNm = MC_UpcInfo.stSensorInfo.uwBikeTor2StepRealNm;
  396. torsensor_stTorSensorCof.uwBikeTorStep2ADC = MC_UpcInfo.stSensorInfo.uwBikeTor2StepADC;
  397. torsensor_stTorSensorCof.uwBikeTorStep3RealNm = MC_UpcInfo.stSensorInfo.uwBikeTor3StepRealNm;
  398. torsensor_stTorSensorCof.uwBikeTorStep3ADC = MC_UpcInfo.stSensorInfo.uwBikeTor3StepADC;
  399. torsensor_stTorSensorCof.uwBikeTorStep4RealNm = MC_UpcInfo.stSensorInfo.uwBikeTor4StepRealNm;
  400. torsensor_stTorSensorCof.uwBikeTorStep4ADC = MC_UpcInfo.stSensorInfo.uwBikeTor4StepADC;
  401. cadence_stFreGetCof.uwNumbersPulses = MC_UpcInfo.stSensorInfo.uwCadSensorPulseNm;
  402. bikespeed_stFreGetCof.uwNumbersPulses = MC_UpcInfo.stSensorInfo.uwBikeSpdSensorPulseNm;
  403. cp_stFlg.ParaAssistUpdateFinishFlg = TRUE;
  404. cp_stFlg.ParaSensorInfoUpdateFlg = FALSE;
  405. }
  406. if (cp_stFlg.ParaAInfoUpdateFlg == TRUE)
  407. {
  408. ass_stParaSet.uwStartupCoef = MC_UpcInfo.stAssistInfo.swStartupGain;
  409. ass_stParaSet.uwStartupCruiseCoef = MC_UpcInfo.stAssistInfo.swStartcruiseGain;
  410. ass_stParaSet.uwAssistStartNm = MC_UpcInfo.stAssistInfo.uwAssistStartNm;
  411. ass_stParaSet.uwAssistStopNm = MC_UpcInfo.stAssistInfo.uwAssistStopNm;
  412. ass_stParaSet.uwStartUpGainStep = MC_UpcInfo.stAssistInfo.uwStartUpGainStep;
  413. ass_stParaSet.uwStartUpCadNm = MC_UpcInfo.stAssistInfo.uwStartUpCadNm;
  414. ass_stParaSet.uwTorLPFCadNm = MC_UpcInfo.stAssistInfo.uwTorLPFCadNm;
  415. ass_stParaSet.uwSpeedAssistSpdRpm = MC_UpcInfo.stAssistInfo.uwSpeedAssistSpdRpm;
  416. ass_stParaSet.uwSpeedAssistIMaxA = MC_UpcInfo.stAssistInfo.uwSpeedAssistIMaxA;
  417. ass_stParaSet.uwAssistLimitBikeSpdStart = MC_UpcInfo.stAssistInfo.uwAssistLimitBikeSpdStart;
  418. ass_stParaSet.uwAssistLimitBikeSpdStop = MC_UpcInfo.stAssistInfo.uwAssistLimitBikeSpdStop;
  419. ass_stParaSet.uwCadenceWeight = MC_UpcInfo.stAssistInfo.uwCadenceAssistWeight;
  420. // ass_stParaSet.uwTorWeight = Q12_1 - ass_stParaSet.uwCadenceWeight;
  421. cp_stFlg.ParaAssistUpdateFinishFlg = TRUE;
  422. cp_stFlg.ParaAInfoUpdateFlg = FALSE;
  423. }
  424. if(cp_stFlg.TestParaInfoUpdateFlg == TRUE)
  425. {
  426. cp_stControlPara.swAlignCurAp = (SWORD)MC_UpcInfo.stTestParaInfo.uwInitPosCurAmp;
  427. cp_stControlPara.swDragVolAp = (SWORD)MC_UpcInfo.stTestParaInfo.uwVFControlVolAmp;
  428. cp_stControlPara.swDragCurAp = (SWORD)MC_UpcInfo.stTestParaInfo.uwIFControlCurAmp;
  429. cp_stControlPara.swDragSpdHz = (SWORD)MC_UpcInfo.stTestParaInfo.uwVFIFTargetFreHz;
  430. cp_stControlPara.swSpeedAccRate = (SWORD)MC_UpcInfo.stTestParaInfo.uwSpeedLoopAccRate;
  431. cp_stControlPara.swSpeedDccRate = (SWORD)MC_UpcInfo.stTestParaInfo.uwSpeedLoopDecRate;
  432. cp_stControlPara.swAsrPIBandwidth = (SWORD)MC_UpcInfo.stTestParaInfo.uwSpeedLoopBandWidthHz;
  433. cp_stControlPara.swAsrPIM = (SWORD)MC_UpcInfo.stTestParaInfo.uwSpeedLoopCoefM;
  434. cp_stControlPara.swAcrPIBandwidth = (SWORD)MC_UpcInfo.stTestParaInfo.uwCuerrentLoopBandWidthHz;
  435. cp_stControlPara.swAcrRaCoef = (SWORD)MC_UpcInfo.stTestParaInfo.uwCurrentLoopCoefM;
  436. cp_stControlPara.swObsFluxPICrossfreHz = (SWORD)MC_UpcInfo.stTestParaInfo.uwFluxObsBandWidthHz;
  437. cp_stControlPara.swObsFluxPIDampratio = (SWORD)MC_UpcInfo.stTestParaInfo.uwFluxObsCoefM;
  438. cp_stControlPara.swObsSpdPLLBandWidthHz = (SWORD)MC_UpcInfo.stTestParaInfo.uwThetaObsPLLBandWidthHz;
  439. cp_stControlPara.swObsSpdPLLM = (SWORD)MC_UpcInfo.stTestParaInfo.uwThetaObsPLLCoefM;
  440. cp_stMotorPara.swJD = (SWORD)MC_UpcInfo.stTestParaInfo.uwJm;
  441. cp_stControlPara.swPWMMaxDuty = (SWORD)MC_UpcInfo.stTestParaInfo.uwPWMMaxDuty;
  442. cp_stControlPara.swPWM7to5Duty = (SWORD)MC_UpcInfo.stTestParaInfo.uwPWM7to5Duty;
  443. cp_stControlPara.swPwrLimitValWt = (SWORD)MC_UpcInfo.stTestParaInfo.uwPwrLimit;
  444. cp_stControlPara.swPwrLimitErrWt =(SWORD) MC_UpcInfo.stTestParaInfo.uwPwrLimitError;
  445. cp_stControlPara.swPwrLimitKpPu = (SWORD)MC_UpcInfo.stTestParaInfo.uwPwrLimitKp;
  446. cp_stControlPara.swPwrLimitKiPu = (SWORD)MC_UpcInfo.stTestParaInfo.uwPwrLimitKi;
  447. cp_stFlg.ParaMotorDriveUpdateFinishFlg = TRUE;
  448. // cp_stFlg.TestParaInfoUpdateFlg = FALSE;
  449. }
  450. cp_stFlg.ParaUpdateFlg = FALSE;
  451. }
  452. /***************************************************************
  453. Function: mn_voSoftwareInit;
  454. Description:software intial
  455. Call by:
  456. Input Variables: N/A
  457. Output/Return Variables: N/A
  458. Subroutine Call: N/A;
  459. Reference: N/A
  460. ****************************************************************/
  461. void mn_voEEUperParaUpdate(void)
  462. {
  463. if (MC_UpcInfo.stMotorInfo.uwSaveFlg == TRUE)
  464. {
  465. Syspara2.stMotorPara.uwPolePairs.uwReal = (UWORD)cp_stMotorPara.swMotrPolePairs;
  466. Syspara2.stMotorPara.uwRsmOhm.uwReal = (UWORD)cp_stMotorPara.swRsOhm;
  467. Syspara2.stMotorPara.uwLduH.uwReal = (UWORD)cp_stMotorPara.swLdmH;
  468. Syspara2.stMotorPara.uwLquH.uwReal = (UWORD)cp_stMotorPara.swLqmH;
  469. Syspara2.stMotorPara.uwFluxmWb.uwReal = (UWORD)cp_stMotorPara.swFluxWb;
  470. Syspara2.stMotorPara.uwIdMaxA.uwReal = (UWORD)cp_stMotorPara.swIdMaxA;
  471. Syspara2.stMotorPara.uwIdMinA.uwReal = (UWORD)cp_stMotorPara.swIdMinA;
  472. Syspara2.stMotorPara.uwRSpdRpm.uwReal = (UWORD)cp_stMotorPara.swRSpeedRpm;
  473. Syspara2.stMotorPara.uwRPwrWt.uwReal = (UWORD)cp_stMotorPara.swRPwrWt;
  474. Syspara2.stMotorPara.uwRCurA.uwReal = (UWORD)cp_stMotorPara.swRIarmsA;
  475. Syspara2.stMotorPara.uwRVolV.uwReal = (UWORD)cp_stMotorPara.swRUdcV;
  476. Syspara2.stMotorPara.uwJD.uwReal = (UWORD)cp_stMotorPara.swJD;
  477. Syspara2.stMotorPara.uwTorMaxNm.uwReal = (UWORD)cp_stMotorPara.swTorMax;
  478. }
  479. Syspara2.stBikePara.swDeltPerimeter.swReal = ass_stParaCong.swDeltPerimeter;
  480. if (MC_UpcInfo.stBikeInfo.uwSaveFlg == TRUE)
  481. {
  482. Syspara2.stBikePara.uwWheelPerimeter.uwReal = ass_stParaCong.uwWheelPerimeter;
  483. Syspara2.stBikePara.uwMechRationMotor.uwReal = ass_stParaCong.uwMechRationMotor;
  484. Syspara2.stBikePara.uwAssistMaxSpdKmH.uwReal = ass_stParaCong.uwAssistMaxSpdKmH;
  485. Syspara2.stBikePara.uwThrottleMaxSpdKmH.uwReal = ass_stParaCong.uwThrottleMaxSpdKmH;
  486. Syspara2.stBikePara.uwNmFrontChainring.uwReal = ass_stParaCong.uwNmFrontChainring;
  487. Syspara2.stBikePara.uwNmBackChainring.uwReal = ass_stParaCong.uwNmBackChainring;
  488. Syspara2.stBikePara.uwAssistSelect1.uwReal = ass_stParaCong.uwAssistSelect1;
  489. Syspara2.stBikePara.uwAssistSelect2.uwReal = ass_stParaCong.uwAssistSelect2;
  490. Syspara2.stBikePara.uwLightVoltage.uwReal = ass_stParaCong.uwLightVoltage;
  491. Syspara2.stBikePara.swDeltPerimeter.swReal = ass_stParaCong.swDeltPerimeter;
  492. Syspara2.stBikePara.uwStartMode.uwReal = ass_stParaCong.uwStartMode;
  493. Syspara2.stBikePara.uwAutoPowerOffTime.uwReal = ass_stParaCong.uwAutoPowerOffTime;
  494. }
  495. if (MC_UpcInfo.stMContorlInfo.uwSaveFlg == TRUE)
  496. {
  497. Syspara2.stMControlPara.ParaFirstSetFlg.uwReal = cp_stFlg.ParaFirstSetFlg;
  498. Syspara2.stMControlPara.SpiOffsetFirstSetFlg.uwReal = cp_stFlg.SpiOffsetFirstSetFlg;
  499. Syspara2.stMControlPara.uwSPIPosOffsetOrigin.uwReal = spi_stResolverOut.swSpiThetaOffsetOrignPu;
  500. Syspara2.stMControlPara.uwSPIPosOffsetNow.uwReal = spi_stResolverOut.swSpiThetaOffsetPu;
  501. Syspara2.stMControlPara.uwIPeakMaxA.uwReal = (UWORD)cp_stMotorPara.swIpeakMaxA;
  502. Syspara2.stMControlPara.uwAlamOCurA.uwReal = (UWORD)cp_stControlPara.swAlmOverCurrentVal;
  503. Syspara2.stMControlPara.uwAlamOVolV.uwReal = (UWORD)cp_stControlPara.swAlmOverVolVal3;
  504. Syspara2.stMControlPara.uwAlamUVolV.uwReal = (UWORD)cp_stControlPara.swAlmUnderVolVal2;
  505. Syspara2.stMControlPara.uwAlamOverSpdRpm.uwReal = (UWORD)cp_stControlPara.swAlmOverSpdVal;
  506. Syspara2.stMControlPara.uwAlamOverHeatCe.uwReal = (UWORD)cp_stControlPara.swAlmOverHeatCeVal;
  507. Syspara2.stMControlPara.uwAlamRecHeatCe.uwReal = (UWORD)cp_stControlPara.swAlmRecOHeatVal;
  508. Syspara2.stMControlPara.uwPwrLimitStartCe.uwReal = (UWORD)cp_stControlPara.swAlmPwrLimitStartTempVal;
  509. }
  510. if (MC_UpcInfo.stSensorInfo.uwSaveFlg == TRUE)
  511. {
  512. Syspara2.stSensorPara.uwTorSensorOffsetOrigin.uwReal = torsensor_stTorSensorCof.uwTorqueOffsetOrign;
  513. Syspara2.stSensorPara.uwTorSensorOffsetNow1.uwReal = torsensor_stTorSensorCof.uwTorqueOffsetNow1;
  514. Syspara2.stSensorPara.uwTorSensorOffsetNow2.uwReal = torsensor_stTorSensorCof.uwTorqueOffsetNow2;
  515. Syspara2.stSensorPara.uwTorSensorOffsetNow3.uwReal = torsensor_stTorSensorCof.uwTorqueOffsetNow3;
  516. Syspara2.stSensorPara.uwTorSensorOffsetNow4.uwReal = torsensor_stTorSensorCof.uwTorqueOffsetNow4;
  517. Syspara2.stSensorPara.uwBikeTorMaxNm.uwReal = torsensor_stTorSensorCof.uwMaxSensorTorquePu;
  518. Syspara2.stSensorPara.uwBikeTor1StepRealNm.uwReal = torsensor_stTorSensorCof.uwBikeTorStep1RealNm;
  519. Syspara2.stSensorPara.uwBikeTor1StepADC.uwReal = torsensor_stTorSensorCof.uwBikeTorStep1ADC;
  520. Syspara2.stSensorPara.uwBikeTor2StepRealNm.uwReal = torsensor_stTorSensorCof.uwBikeTorStep2RealNm;
  521. Syspara2.stSensorPara.uwBikeTor2StepADC.uwReal = torsensor_stTorSensorCof.uwBikeTorStep2ADC;
  522. Syspara2.stSensorPara.uwBikeTor3StepRealNm.uwReal = torsensor_stTorSensorCof.uwBikeTorStep3RealNm;
  523. Syspara2.stSensorPara.uwBikeTor3StepADC.uwReal = torsensor_stTorSensorCof.uwBikeTorStep3ADC;
  524. Syspara2.stSensorPara.uwBikeTor4StepRealNm.uwReal = torsensor_stTorSensorCof.uwBikeTorStep4RealNm;
  525. Syspara2.stSensorPara.uwBikeTor4StepADC.uwReal = torsensor_stTorSensorCof.uwBikeTorStep4ADC;
  526. Syspara2.stSensorPara.uwCadSensorPulseNm.uwReal = cadence_stFreGetCof.uwNumbersPulses;
  527. Syspara2.stSensorPara.uwBikeSpdSensorPulseNm.uwReal = bikespeed_stFreGetCof.uwNumbersPulses;
  528. }
  529. if (MC_UpcInfo.stAssistInfo.uwSaveFlg == TRUE)
  530. {
  531. Syspara2.stAssistPara.uwStartupGain.uwReal = ass_stParaSet.uwStartupCoef;
  532. Syspara2.stAssistPara.uwStartcruiseGain.uwReal = ass_stParaSet.uwStartupCruiseCoef;
  533. Syspara2.stAssistPara.uwAssistStartNm.uwReal = ass_stParaSet.uwAssistStartNm;
  534. Syspara2.stAssistPara.uwAssistStopNm.uwReal = ass_stParaSet.uwAssistStopNm;
  535. Syspara2.stAssistPara.uwStartUpGainStep.uwReal = ass_stParaSet.uwStartUpGainStep;
  536. Syspara2.stAssistPara.uwStartUpCadNm.uwReal = ass_stParaSet.uwStartUpCadNm;
  537. Syspara2.stAssistPara.uwTorLPFCadNm.uwReal = ass_stParaSet.uwTorLPFCadNm;
  538. Syspara2.stAssistPara.uwSpeedAssistSpdRpm.uwReal = ass_stParaSet.uwSpeedAssistSpdRpm;
  539. Syspara2.stAssistPara.uwSpeedAssistIMaxA.uwReal = ass_stParaSet.uwSpeedAssistIMaxA;
  540. Syspara2.stAssistPara.uwAssistLimitBikeSpdStart.uwReal = ass_stParaSet.uwAssistLimitBikeSpdStart;
  541. Syspara2.stAssistPara.uwAssistLimitBikeSpdStop.uwReal = ass_stParaSet.uwAssistLimitBikeSpdStop;
  542. Syspara2.stAssistPara.uwCadenceAssistWeight.uwReal = ass_stParaSet.uwCadenceWeight;
  543. }
  544. }
  545. /***************************************************************
  546. Function: mn_voSoftwareInit;
  547. Description:software intial
  548. Call by:
  549. Input Variables: N/A
  550. Output/Return Variables: N/A
  551. Subroutine Call: N/A;
  552. Reference: N/A
  553. ****************************************************************/
  554. void mn_voEEHistoryParaUpdate(void)
  555. {
  556. Syspara2.stHistoryPara.uwAssModSelect.uwReal = ass_stParaSet.uwAsssistSelectNum;
  557. Syspara2.stHistoryPara.uwOpenTimes.uwReal = cp_stHistoryPara.uwOpenTimes;
  558. Syspara2.stHistoryPara.uwUsedTimeH.uwReal = (UWORD)(cp_stHistoryPara.ulUsedTime >> 16);
  559. Syspara2.stHistoryPara.uwUsedTimeL.uwReal = (UWORD)cp_stHistoryPara.ulUsedTime;
  560. Syspara2.stHistoryPara.uwNTCTempMaxCe.uwReal = cp_stHistoryPara.uwNTCTempMaxCe;
  561. Syspara2.stHistoryPara.uwNTCTempMinCe.uwReal = cp_stHistoryPara.uwNTCTempMinCe;
  562. Syspara2.stHistoryPara.uwAlamHOcurTimes.uwReal = cp_stHistoryPara.uwAlamHOcurTimes;
  563. Syspara2.stHistoryPara.uwAlamSOcurTimes.uwReal = cp_stHistoryPara.uwAlamSOcurTimes;
  564. Syspara2.stHistoryPara.uwAlamOHeatTimes.uwReal = cp_stHistoryPara.uwAlamOHeatTimes;
  565. Syspara2.stHistoryPara.uwAlamRotorLockTimes.uwReal = cp_stHistoryPara.uwAlamRotorLockTimes;
  566. Syspara2.stHistoryPara.uwAlamPhsLossTimes.uwReal = cp_stHistoryPara.uwAlamPhsLossTimes;
  567. Syspara2.stHistoryPara.uwAlamOVolTimes.uwReal = cp_stHistoryPara.uwAlamOVolTimes;
  568. Syspara2.stHistoryPara.uwAlamUVolTimes.uwReal = cp_stHistoryPara.uwAlamUVolTimes;
  569. Syspara2.stHistoryPara.uwAlamComOTimeTimes.uwReal = cp_stHistoryPara.uwAlamComOTimeTimes;
  570. Syspara2.stHistoryPara.uwG1AvgPwrConsumption.uwReal = cp_stHistoryPara.uwG1AvgPwrConsumption;
  571. Syspara2.stHistoryPara.uwG2AvgPwrConsumption.uwReal = cp_stHistoryPara.uwG2AvgPwrConsumption;
  572. Syspara2.stHistoryPara.uwG3AvgPwrConsumption.uwReal = cp_stHistoryPara.uwG3AvgPwrConsumption;
  573. Syspara2.stHistoryPara.uwG4AvgPwrConsumption.uwReal = cp_stHistoryPara.uwG4AvgPwrConsumption;
  574. Syspara2.stHistoryPara.uwG5AvgPwrConsumption.uwReal = cp_stHistoryPara.uwG5AvgPwrConsumption;
  575. Syspara2.stHistoryPara.uwODOTripH.uwReal = (UWORD)(cp_stHistoryPara.ulODOTrip >> 16);
  576. Syspara2.stHistoryPara.uwODOTripL.uwReal = (UWORD)cp_stHistoryPara.ulODOTrip;
  577. Syspara2.stHistoryPara.uwODOTimeH.uwReal = (UWORD)(cp_stHistoryPara.ulODOTime >> 16);
  578. Syspara2.stHistoryPara.uwODOTimeL.uwReal = (UWORD)cp_stHistoryPara.ulODOTime;
  579. Syspara2.stHistoryPara.uwTripSumH.uwReal = (UWORD)(cp_stHistoryPara.ulTripSum >> 16);
  580. Syspara2.stHistoryPara.uwTripSumL.uwReal = (UWORD)cp_stHistoryPara.ulTripSum;
  581. Syspara2.stHistoryPara.uwTripSumTimeH.uwReal = (UWORD)(cp_stHistoryPara.ulTripSumTime >> 16);
  582. Syspara2.stHistoryPara.uwTripSumTimeL.uwReal = (UWORD)cp_stHistoryPara.ulTripSumTime;
  583. Syspara2.stHistoryPara.uwTorSensorAlamTimes.uwReal = cp_stHistoryPara.uwTorSensorAlamTimes;
  584. Syspara2.stHistoryPara.uwCadSensorAlamTimes.uwReal = cp_stHistoryPara.uwCadSensorAlamTimes;
  585. Syspara2.stHistoryPara.uwBikeSpdSensorAlamTimes.uwReal = cp_stHistoryPara.uwBikeSpdSensorAlamTimes;
  586. Syspara2.stHistoryPara.uwPosSensorAlamTimes.uwReal = cp_stHistoryPara.uwPosSensorAlamTimes;
  587. }
  588. /***************************************************************
  589. Function: mn_voSoftwareInit;
  590. Description:software intial
  591. Call by:
  592. Input Variables: N/A
  593. Output/Return Variables: N/A
  594. Subroutine Call: N/A;
  595. Reference: N/A
  596. ****************************************************************/
  597. void mn_voSoftwareInit(void)
  598. {
  599. /* System coefficient calculate */
  600. cof_voSysInit();
  601. /* Api App Init*/
  602. AppInit();
  603. /* Control Parameters init */
  604. mn_voMcParInit();
  605. /*cmd handle Initial */
  606. cmd_voCmdInit();
  607. /* FSM init */
  608. FSM_voInit();
  609. RUN_FSM_voInit();
  610. Switch_speed_FSMInit();
  611. /* TempInit */
  612. TempInit();
  613. /* CANInit */
  614. Can_voInitMC_Run();
  615. /* Alarm init */
  616. alm_voInit();
  617. alm_voCoef();
  618. /* ADC init */
  619. adc_voSampleInit();
  620. adc_voSampleCoef(&adc_stCof);
  621. /* UART init */
  622. // uart_voApplInit();
  623. uart_voMonitorInit();
  624. }
  625. /************************************************************************
  626. Function: void mn_voMtParInit(void)
  627. Description:
  628. Call by:
  629. Input Variables:
  630. Output/Return Variables:
  631. Subroutine Call:
  632. Reference:
  633. ************************************************************************/
  634. void mn_voMtParInit(void)
  635. {
  636. mn_swIdTurn1Pu = (SWORD)(((SLONG)M_LD_TURN1_ID_AP << 14) / (SWORD)cof_uwIbAp); // Q14, saturation current of Ld
  637. mn_slLdTurn1Pu = ((SLONG)M_LD_TURN1_LD_MH << 10) / cof_uwLbHm; // Q10, saturation inductance of Ld
  638. mn_swIdTurn2Pu = (SWORD)(((SLONG)M_LD_TURN2_ID_AP << 14) / (SWORD)cof_uwIbAp); // Q14, saturation current of Ld
  639. mn_slLdTurn2Pu = ((SLONG)M_LD_TURN2_LD_MH << 10) / cof_uwLbHm; // Q10, saturation inductance of Ld
  640. if (mn_swIdTurn1Pu == mn_swIdTurn2Pu)
  641. {
  642. mn_swKLdSat = 0;
  643. }
  644. else
  645. {
  646. mn_swKLdSat = (SWORD)(((mn_slLdTurn2Pu - mn_slLdTurn1Pu) << 10) / (mn_swIdTurn2Pu - mn_swIdTurn1Pu)); // Q10
  647. }
  648. mn_swIqTurn1Pu = (SWORD)(((SLONG)M_LQ_TURN1_IQ_AP << 14) / (SWORD)cof_uwIbAp); // Q14, saturation current of Lq
  649. mn_slLqTurn1Pu = ((SLONG)M_LQ_TURN1_LQ_MH << 10) / cof_uwLbHm; // Q10, saturation inductance of Lq
  650. mn_swIqTurn2Pu = (SWORD)(((SLONG)M_LQ_TURN2_IQ_AP << 14) / (SWORD)cof_uwIbAp); // Q14, saturation current of Lq
  651. mn_slLqTurn2Pu = ((SLONG)M_LQ_TURN2_LQ_MH << 10) / cof_uwLbHm; // Q10, saturation inductance of Lq
  652. if (mn_swIqTurn1Pu == mn_swIqTurn2Pu)
  653. {
  654. mn_swKLqSat = 0;
  655. }
  656. else
  657. {
  658. mn_swKLqSat = (SWORD)(((mn_slLqTurn2Pu - mn_slLqTurn1Pu) << 10) / (mn_swIqTurn2Pu - mn_swIqTurn1Pu)); // Q10
  659. }
  660. }
  661. /************************************************************************
  662. Function: void mn_voMcParInit(void)
  663. Description:
  664. Call by:
  665. Input Variables:
  666. Output/Return Variables:
  667. Subroutine Call:
  668. Reference:
  669. ************************************************************************/
  670. void mn_voMcParInit(void)
  671. {
  672. align_voInit();
  673. /* Align Parameters */
  674. mn_uwAlignCurPu =(UWORD) CUR_AP2PU(cp_stControlPara.swAlignCurAp); // Q14
  675. mn_ulAlignRampTbcCt = TBC_MS2CT(cp_stControlPara.swAlignRampTMms);
  676. mn_ulAlignHoldTbcCt = TBC_MS2CT(cp_stControlPara.swAlignHoldTMms);
  677. if (mn_ulAlignRampTbcCt == 0)
  678. {
  679. mn_ulAlignCurIncPerTbcPu = 1;
  680. }
  681. else
  682. {
  683. mn_ulAlignCurIncPerTbcPu = ((ULONG)mn_uwAlignCurPu << 15) / mn_ulAlignRampTbcCt; // Q29
  684. if (mn_ulAlignCurIncPerTbcPu == 0)
  685. {
  686. mn_ulAlignCurIncPerTbcPu = 1;
  687. }
  688. }
  689. mn_slAlignAngInit = ANG_DEG2PU(cp_stControlPara.swAlignAngInitDeg);
  690. /* Open Drag Parameters */
  691. mn_uwDragCurPu = (UWORD)CUR_AP2PU(cp_stControlPara.swDragCurAp); // Q14
  692. mn_swDragSpdPu = (SWORD)SPD_HZ2PU(cp_stControlPara.swDragSpdHz); // Q15
  693. mn_ulDragSpdRampTbcCt = TBC_MS2CT(cp_stControlPara.swDragSpdRampTMms);
  694. if (mn_ulDragSpdRampTbcCt == 0)
  695. {
  696. mn_ulDragSpdIncPerTbcPu = 1;
  697. }
  698. else
  699. {
  700. mn_ulDragSpdIncPerTbcPu = ((ULONG)mn_swDragSpdPu << 14) / mn_ulDragSpdRampTbcCt; // Q29
  701. if (mn_ulDragSpdIncPerTbcPu == 0)
  702. {
  703. mn_ulDragSpdIncPerTbcPu = 1;
  704. }
  705. }
  706. // Open to Close Parameters
  707. mn_ulOpen2ClzCurRampTbcCt = TBC_MS2CT(cp_stControlPara.swOpen2ClzRampTMms);
  708. if (mn_ulOpen2ClzCurRampTbcCt == 0)
  709. {
  710. mn_ulOpen2ClzCurIncPerTbcPu = 1;
  711. }
  712. else
  713. {
  714. mn_ulOpen2ClzCurIncPerTbcPu = (ULONG)mn_uwDragCurPu / mn_ulOpen2ClzCurRampTbcCt;
  715. if (mn_ulOpen2ClzCurIncPerTbcPu == 0)
  716. {
  717. mn_ulOpen2ClzCurIncPerTbcPu = 1;
  718. }
  719. }
  720. // Stop Parameters
  721. mn_swStopSpdRefPu = (SWORD)SPD_RPM2PU(cp_stControlPara.swStopSpdRefRpm);
  722. }
  723. /***************************************************************
  724. Function: mn_voIPMSeletion;
  725. Description:software intial
  726. Call by:
  727. Input Variables: N/A
  728. Output/Return Variables: N/A
  729. Subroutine Call: N/A;
  730. Reference: N/A
  731. ****************************************************************/
  732. // void mn_voIPMSelection(void)
  733. // {
  734. // //Dead band time and Turn on/off time
  735. // hw_uwPwmDeadBandTmNs = cp_stControlPara.swIPMDeadTimeNs;
  736. // mn_uwIpmDeadBandTmNs = cp_stControlPara.swIPMDeadTimeNs;
  737. // mn_uwIpmTurnOnTmNs = cp_stControlPara.swIPMTurnOnNs;
  738. // mn_uwIpmTurnOffTmNs = cp_stControlPara.swIPMTurnOffNs;
  739. // //HVIC charge parameters
  740. // mn_ulHvicChrgTmTbcCt = EVENT1MS_MS2CT(cp_stControlPara.swIPMHvicChrgMs);
  741. // //Max duty cyle
  742. // mn_uwPwmMaxDutyCyle = cp_stControlPara.swPWMMaxDuty;
  743. // mn_uwPwm7SvmTo5SvmDuty = cp_stControlPara.swPWM7to5Duty;
  744. // mn_uwPWMMinSample1Pu = cp_stControlPara.swPWMMinSampleDuty1;
  745. // mn_uwPWMMinSample2Pu = cp_stControlPara.swPWMMinSampleDuty2;
  746. // mn_uwFlxMaxDutyCyle = cp_stControlPara.swFwPWMMaxDuty;
  747. // //Current sample parameters
  748. // pwm_sw1stCurSmplCt = cp_stControlPara.swPWM1STSampleCnt;
  749. // pwm_sw2ndCurSmplCt = cp_stControlPara.swPWM2NDSampleCnt;
  750. // pwm_swMinDoubleCurSmplPu = (cp_stControlPara.swPWMMinEffVectorPu << 1);
  751. // pwm_swMinCurSmplCt = cp_stControlPara.swPWMMinEffVectorCnt;
  752. // pwm_swMinCurSmplPu = cp_stControlPara.swPWMMinEffVectorPu;
  753. // }
  754. /*************************************************************************
  755. Copyright (c) 2018 Welling Motor Technology(Shanghai) Co. Ltd.
  756. All rights reserved.
  757. *************************************************************************/
  758. #ifdef _MAIN_C_
  759. #undef _MAIN_C_ /* parasoft-suppress MISRA2004-19_6 "本项目无法更改,后续避免使用" */
  760. #endif
  761. /*************************************************************************
  762. End of this File (EOF)!
  763. Do not put anything after this part!
  764. *************************************************************************/