adc.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. #include "bsp/adc.h"
  2. #include "libs/utils.h"
  3. #include "os/co_task.h"
  4. #include "libs/logger.h"
  5. static void _gpio_init(void);
  6. void adc_init(void){
  7. rcu_adc_clock_config(RCU_AF);
  8. /* init adc input gpio */
  9. _gpio_init();
  10. /* config ADC clock */
  11. rcu_adc_clock_config(RCU_CKADC_CKAPB2_DIV4); //APB2 clk 120M, adc clk 30M
  12. rcu_periph_clock_enable(RCU_ADC0);
  13. rcu_periph_clock_enable(RCU_ADC1);
  14. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  15. adc_mode_config(ADC_DAUL_INSERTED_PARALLEL);
  16. #else
  17. adc_mode_config(ADC_MODE_FREE);
  18. #endif
  19. /* ADC scan mode function enable */
  20. adc_special_function_config(ADC0, ADC_SCAN_MODE, ENABLE);
  21. adc_special_function_config(ADC1, ADC_SCAN_MODE, ENABLE);
  22. /* configure ADC data alignment */
  23. adc_data_alignment_config(ADC0, ADC_DATAALIGN_RIGHT);
  24. adc_data_alignment_config(ADC1, ADC_DATAALIGN_RIGHT);
  25. /* configure ADC inserted channel trigger */
  26. adc_external_trigger_source_config(ADC0, ADC_INSERTED_CHANNEL, ADC_TRIGGER_PHASE);
  27. /* configure ADC inserted channel length */
  28. adc_channel_length_config(ADC0, ADC_INSERTED_CHANNEL, 1);
  29. /* configure ADC inserted channel trigger */
  30. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  31. adc_external_trigger_source_config(ADC1, ADC_INSERTED_CHANNEL, ADC_TRIGGER_NONE);
  32. #else
  33. adc_external_trigger_source_config(ADC1, ADC_INSERTED_CHANNEL, ADC_TRIGGER_PHASE2);
  34. #endif
  35. /* configure ADC inserted channel length */
  36. adc_channel_length_config(ADC1, ADC_INSERTED_CHANNEL, 1);
  37. /* configure ADC inserted channel */
  38. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  39. adc_inserted_channel_config(ADC0, 0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  40. adc_inserted_channel_config(ADC1, 0, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  41. adc_update_insert_sample_time(ADC0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  42. adc_update_insert_sample_time(ADC0, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  43. adc_update_insert_sample_time(ADC0, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  44. adc_update_insert_sample_time(ADC1, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  45. adc_update_insert_sample_time(ADC1, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  46. adc_update_insert_sample_time(ADC1, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  47. #else
  48. adc_inserted_channel_config(ADC0, 0, VBUS_I_CHAN, ADC_SAMPLE_TIME);
  49. adc_inserted_channel_config(ADC1, 0, VBUS_I_CHAN, ADC_SAMPLE_TIME);
  50. #endif
  51. /* ADC external trigger enable */
  52. adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
  53. adc_external_trigger_config(ADC1, ADC_INSERTED_CHANNEL, ENABLE);
  54. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  55. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  56. adc_interrupt_disable(ADC1, ADC_INT_EOIC);
  57. #else
  58. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  59. adc_interrupt_disable(ADC1, ADC_INT_EOIC);
  60. #endif
  61. /* configure ADC regular channel trigger */
  62. adc_external_trigger_source_config(ADC0, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  63. adc_external_trigger_config(ADC0, ADC_REGULAR_CHANNEL, ENABLE);
  64. /* enable ADC interface */
  65. adc_enable(ADC0);
  66. adc_enable(ADC1);
  67. /* ADC calibration and reset calibration */
  68. adc_calibration_enable(ADC0);
  69. adc_calibration_enable(ADC1);
  70. nvic_irq_enable(ADC0_1_IRQn, ADC_IRQ_PRIORITY, 0);
  71. adc_disable_ext_trigger();
  72. }
  73. static void _gpio_init(void) {
  74. rcu_periph_clock_enable(RCU_GPIOA);
  75. rcu_periph_clock_enable(RCU_GPIOB);
  76. gpio_init(GPIOA, GPIO_MODE_AIN, GPIO_OSPEED_50MHZ, GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3|GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_6|GPIO_PIN_7);
  77. gpio_init(GPIOB, GPIO_MODE_AIN, GPIO_OSPEED_50MHZ, GPIO_PIN_0|GPIO_PIN_1);
  78. }
  79. void adc_start_insert_convert(void) {
  80. int drop = 2;
  81. /* clear the ADC flag */
  82. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  83. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  84. //adc_enable_ext_trigger();
  85. while(drop-- > 0) {
  86. while ((adc_flag_get(ADC0, ADC_FLAG_EOIC) == RESET) || (adc_flag_get(ADC1, ADC_FLAG_EOIC) == RESET));
  87. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  88. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  89. }
  90. /* enable ADC interrupt */
  91. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  92. adc_interrupt_enable(ADC0, ADC_INT_EOIC);
  93. #else
  94. adc_interrupt_enable(ADC1, ADC_INT_EOIC);
  95. #endif
  96. }
  97. void adc_stop_insert_convert(void) {
  98. adc_disable_ext_trigger();
  99. /* disable ADC interrupt */
  100. #if SHUNT_NUM==THREE_SHUNTS_SAMPLE
  101. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  102. #else
  103. adc_interrupt_disable(ADC1, ADC_INT_EOIC);
  104. #endif
  105. /* clear the ADC flag */
  106. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  107. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  108. }
  109. s32 adc_sample_regular_channel(int channel, int times) {
  110. #if 1
  111. u32 adc_device = ADC0;
  112. int value = 0;
  113. int count = 0;
  114. int min = 0xFFFFF;
  115. int max = -0xFFFFF;
  116. u64 start_time;
  117. adc_channel_length_config(adc_device, ADC_REGULAR_CHANNEL, 1);
  118. adc_regular_channel_config(adc_device, 0, channel, ADC_SAMPLETIME_55POINT5);
  119. while(count < times){
  120. restart:
  121. start_time = co_task_sys64_ticks();
  122. adc_software_trigger_enable(adc_device, ADC_REGULAR_CHANNEL);
  123. while(SET != adc_flag_get(adc_device, ADC_FLAG_EOC)){
  124. if (co_task_sys64_ticks() - start_time >= 2){
  125. goto restart;
  126. }
  127. };
  128. int one = adc_regular_data_read(adc_device);
  129. adc_flag_clear(adc_device, ADC_FLAG_EOC);
  130. value += (one & 0xFFF);
  131. count ++;
  132. if (one > max){
  133. max = one;
  134. }
  135. if (one < min) {
  136. min = one;
  137. }
  138. }
  139. if (times <= 2) {
  140. return value/times;
  141. }
  142. return (value - min - max)/(times-2);
  143. #else
  144. return 0;
  145. #endif
  146. }