adc.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  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. #define REG_CHAN_DMA 1
  7. #ifdef REG_CHAN_DMA
  8. #ifndef CONFIG_BOARD_MCXXX
  9. #define ADC01_NUM 7
  10. #define ADC2_NUM 0
  11. #define VBUS_V_BUFF_IDX 0
  12. #define THROTTLE_BUFF_IDX 1
  13. #define U_VOL_BUFF_IDX 2
  14. #define V_VOL_BUFF_IDX 3
  15. #define W_VOL_BUFF_IDX 4
  16. #define MOS_TEMP_BUFF_IDX 5
  17. #define MOTOR_TEMP_BUFF_IDX 6
  18. #elif (CONFIG_HW_VERSION==2)
  19. #define ADC01_NUM (8)
  20. #define ADC2_NUM 4
  21. #define MOS_TEMP_BUFF_IDX 0
  22. #define VREF5v_BUFF_IDX 1
  23. #define VBUS_I_BUFF_IDX 2
  24. #define U_VOL_BUFF_IDX 3
  25. #define V_VOL_BUFF_IDX 4
  26. #define W_VOL_BUFF_IDX 5
  27. #define VREF_BUFF_IDX 7
  28. #define VBUS_V_BUFF_IDX 8
  29. #define ACC_V_BUFF_IDX 9
  30. #define THROTTLE_BUFF_IDX 10
  31. #define MOTOR_TEMP_BUFF_IDX 11
  32. #elif (CONFIG_HW_VERSION==3)
  33. #define ADC01_NUM (16)
  34. #define ADC2_NUM 0
  35. #define MOS_TEMP_BUFF_IDX 0
  36. #define MOTOR_TEMP_BUFF_IDX 1
  37. #define THROTTLE_BUFF_IDX 2
  38. #define THROTTLE2_BUFF_IDX 3
  39. #define THROTTLE_5V_BUFF_IDX 4
  40. #define THROTTLE2_5V_BUFF_IDX 5
  41. #define U_VOL_BUFF_IDX 6
  42. #define VREF_BUFF_IDX 8
  43. #define VREF5v_BUFF_IDX 10
  44. #define VBUS_V_BUFF_IDX 11
  45. #define ACC_V_BUFF_IDX 12
  46. #define VBUS_I_BUFF_IDX 13
  47. #define V_VOL_BUFF_IDX 14
  48. #define W_VOL_BUFF_IDX 15
  49. #endif
  50. #define REG_CHAN_NUM (ADC01_NUM + ADC2_NUM)
  51. s16 adc_buffer[REG_CHAN_NUM];
  52. float vref_adc = 1408.0f;
  53. float vref_5v_adc = 2047.0f;
  54. #define VREF_ADC_DATA 1509.0F //1498, 1.21/3.3*4095
  55. static void adc01_dma_init(void)
  56. {
  57. dma_parameter_struct dma_init_struct;
  58. rcu_periph_clock_enable(RCU_DMA0);
  59. dma_deinit(DMA0, DMA_CH0);
  60. dma_init_struct.direction = DMA_PERIPHERAL_TO_MEMORY;
  61. dma_init_struct.memory_addr = (uint32_t)adc_buffer;
  62. dma_init_struct.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  63. dma_init_struct.memory_width = DMA_MEMORY_WIDTH_16BIT;
  64. dma_init_struct.number = ADC01_NUM;
  65. dma_init_struct.periph_addr = (uint32_t)(&ADC_RDATA(ADC0));
  66. dma_init_struct.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  67. dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_16BIT;
  68. dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH;
  69. dma_init(DMA0, DMA_CH0, &dma_init_struct);
  70. dma_circulation_enable(DMA0, DMA_CH0);
  71. dma_memory_to_memory_disable(DMA0, DMA_CH0);
  72. dma_channel_enable(DMA0, DMA_CH0);
  73. }
  74. #if (CONFIG_HW_VERSION==2)
  75. static void adc2_dma_init(void)
  76. {
  77. dma_parameter_struct dma_init_struct;
  78. rcu_periph_clock_enable(RCU_DMA1);
  79. dma_deinit(DMA1, DMA_CH4);
  80. dma_init_struct.direction = DMA_PERIPHERAL_TO_MEMORY;
  81. dma_init_struct.memory_addr = (uint32_t)(adc_buffer + ADC01_NUM);
  82. dma_init_struct.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  83. dma_init_struct.memory_width = DMA_MEMORY_WIDTH_16BIT;
  84. dma_init_struct.number = ADC2_NUM;
  85. dma_init_struct.periph_addr = (uint32_t)(&ADC_RDATA(ADC2));
  86. dma_init_struct.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  87. dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_16BIT;
  88. dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH;
  89. dma_init(DMA1, DMA_CH4, &dma_init_struct);
  90. dma_circulation_enable(DMA1, DMA_CH4);
  91. dma_memory_to_memory_disable(DMA1, DMA_CH4);
  92. dma_channel_enable(DMA1, DMA_CH4);
  93. }
  94. #endif
  95. #endif
  96. static void adc0_init(void){
  97. /* config ADC clock */
  98. rcu_adc_clock_config(RCU_CKADC_CKAPB2_DIV4); //APB2 clk 120M, adc clk 30M
  99. rcu_periph_clock_enable(RCU_ADC0);
  100. adc_deinit(ADC0);
  101. adc_mode_config(ADC_DAUL_INSERTED_PARALLEL);
  102. adc_special_function_config(ADC0, ADC_CONTINUOUS_MODE, ENABLE);
  103. adc_special_function_config(ADC0, ADC_SCAN_MODE, ENABLE);
  104. /* configure ADC data alignment */
  105. adc_data_alignment_config(ADC0, ADC_DATAALIGN_RIGHT);
  106. /* configure ADC inserted channel length */
  107. adc_channel_length_config(ADC0, ADC_INSERTED_CHANNEL, 1);
  108. //adc_inserted_channel_config(ADC0, 0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  109. #ifdef U_PHASE_I_CHAN
  110. adc_update_insert_sample_time(ADC0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  111. #endif
  112. #ifdef V_PHASE_I_CHAN
  113. adc_update_insert_sample_time(ADC0, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  114. #endif
  115. #ifdef W_PHASE_I_CHAN
  116. adc_update_insert_sample_time(ADC0, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  117. #endif
  118. #ifdef CONFIG_HW_MUTISAMPLE
  119. adc_oversample_mode_config(ADC0, ADC_OVERSAMPLING_ALL_CONVERT, CONFIG_HW_MUTISAMPLE_SHIFT, CONFIG_HW_MUTISAMPLE);
  120. adc_oversample_mode_enable(ADC0);
  121. #endif
  122. /* configure ADC inserted channel trigger */
  123. adc_external_trigger_source_config(ADC0, ADC_INSERTED_CHANNEL, ADC_TRIGGER_PHASE);
  124. /* ADC external trigger enable */
  125. adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
  126. #ifdef REG_CHAN_DMA
  127. /* configure ADC regular channel */
  128. adc_channel_length_config(ADC0, ADC_REGULAR_CHANNEL, ADC01_NUM);
  129. #ifndef CONFIG_BOARD_MCXXX
  130. adc_regular_channel_config(ADC0, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  131. adc_regular_channel_config(ADC0, 1, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  132. adc_regular_channel_config(ADC0, 2, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  133. adc_regular_channel_config(ADC0, 3, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  134. adc_regular_channel_config(ADC0, 4, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  135. adc_regular_channel_config(ADC0, 5, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  136. adc_regular_channel_config(ADC0, 6, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  137. #elif (CONFIG_HW_VERSION==2)
  138. adc_regular_channel_config(ADC0, 0, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  139. adc_regular_channel_config(ADC0, 1, MOS_TEMP1_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  140. adc_regular_channel_config(ADC0, 2, VBUS_I_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  141. adc_regular_channel_config(ADC0, 3, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  142. adc_regular_channel_config(ADC0, 4, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  143. adc_regular_channel_config(ADC0, 5, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  144. adc_regular_channel_config(ADC0, 6, ADC_CHANNEL_10, ADC_REGCHAN_SAMPLE_TIME);
  145. adc_regular_channel_config(ADC0, 7, ADC_CHANNEL_17, ADC_REGCHAN_SAMPLE_TIME);
  146. adc_tempsensor_vrefint_enable();
  147. adc_buffer[VREF_BUFF_IDX] = VREF_ADC_DATA; //1.21/3.3*4095
  148. #elif (CONFIG_HW_VERSION==3)
  149. adc_regular_channel_config(ADC0, 0, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  150. adc_regular_channel_config(ADC0, 1, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  151. adc_regular_channel_config(ADC0, 2, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  152. adc_regular_channel_config(ADC0, 3, THROTTLE2_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  153. adc_regular_channel_config(ADC0, 4, THROTTLE_5V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  154. adc_regular_channel_config(ADC0, 5, THROTTLE2_5V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  155. adc_regular_channel_config(ADC0, 6, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  156. adc_regular_channel_config(ADC0, 7, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  157. adc_regular_channel_config(ADC0, 8, ADC_CHANNEL_17, ADC_SAMPLETIME_239POINT5); //mcu内部vref
  158. adc_regular_channel_config(ADC0, 9, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  159. adc_regular_channel_config(ADC0, 10, DC5V_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  160. adc_regular_channel_config(ADC0, 11, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  161. adc_regular_channel_config(ADC0, 12, ACC_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  162. adc_regular_channel_config(ADC0, 13, VBUS_I_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  163. adc_regular_channel_config(ADC0, 14, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  164. adc_regular_channel_config(ADC0, 15, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  165. adc_tempsensor_vrefint_enable();
  166. adc_buffer[VREF_BUFF_IDX] = VREF_ADC_DATA; //1.21/3.3*4095
  167. #endif
  168. #endif
  169. /* configure ADC regular channel trigger */
  170. adc_external_trigger_source_config(ADC0, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  171. adc_external_trigger_config(ADC0, ADC_REGULAR_CHANNEL, ENABLE);
  172. #ifdef REG_CHAN_DMA
  173. adc_dma_mode_enable(ADC0);
  174. #endif
  175. /* enable ADC interface */
  176. adc_enable(ADC0);
  177. delay_ms(1);
  178. /* ADC calibration and reset calibration */
  179. adc_calibration_enable(ADC0);
  180. nvic_irq_enable(ADC0_1_IRQn, ADC_IRQ_PRIORITY, 0);
  181. adc_disable_ext_trigger();
  182. #ifdef REG_CHAN_DMA
  183. adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
  184. #endif
  185. }
  186. static void adc1_init(void){
  187. rcu_periph_clock_enable(RCU_ADC1);
  188. adc_deinit(ADC1);
  189. adc_special_function_config(ADC0, ADC_CONTINUOUS_MODE, ENABLE);
  190. adc_special_function_config(ADC1, ADC_SCAN_MODE, ENABLE);
  191. /* configure ADC data alignment */
  192. adc_data_alignment_config(ADC1, ADC_DATAALIGN_RIGHT);
  193. /* configure ADC inserted channel length */
  194. adc_channel_length_config(ADC1, ADC_INSERTED_CHANNEL, 1);
  195. /* configure ADC inserted channel */
  196. #ifdef U_PHASE_I_CHAN
  197. adc_update_insert_sample_time(ADC1, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  198. #endif
  199. #ifdef V_PHASE_I_CHAN
  200. adc_update_insert_sample_time(ADC1, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  201. #endif
  202. #ifdef W_PHASE_I_CHAN
  203. adc_update_insert_sample_time(ADC1, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  204. #endif
  205. #ifdef CONFIG_HW_MUTISAMPLE
  206. adc_oversample_mode_config(ADC1, ADC_OVERSAMPLING_ALL_CONVERT, CONFIG_HW_MUTISAMPLE_SHIFT, CONFIG_HW_MUTISAMPLE);
  207. adc_oversample_mode_enable(ADC1);
  208. #endif
  209. /* ADC external trigger enable */
  210. adc_external_trigger_source_config(ADC1, ADC_INSERTED_CHANNEL, ADC_TRIGGER_NONE);
  211. adc_external_trigger_config(ADC1, ADC_INSERTED_CHANNEL, ENABLE);
  212. /* enable ADC interface */
  213. adc_enable(ADC1);
  214. delay_ms(1);
  215. /* ADC calibration and reset calibration */
  216. adc_calibration_enable(ADC1);
  217. /* ADC software trigger enable */
  218. adc_software_trigger_enable(ADC1, ADC_INSERTED_CHANNEL);
  219. }
  220. #if (CONFIG_HW_VERSION==2)
  221. static void adc2_init(void){
  222. rcu_periph_clock_enable(RCU_ADC2);
  223. adc_deinit(ADC2);
  224. adc_special_function_config(ADC2, ADC_CONTINUOUS_MODE, ENABLE);
  225. adc_special_function_config(ADC2, ADC_SCAN_MODE, ENABLE);
  226. /* configure ADC data alignment */
  227. adc_data_alignment_config(ADC2, ADC_DATAALIGN_RIGHT);
  228. #ifdef CONFIG_HW_MUTISAMPLE
  229. adc_oversample_mode_config(ADC2, ADC_OVERSAMPLING_ALL_CONVERT, CONFIG_HW_MUTISAMPLE_SHIFT, CONFIG_HW_MUTISAMPLE);
  230. adc_oversample_mode_enable(ADC2);
  231. #endif
  232. #ifdef REG_CHAN_DMA
  233. /* configure ADC regular channel */
  234. adc_channel_length_config(ADC2, ADC_REGULAR_CHANNEL, ADC2_NUM);
  235. #if (CONFIG_HW_VERSION==2)
  236. adc_regular_channel_config(ADC2, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  237. adc_regular_channel_config(ADC2, 1, ACC_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  238. adc_regular_channel_config(ADC2, 2, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  239. adc_regular_channel_config(ADC2, 3, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  240. #elif (CONFIG_HW_VERSION==3)
  241. adc_regular_channel_config(ADC2, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  242. adc_regular_channel_config(ADC2, 1, ACC_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  243. adc_regular_channel_config(ADC2, 2, VBUS_I_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  244. adc_regular_channel_config(ADC2, 3, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  245. adc_regular_channel_config(ADC2, 4, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  246. #endif
  247. #endif
  248. /* configure ADC regular channel trigger */
  249. adc_external_trigger_source_config(ADC2, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  250. adc_external_trigger_config(ADC2, ADC_REGULAR_CHANNEL, ENABLE);
  251. #ifdef REG_CHAN_DMA
  252. adc_dma_mode_enable(ADC2);
  253. #endif
  254. /* enable ADC interface */
  255. adc_enable(ADC2);
  256. delay_ms(1);
  257. /* ADC calibration and reset calibration */
  258. adc_calibration_enable(ADC2);
  259. #ifdef REG_CHAN_DMA
  260. adc_software_trigger_enable(ADC2, ADC_REGULAR_CHANNEL);
  261. #endif
  262. }
  263. #endif
  264. static void adc_gpio_init(void) {
  265. rcu_periph_clock_enable(RCU_AF);
  266. /* configure ADC pin, current sampling -- ADC_IN1(PA1) ADC_IN12(PC2) ADC_IN13(PC3) */
  267. #ifdef U_PHASE_ADC_GROUP
  268. rcu_periph_clock_enable(U_PHASE_ADC_RCU);
  269. gpio_init(U_PHASE_ADC_GROUP, U_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, U_PHASE_ADC_PIN);
  270. #endif
  271. #ifdef V_PHASE_ADC_GROUP
  272. rcu_periph_clock_enable(V_PHASE_ADC_RCU);
  273. gpio_init(V_PHASE_ADC_GROUP, V_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, V_PHASE_ADC_PIN);
  274. #endif
  275. #ifdef W_PHASE_ADC_GROUP
  276. rcu_periph_clock_enable(W_PHASE_ADC_RCU);
  277. gpio_init(W_PHASE_ADC_GROUP, W_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, W_PHASE_ADC_PIN);
  278. #endif
  279. #ifdef VBUS_V_ADC_GROUP
  280. rcu_periph_clock_enable(VBUS_V_ADC_RCU);
  281. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  282. gpio_init(VBUS_V_ADC_GROUP, VBUS_V_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_V_ADC_PIN);
  283. #endif
  284. #ifdef VBUS_I_ADC_GROUP
  285. rcu_periph_clock_enable(VBUS_I_ADC_RCU);
  286. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  287. gpio_init(VBUS_I_ADC_GROUP, VBUS_I_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_I_ADC_PIN);
  288. #endif
  289. #ifdef ACC_V_ADC_GROUP
  290. rcu_periph_clock_enable(ACC_V_ADC_RCU);
  291. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  292. gpio_init(ACC_V_ADC_GROUP, ACC_V_ADC_MODE, GPIO_OSPEED_50MHZ, ACC_V_ADC_PIN);
  293. #endif
  294. #ifdef THROTTLE_V_ADC_GROUP
  295. rcu_periph_clock_enable(THROTTLE_V_ADC_RCU);
  296. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  297. gpio_init(THROTTLE_V_ADC_GROUP, THROTTLE_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_V_ADC_PIN);
  298. #endif
  299. #ifdef THROTTLE2_V_ADC_GROUP
  300. rcu_periph_clock_enable(THROTTLE2_V_ADC_RCU);
  301. gpio_init(THROTTLE2_V_ADC_GROUP, THROTTLE2_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_V_ADC_PIN);
  302. #endif
  303. #ifdef THROTTLE_5V_ADC_GROUP
  304. rcu_periph_clock_enable(THROTTLE_5V_ADC_RCU);
  305. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  306. gpio_init(THROTTLE_5V_ADC_GROUP, THROTTLE_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_5V_ADC_PIN);
  307. #endif
  308. #ifdef THROTTLE2_5V_ADC_GROUP
  309. rcu_periph_clock_enable(THROTTLE2_5V_ADC_RCU);
  310. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  311. gpio_init(THROTTLE2_5V_ADC_GROUP, THROTTLE2_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_5V_ADC_PIN);
  312. #endif
  313. #ifdef U_VOL_ADC_GROUP
  314. rcu_periph_clock_enable(U_VOL_ADC_RCU);
  315. gpio_init(U_VOL_ADC_GROUP, U_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, U_VOL_ADC_PIN);
  316. #endif
  317. #ifdef V_VOL_ADC_GROUP
  318. rcu_periph_clock_enable(V_VOL_ADC_RCU);
  319. gpio_init(V_VOL_ADC_GROUP, V_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, V_VOL_ADC_PIN);
  320. #endif
  321. #ifdef W_VOL_ADC_GROUP
  322. rcu_periph_clock_enable(W_VOL_ADC_RCU);
  323. gpio_init(W_VOL_ADC_GROUP, W_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, W_VOL_ADC_PIN);
  324. #endif
  325. #ifdef MOS_TEMP_ADC_GROUP
  326. rcu_periph_clock_enable(MOS_TEMP_ADC_RCU);
  327. gpio_init(MOS_TEMP_ADC_GROUP, MOS_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP_ADC_PIN);
  328. #endif
  329. #ifdef MOS_TEMP1_ADC_GROUP
  330. rcu_periph_clock_enable(MOS_TEMP1_ADC_RCU);
  331. gpio_init(MOS_TEMP1_ADC_GROUP, MOS_TEMP1_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP1_ADC_PIN);
  332. #endif
  333. #ifdef MOTOR_TEMP_ADC_GROUP
  334. rcu_periph_clock_enable(MOTOR_TEMP_ADC_RCU);
  335. gpio_init(MOTOR_TEMP_ADC_GROUP, MOTOR_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOTOR_TEMP_ADC_PIN);
  336. #endif
  337. #ifdef ZERO_ADC_GROUP
  338. rcu_periph_clock_enable(ZERO_ADC_RCU);
  339. gpio_init(ZERO_ADC_GROUP, ZERO_ADC_MODE, GPIO_OSPEED_50MHZ, ZERO_ADC_PIN);
  340. #endif
  341. }
  342. void adc_init(void) {
  343. adc_gpio_init();
  344. #ifdef REG_CHAN_DMA
  345. adc01_dma_init();
  346. #if (CONFIG_HW_VERSION==2)
  347. adc2_dma_init();
  348. #endif
  349. #endif
  350. adc0_init();
  351. adc1_init();
  352. #if (CONFIG_HW_VERSION==2)
  353. adc2_init();
  354. #endif
  355. adc_current_sample_config(0);
  356. }
  357. void adc_set_vref_calc(float v) {
  358. vref_adc = v;
  359. }
  360. void adc_set_5vref_calc(float v) {
  361. vref_5v_adc = v;
  362. }
  363. #define VREF_COMP_LFP_CEOF (0.0001F)
  364. static float vref_compestion_filter = 1.0f;
  365. #define VREF_3V3_COMPESTION() (vref_adc/(float)adc_buffer[VREF_BUFF_IDX])
  366. void adc_3v3ref_filter(void) {
  367. float value = VREF_3V3_COMPESTION();
  368. LowPass_Filter(vref_compestion_filter, value, VREF_COMP_LFP_CEOF);
  369. }
  370. float adc_vref_compesion(void) {
  371. return vref_compestion_filter;
  372. }
  373. static float vref_5v_compestion_filter = 1.0f;
  374. #define VREF_5V_COMPESTION() (vref_5v_adc/(float)adc_buffer[VREF5v_BUFF_IDX])
  375. void adc_5vref_filter(void) {
  376. float value = VREF_5V_COMPESTION();
  377. LowPass_Filter(vref_5v_compestion_filter, value, VREF_COMP_LFP_CEOF);
  378. }
  379. float adc_5vref_compesion(void) {
  380. return vref_5v_compestion_filter;
  381. }
  382. void adc_vref_filter(void) {
  383. adc_3v3ref_filter();
  384. adc_5vref_filter();
  385. }
  386. u16 adc_get_vbus(void) {
  387. return (float)adc_buffer[VBUS_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  388. }
  389. u16 adc_get_acc(void) {
  390. #ifdef CONFIG_BOARD_MCXXX
  391. return (float)adc_buffer[ACC_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  392. #else
  393. return adc_get_vbus();
  394. #endif
  395. }
  396. u16 adc_get_ibus(void) {
  397. #ifdef CONFIG_BOARD_MCXXX
  398. return (float)adc_buffer[VBUS_I_BUFF_IDX] * VREF_5V_COMPESTION();
  399. #else
  400. return 0;
  401. #endif
  402. }
  403. u16 adc_get_throttle(void) {
  404. return adc_buffer[THROTTLE_BUFF_IDX] * VREF_3V3_COMPESTION();
  405. }
  406. u16 adc_get_throttle2(void) {
  407. #ifdef THROTTLE2_BUFF_IDX
  408. return adc_buffer[THROTTLE2_BUFF_IDX] * VREF_3V3_COMPESTION();
  409. #else
  410. return adc_get_throttle();
  411. #endif
  412. }
  413. u16 adc_get_thro_5v(void) {
  414. #ifdef THROTTLE_5V_BUFF_IDX
  415. return adc_buffer[THROTTLE_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  416. #else
  417. return 0;
  418. #endif
  419. }
  420. u16 adc_get_thro2_5v(void) {
  421. #ifdef THROTTLE2_5V_BUFF_IDX
  422. return adc_buffer[THROTTLE2_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  423. #else
  424. return 0;
  425. #endif
  426. }
  427. void adc_get_uvw_phaseV(u16 *uvw) {
  428. uvw[0] = adc_buffer[U_VOL_BUFF_IDX];
  429. uvw[1] = adc_buffer[V_VOL_BUFF_IDX];
  430. uvw[2] = adc_buffer[W_VOL_BUFF_IDX];
  431. }
  432. u16 adc_get_mos_temp(void) {
  433. return adc_buffer[MOS_TEMP_BUFF_IDX];
  434. }
  435. u16 adc_get_motor_temp(void) {
  436. return adc_buffer[MOTOR_TEMP_BUFF_IDX];
  437. }
  438. u16 adc_get_vref(void) {
  439. #ifdef CONFIG_BOARD_MCXXX
  440. return adc_buffer[VREF_BUFF_IDX];
  441. #else
  442. return 0;
  443. #endif
  444. }
  445. u16 adc_get_5v_ref(void) {
  446. #ifdef CONFIG_BOARD_MCXXX
  447. return adc_buffer[VREF5v_BUFF_IDX];
  448. #else
  449. return 0;
  450. #endif
  451. }
  452. void adc_start_convert(void) {
  453. int drop = 2;
  454. /* clear the ADC flag */
  455. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  456. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  457. adc_enable_ext_trigger();
  458. while(drop-- > 0) {
  459. while (adc_flag_get(ADC0, ADC_FLAG_EOIC) == RESET);
  460. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  461. }
  462. /* enable ADC interrupt */
  463. adc_interrupt_enable(ADC0, ADC_INT_EOIC);
  464. adc_update_ext_trigger(ADC_TRIGGER_PHASE);
  465. }
  466. void adc_stop_convert(void) {
  467. adc_disable_ext_trigger();
  468. /* disable ADC interrupt */
  469. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  470. /* clear the ADC flag */
  471. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  472. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  473. }
  474. s32 adc_sample_regular_channel(int channel, int times) {
  475. #ifndef REG_CHAN_DMA
  476. u32 adc_device = ADC0;
  477. int value = 0;
  478. int count = 0;
  479. int min = 0xFFFFF;
  480. int max = -0xFFFFF;
  481. u64 start_time;
  482. adc_channel_length_config(adc_device, ADC_REGULAR_CHANNEL, 1);
  483. adc_regular_channel_config(adc_device, 0, channel, ADC_REGCHAN_SAMPLE_TIME);
  484. while(count < times){
  485. restart:
  486. start_time = shark_get_mseconds();
  487. adc_software_trigger_enable(adc_device, ADC_REGULAR_CHANNEL);
  488. while(SET != adc_flag_get(adc_device, ADC_FLAG_EOC)){
  489. if (shark_get_mseconds() - start_time >= 2){
  490. goto restart;
  491. }
  492. };
  493. int one = adc_regular_data_read(adc_device);
  494. adc_flag_clear(adc_device, ADC_FLAG_EOC);
  495. value += (one & 0xFFF);
  496. count ++;
  497. if (one > max){
  498. max = one;
  499. }
  500. if (one < min) {
  501. min = one;
  502. }
  503. }
  504. if (times <= 2) {
  505. return value/times;
  506. }
  507. return (value - min - max)/(times-2);
  508. #else
  509. return 0;
  510. #endif
  511. }