adc.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  1. #include "bsp/bsp_driver.h"
  2. #include "libs/utils.h"
  3. #include "os/os_task.h"
  4. #include "libs/logger.h"
  5. #include "math/fast_math.h"
  6. #if (CONFIG_HW_VERSION==3)
  7. #define ADC01_NUM (8)
  8. #define VBUS_V_BUFF_IDX 0
  9. #define ACC_V_BUFF_IDX 2
  10. #define VBUS_I_BUFF_IDX 4
  11. #define V_VOL_BUFF_IDX 6
  12. #define THROTTLE_5V_BUFF_IDX 8
  13. //zero chan 10
  14. #define VREF_BUFF_IDX 12
  15. #define VREF5v_BUFF_IDX 14
  16. #define MOS_TEMP_BUFF_IDX 1
  17. #define MOTOR_TEMP_BUFF_IDX 3
  18. //zero 5
  19. #define THROTTLE_BUFF_IDX 7
  20. #define THROTTLE2_BUFF_IDX 9
  21. #define U_VOL_BUFF_IDX 11
  22. #define W_VOL_BUFF_IDX 13
  23. //zero 15
  24. #define REG_CHAN_NUM (ADC01_NUM + ADC01_NUM)
  25. #define ADC_DUAL_MODE ADC_DAUL_REGULAL_PARALLEL_INSERTED_PARALLEL
  26. #endif
  27. u16 adc_buffer[REG_CHAN_NUM];
  28. float vref_adc = 1408.0f;
  29. float vref_5v_adc = 2047.0f;
  30. #define VREF_ADC_DATA 1509.0F //1498, 1.21/3.3*4095
  31. static void adc01_dma_init(void)
  32. {
  33. DMA_InitType DMA_InitStructure;
  34. rcu_ahb_periph_clock_enable(RCU_DMA1);
  35. DMA_DeInit(DMA1_CH1);
  36. DMA_InitStructure.PeriphAddr = (uint32_t)&ADC1->DAT;
  37. DMA_InitStructure.MemAddr = (uint32_t)adc_buffer;
  38. DMA_InitStructure.Direction = DMA_DIR_PERIPH_SRC;
  39. DMA_InitStructure.BufSize = REG_CHAN_NUM/2;
  40. DMA_InitStructure.PeriphInc = DMA_PERIPH_INC_DISABLE;
  41. DMA_InitStructure.DMA_MemoryInc = DMA_MEM_INC_ENABLE;
  42. DMA_InitStructure.PeriphDataSize = DMA_PERIPH_DATA_SIZE_WORD;
  43. DMA_InitStructure.MemDataSize = DMA_MemoryDataSize_Word;
  44. DMA_InitStructure.CircularMode = DMA_MODE_CIRCULAR;
  45. DMA_InitStructure.Priority = DMA_PRIORITY_HIGH;
  46. DMA_InitStructure.Mem2Mem = DMA_M2M_DISABLE;
  47. DMA_Init(DMA1_CH1, &DMA_InitStructure);
  48. /* Enable DMA1 Channel1 */
  49. DMA_EnableChannel(DMA1_CH1, ENABLE);
  50. }
  51. static void adc01_init(void) {
  52. ADC_InitType ADC_InitStructure;
  53. /* config ADC clock */
  54. RCC_ConfigAdcHclk(RCC_ADCHCLK_DIV4);
  55. rcu_ahb_periph_clock_enable(RCU_ADC1);
  56. rcu_ahb_periph_clock_enable(RCU_ADC2);
  57. ADC_DeInit(ADC1);
  58. ADC_DeInit(ADC2);
  59. //ADC1 and ADC2 configuration
  60. ADC_InitStruct(&ADC_InitStructure);
  61. ADC_InitStructure.WorkMode = ADC_WORKMODE_REG_INJECT_SIMULT;
  62. ADC_InitStructure.MultiChEn = ENABLE;
  63. ADC_InitStructure.ContinueConvEn = ENABLE;
  64. ADC_InitStructure.ExtTrigSelect = ADC_EXT_TRIG_INJ_CONV_T1_CC4 | ADC_EXT_TRIGCONV_NONE; //inject trigger T1CC4, regular trigger software
  65. ADC_InitStructure.DatAlign = ADC_DAT_ALIGN_R;
  66. ADC_InitStructure.ChsNumber = ADC01_NUM;
  67. ADC_Init(ADC1, &ADC_InitStructure);
  68. ADC_Init(ADC2, &ADC_InitStructure);
  69. //Config Sampling Time
  70. ADC_ConfigInjectedSequencerLength(ADC1,INJ_CHAN_NUM);
  71. ADC_ConfigInjectedChannel(ADC1, V_PHASE_I_CHAN, 1, ADC_INJ_SAMPLE_TIME);
  72. #if (INJ_CHAN_NUM == 4)
  73. ADC_ConfigInjectedChannel(ADC1, V_PHASE_I_CHAN, 2, ADC_INJ_SAMPLE_TIME);
  74. ADC_ConfigInjectedChannel(ADC1, V_PHASE_I_CHAN, 3, ADC_INJ_SAMPLE_TIME);
  75. ADC_ConfigInjectedChannel(ADC1, V_PHASE_I_CHAN, 4, ADC_INJ_SAMPLE_TIME);
  76. #endif
  77. ADC_ConfigInjectedSequencerLength(ADC2,INJ_CHAN_NUM);
  78. ADC_ConfigInjectedChannel(ADC2, W_PHASE_I_CHAN, 1, ADC_INJ_SAMPLE_TIME);
  79. #if (INJ_CHAN_NUM == 4)
  80. ADC_ConfigInjectedChannel(ADC2, W_PHASE_I_CHAN, 2, ADC_INJ_SAMPLE_TIME);
  81. ADC_ConfigInjectedChannel(ADC2, W_PHASE_I_CHAN, 3, ADC_INJ_SAMPLE_TIME);
  82. ADC_ConfigInjectedChannel(ADC2, W_PHASE_I_CHAN, 4, ADC_INJ_SAMPLE_TIME);
  83. #endif
  84. //ADC1 and ADC2 TrigInJectConv Enable
  85. ADC_EnableExternalTrigInjectedConv(ADC1,ENABLE);
  86. ADC_EnableExternalTrigInjectedConv(ADC2,ENABLE);
  87. ADC_ConfigRegularChannel(ADC1, VBUS_V_CHAN, 1, ADC_REGCHAN_SAMPLE_TIME);
  88. ADC_ConfigRegularChannel(ADC1, ACC_V_CHAN, 2, ADC_REGCHAN_SAMPLE_TIME);
  89. ADC_ConfigRegularChannel(ADC1, VBUS_I_CHAN, 3, ADC_REGCHAN_SAMPLE_TIME);
  90. ADC_ConfigRegularChannel(ADC1, V_VOL_ADC_CHAN, 4, ADC_REGCHAN_SAMPLE_TIME);
  91. ADC_ConfigRegularChannel(ADC1, THROTTLE_5V_CHAN, 5, ADC_REGCHAN_SAMPLE_TIME);
  92. ADC_ConfigRegularChannel(ADC1, ZERO_ADC_CHAN, 6, ADC_REGCHAN_SAMPLE_TIME);
  93. ADC_ConfigRegularChannel(ADC1, ADC_CH_INT_VREF, 7, ADC_REGCHAN_SAMPLE_TIME);
  94. ADC_ConfigRegularChannel(ADC1, DC5V_ADC_CHAN, 8, ADC_REGCHAN_SAMPLE_TIME);
  95. ADC_EnableExternalTrigConv(ADC1, ENABLE);
  96. ADC_ConfigRegularChannel(ADC2, MOS_TEMP_ADC_CHAN, 1, ADC_REGCHAN_SAMPLE_TIME);
  97. ADC_ConfigRegularChannel(ADC2, MOTOR_TEMP_ADC_CHAN, 2, ADC_REGCHAN_SAMPLE_TIME);
  98. ADC_ConfigRegularChannel(ADC2, ZERO_ADC_CHAN, 3, ADC_REGCHAN_SAMPLE_TIME);
  99. ADC_ConfigRegularChannel(ADC2, THROTTLE_CHAN, 4, ADC_REGCHAN_SAMPLE_TIME);
  100. ADC_ConfigRegularChannel(ADC2, THROTTLE2_CHAN, 5, ADC_REGCHAN_SAMPLE_TIME);
  101. ADC_ConfigRegularChannel(ADC2, U_VOL_ADC_CHAN, 6, ADC_REGCHAN_SAMPLE_TIME);
  102. ADC_ConfigRegularChannel(ADC2, W_VOL_ADC_CHAN, 7, ADC_REGCHAN_SAMPLE_TIME); //adc12
  103. ADC_ConfigRegularChannel(ADC2, ZERO_ADC_CHAN, 8, ADC_REGCHAN_SAMPLE_TIME);
  104. ADC_EnableExternalTrigConv(ADC2, ENABLE);
  105. /* Enable Vrefint channel17 */
  106. ADC_EnableTempSensorVrefint(ENABLE);
  107. ADC_EnableDMA(ADC1, ENABLE);
  108. /* Enable ADC1 */
  109. ADC_Enable(ADC1, ENABLE);
  110. /*Check ADC Ready*/
  111. while(ADC_GetFlagStatusNew(ADC1,ADC_FLAG_RDY) == RESET)
  112. ;
  113. /* Start ADC1 calibration */
  114. ADC_StartCalibration(ADC1);
  115. /* Check the end of ADC1 calibration */
  116. while (ADC_GetCalibrationStatus(ADC1))
  117. ;
  118. /* Enable ADC2 */
  119. ADC_Enable(ADC2, ENABLE);
  120. /*Check ADC Ready*/
  121. while(ADC_GetFlagStatusNew(ADC2,ADC_FLAG_RDY) == RESET)
  122. ;
  123. /* Start ADC2 calibration */
  124. ADC_StartCalibration(ADC2);
  125. /* Check the end of ADC2 calibration */
  126. while (ADC_GetCalibrationStatus(ADC2))
  127. ;
  128. adc_disable_ext_trigger();
  129. nvic_irq_enable(ADC1_2_IRQn, ADC_IRQ_PRIORITY, 0);
  130. /* Start ADC1 Software Conversion */
  131. ADC_EnableSoftwareStartConv(ADC1, ENABLE);
  132. }
  133. static void adc_gpio_init(void) {
  134. rcu_apb2_periph_clock_enable(RCU_AF);
  135. /* configure ADC pin, current sampling -- ADC_IN1(PA1) ADC_IN12(PC2) ADC_IN13(PC3) */
  136. #ifdef U_PHASE_ADC_GROUP
  137. rcu_apb2_periph_clock_enable(U_PHASE_ADC_RCU);
  138. gpio_init(U_PHASE_ADC_GROUP, U_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, U_PHASE_ADC_PIN);
  139. #endif
  140. #ifdef V_PHASE_ADC_GROUP
  141. rcu_apb2_periph_clock_enable(V_PHASE_ADC_RCU);
  142. gpio_init(V_PHASE_ADC_GROUP, V_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, V_PHASE_ADC_PIN);
  143. #endif
  144. #ifdef W_PHASE_ADC_GROUP
  145. rcu_apb2_periph_clock_enable(W_PHASE_ADC_RCU);
  146. gpio_init(W_PHASE_ADC_GROUP, W_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, W_PHASE_ADC_PIN);
  147. #endif
  148. #ifdef VBUS_V_ADC_GROUP
  149. rcu_apb2_periph_clock_enable(VBUS_V_ADC_RCU);
  150. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  151. gpio_init(VBUS_V_ADC_GROUP, VBUS_V_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_V_ADC_PIN);
  152. #endif
  153. #ifdef VBUS_I_ADC_GROUP
  154. rcu_apb2_periph_clock_enable(VBUS_I_ADC_RCU);
  155. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  156. gpio_init(VBUS_I_ADC_GROUP, VBUS_I_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_I_ADC_PIN);
  157. #endif
  158. #ifdef ACC_V_ADC_GROUP
  159. rcu_apb2_periph_clock_enable(ACC_V_ADC_RCU);
  160. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  161. gpio_init(ACC_V_ADC_GROUP, ACC_V_ADC_MODE, GPIO_OSPEED_50MHZ, ACC_V_ADC_PIN);
  162. #endif
  163. #ifdef THROTTLE_V_ADC_GROUP
  164. rcu_apb2_periph_clock_enable(THROTTLE_V_ADC_RCU);
  165. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  166. gpio_init(THROTTLE_V_ADC_GROUP, THROTTLE_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_V_ADC_PIN);
  167. #endif
  168. #ifdef THROTTLE2_V_ADC_GROUP
  169. rcu_apb2_periph_clock_enable(THROTTLE2_V_ADC_RCU);
  170. gpio_init(THROTTLE2_V_ADC_GROUP, THROTTLE2_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_V_ADC_PIN);
  171. #endif
  172. #ifdef THROTTLE_5V_ADC_GROUP
  173. rcu_apb2_periph_clock_enable(THROTTLE_5V_ADC_RCU);
  174. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  175. gpio_init(THROTTLE_5V_ADC_GROUP, THROTTLE_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_5V_ADC_PIN);
  176. #endif
  177. #ifdef THROTTLE2_5V_ADC_GROUP
  178. rcu_apb2_periph_clock_enable(THROTTLE2_5V_ADC_RCU);
  179. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  180. gpio_init(THROTTLE2_5V_ADC_GROUP, THROTTLE2_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_5V_ADC_PIN);
  181. #endif
  182. #ifdef U_VOL_ADC_GROUP
  183. rcu_apb2_periph_clock_enable(U_VOL_ADC_RCU);
  184. gpio_init(U_VOL_ADC_GROUP, U_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, U_VOL_ADC_PIN);
  185. #endif
  186. #ifdef V_VOL_ADC_GROUP
  187. rcu_apb2_periph_clock_enable(V_VOL_ADC_RCU);
  188. gpio_init(V_VOL_ADC_GROUP, V_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, V_VOL_ADC_PIN);
  189. #endif
  190. #ifdef W_VOL_ADC_GROUP
  191. rcu_apb2_periph_clock_enable(W_VOL_ADC_RCU);
  192. gpio_init(W_VOL_ADC_GROUP, W_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, W_VOL_ADC_PIN);
  193. #endif
  194. #ifdef MOS_TEMP_ADC_GROUP
  195. rcu_apb2_periph_clock_enable(MOS_TEMP_ADC_RCU);
  196. gpio_init(MOS_TEMP_ADC_GROUP, MOS_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP_ADC_PIN);
  197. #endif
  198. #ifdef MOS_TEMP1_ADC_GROUP
  199. rcu_apb2_periph_clock_enable(MOS_TEMP1_ADC_RCU);
  200. gpio_init(MOS_TEMP1_ADC_GROUP, MOS_TEMP1_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP1_ADC_PIN);
  201. #endif
  202. #ifdef MOTOR_TEMP_ADC_GROUP
  203. rcu_apb2_periph_clock_enable(MOTOR_TEMP_ADC_RCU);
  204. gpio_init(MOTOR_TEMP_ADC_GROUP, MOTOR_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOTOR_TEMP_ADC_PIN);
  205. #endif
  206. #ifdef ZERO_ADC_GROUP
  207. rcu_apb2_periph_clock_enable(ZERO_ADC_RCU);
  208. gpio_init(ZERO_ADC_GROUP, ZERO_ADC_MODE, GPIO_OSPEED_50MHZ, ZERO_ADC_PIN);
  209. #endif
  210. }
  211. void adc_init(void) {
  212. adc_gpio_init();
  213. adc01_dma_init();
  214. adc01_init();
  215. adc_current_sample_config(0);
  216. }
  217. void adc_set_vref_calc(float v) {
  218. vref_adc = v;
  219. }
  220. void adc_set_5vref_calc(float v) {
  221. vref_5v_adc = v;
  222. }
  223. #define VREF_COMP_LFP_CEOF (0.0001F)
  224. static float vref_compestion_filter = 1.0f;
  225. #define VREF_3V3_COMPESTION() (vref_adc/(float)adc_buffer[VREF_BUFF_IDX])
  226. void adc_3v3ref_filter(void) {
  227. float value = VREF_3V3_COMPESTION();
  228. LowPass_Filter(vref_compestion_filter, value, VREF_COMP_LFP_CEOF);
  229. }
  230. float adc_vref_compesion(void) {
  231. return vref_compestion_filter;
  232. }
  233. static float vref_5v_compestion_filter = 1.0f;
  234. #define VREF_5V_COMPESTION() (vref_5v_adc/(float)adc_buffer[VREF5v_BUFF_IDX])
  235. void adc_5vref_filter(void) {
  236. float value = VREF_5V_COMPESTION();
  237. LowPass_Filter(vref_5v_compestion_filter, value, VREF_COMP_LFP_CEOF);
  238. }
  239. float adc_5vref_compesion(void) {
  240. return vref_5v_compestion_filter;
  241. }
  242. void adc_vref_filter(void) {
  243. adc_3v3ref_filter();
  244. adc_5vref_filter();
  245. }
  246. u16 adc_get_vbus(void) {
  247. return (float)adc_buffer[VBUS_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  248. }
  249. u16 adc_get_acc(void) {
  250. #ifdef CONFIG_BOARD_MCXXX
  251. return (float)adc_buffer[ACC_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  252. #else
  253. return adc_get_vbus();
  254. #endif
  255. }
  256. u16 adc_get_ibus(void) {
  257. #ifdef CONFIG_BOARD_MCXXX
  258. return (float)adc_buffer[VBUS_I_BUFF_IDX] * VREF_5V_COMPESTION();
  259. #else
  260. return 0;
  261. #endif
  262. }
  263. u16 adc_get_throttle(void) {
  264. return adc_buffer[THROTTLE_BUFF_IDX] * VREF_3V3_COMPESTION();
  265. }
  266. u16 adc_get_throttle2(void) {
  267. #ifdef THROTTLE2_BUFF_IDX
  268. return adc_buffer[THROTTLE2_BUFF_IDX] * VREF_3V3_COMPESTION();
  269. #else
  270. return adc_get_throttle();
  271. #endif
  272. }
  273. u16 adc_get_thro_5v(void) {
  274. #ifdef THROTTLE_5V_BUFF_IDX
  275. return adc_buffer[THROTTLE_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  276. #else
  277. return 0;
  278. #endif
  279. }
  280. u16 adc_get_thro2_5v(void) {
  281. #ifdef THROTTLE2_5V_BUFF_IDX
  282. return adc_buffer[THROTTLE2_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  283. #else
  284. return 0;
  285. #endif
  286. }
  287. void adc_get_uvw_phaseV(u16 *uvw) {
  288. uvw[0] = adc_buffer[U_VOL_BUFF_IDX];
  289. uvw[1] = adc_buffer[V_VOL_BUFF_IDX];
  290. uvw[2] = adc_buffer[W_VOL_BUFF_IDX];
  291. }
  292. u16 adc_get_mos_temp(void) {
  293. return adc_buffer[MOS_TEMP_BUFF_IDX];
  294. }
  295. u16 adc_get_motor_temp(void) {
  296. return adc_buffer[MOTOR_TEMP_BUFF_IDX];
  297. }
  298. u16 adc_get_vref(void) {
  299. #ifdef CONFIG_BOARD_MCXXX
  300. return adc_buffer[VREF_BUFF_IDX];
  301. #else
  302. return 0;
  303. #endif
  304. }
  305. u16 adc_get_5v_ref(void) {
  306. #ifdef CONFIG_BOARD_MCXXX
  307. return adc_buffer[VREF5v_BUFF_IDX];
  308. #else
  309. return 0;
  310. #endif
  311. }
  312. void adc_start_convert(void) {
  313. int drop = 16;
  314. /* clear the ADC flag */
  315. ADC_ClearFlag(ADC1, ADC_FLAG_JENDC);
  316. ADC_ClearFlag(ADC2, ADC_FLAG_JENDC);
  317. adc_enable_ext_trigger();
  318. while(drop-- > 0) {
  319. while (ADC_GetFlagStatus(ADC1, ADC_FLAG_JENDC) == RESET);
  320. ADC_ClearFlag(ADC1, ADC_FLAG_JENDC);
  321. }
  322. /* enable ADC interrupt */
  323. ADC_ConfigInt(ADC1, ADC_INT_JENDC, ENABLE);
  324. adc_update_ext_trigger(ADC_TRIGGER_PHASE);
  325. }
  326. void adc_stop_convert(void) {
  327. adc_disable_ext_trigger();
  328. /* disable ADC interrupt */
  329. ADC_ConfigInt(ADC1, ADC_INT_JENDC, DISABLE);
  330. /* clear the ADC flag */
  331. ADC_ClearFlag(ADC1, ADC_FLAG_JENDC);
  332. ADC_ClearFlag(ADC2, ADC_FLAG_JENDC);
  333. }