adc.c 15 KB

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