adc.c 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  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. #define REG_CHAN_DMA 1
  7. #ifdef REG_CHAN_DMA
  8. #define REG_CHAN_NUM 7
  9. s16 adc_buffer[REG_CHAN_NUM] = {0, 0, 0, 0, 0, 0, 0};
  10. static void adc_dma_init(void)
  11. {
  12. dma_parameter_struct dma_init_struct;
  13. rcu_periph_clock_enable(RCU_DMA0);
  14. dma_deinit(DMA0, DMA_CH0);
  15. dma_init_struct.direction = DMA_PERIPHERAL_TO_MEMORY;
  16. dma_init_struct.memory_addr = (uint32_t)adc_buffer;
  17. dma_init_struct.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  18. dma_init_struct.memory_width = DMA_MEMORY_WIDTH_16BIT;
  19. dma_init_struct.number = REG_CHAN_NUM;
  20. dma_init_struct.periph_addr = (uint32_t)(&ADC_RDATA(ADC0));
  21. dma_init_struct.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  22. dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_16BIT;
  23. dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH;
  24. dma_init(DMA0, DMA_CH0, &dma_init_struct);
  25. dma_circulation_enable(DMA0, DMA_CH0);
  26. dma_memory_to_memory_disable(DMA0, DMA_CH0);
  27. /* enable the full transfer interrupt */
  28. dma_interrupt_flag_clear(DMA0, DMA_CH0, DMA_INT_FLAG_FTF);
  29. dma_interrupt_enable(DMA0, DMA_CH0, DMA_INT_FTF);
  30. dma_channel_enable(DMA0, DMA_CH0);
  31. }
  32. #endif
  33. static void adc0_init(void){
  34. /* config ADC clock */
  35. rcu_adc_clock_config(RCU_CKADC_CKAPB2_DIV4); //APB2 clk 120M, adc clk 30M
  36. rcu_periph_clock_enable(RCU_ADC0);
  37. adc_deinit(ADC0);
  38. adc_mode_config(ADC_DAUL_INSERTED_PARALLEL);
  39. adc_special_function_config(ADC0, ADC_CONTINUOUS_MODE, ENABLE);
  40. adc_special_function_config(ADC0, ADC_SCAN_MODE, ENABLE);
  41. /* configure ADC data alignment */
  42. adc_data_alignment_config(ADC0, ADC_DATAALIGN_RIGHT);
  43. /* configure ADC inserted channel length */
  44. adc_channel_length_config(ADC0, ADC_INSERTED_CHANNEL, 1);
  45. //adc_inserted_channel_config(ADC0, 0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  46. #ifdef U_PHASE_I_CHAN
  47. adc_update_insert_sample_time(ADC0, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  48. #endif
  49. #ifdef V_PHASE_I_CHAN
  50. adc_update_insert_sample_time(ADC0, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  51. #endif
  52. #ifdef W_PHASE_I_CHAN
  53. adc_update_insert_sample_time(ADC0, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  54. #endif
  55. #ifdef HIGH_SIDE_CURRENT_SENSOR
  56. adc_oversample_mode_config(ADC0, ADC_OVERSAMPLING_ALL_CONVERT, ADC_OVERSAMPLING_SHIFT_1B, ADC_OVERSAMPLING_RATIO_MUL2);
  57. adc_oversample_mode_enable(ADC0);
  58. #endif
  59. /* configure ADC inserted channel trigger */
  60. adc_external_trigger_source_config(ADC0, ADC_INSERTED_CHANNEL, ADC_TRIGGER_PHASE);
  61. /* ADC external trigger enable */
  62. adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
  63. #ifdef REG_CHAN_DMA
  64. /* configure ADC regular channel */
  65. adc_channel_length_config(ADC0, ADC_REGULAR_CHANNEL, REG_CHAN_NUM);
  66. adc_regular_channel_config(ADC0, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  67. adc_regular_channel_config(ADC0, 1, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  68. adc_regular_channel_config(ADC0, 2, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  69. adc_regular_channel_config(ADC0, 3, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  70. adc_regular_channel_config(ADC0, 4, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  71. adc_regular_channel_config(ADC0, 5, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  72. adc_regular_channel_config(ADC0, 6, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  73. #endif
  74. /* configure ADC regular channel trigger */
  75. adc_external_trigger_source_config(ADC0, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  76. adc_external_trigger_config(ADC0, ADC_REGULAR_CHANNEL, ENABLE);
  77. #ifdef REG_CHAN_DMA
  78. adc_dma_mode_enable(ADC0);
  79. #endif
  80. /* enable ADC interface */
  81. adc_enable(ADC0);
  82. delay_ms(1);
  83. /* ADC calibration and reset calibration */
  84. adc_calibration_enable(ADC0);
  85. nvic_irq_enable(ADC0_1_IRQn, ADC_IRQ_PRIORITY, 0);
  86. adc_disable_ext_trigger();
  87. #ifdef REG_CHAN_DMA
  88. adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
  89. #endif
  90. }
  91. static void adc1_init(void){
  92. rcu_periph_clock_enable(RCU_ADC1);
  93. adc_deinit(ADC1);
  94. /* configure ADC data alignment */
  95. adc_data_alignment_config(ADC1, ADC_DATAALIGN_RIGHT);
  96. /* configure ADC inserted channel length */
  97. adc_channel_length_config(ADC1, ADC_INSERTED_CHANNEL, 1);
  98. /* configure ADC inserted channel */
  99. #ifdef U_PHASE_I_CHAN
  100. adc_update_insert_sample_time(ADC1, U_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  101. #endif
  102. #ifdef V_PHASE_I_CHAN
  103. adc_update_insert_sample_time(ADC1, V_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  104. #endif
  105. #ifdef W_PHASE_I_CHAN
  106. adc_update_insert_sample_time(ADC1, W_PHASE_I_CHAN, ADC_SAMPLE_TIME);
  107. #endif
  108. #ifdef HIGH_SIDE_CURRENT_SENSOR
  109. adc_oversample_mode_config(ADC1, ADC_OVERSAMPLING_ALL_CONVERT, ADC_OVERSAMPLING_SHIFT_1B, ADC_OVERSAMPLING_RATIO_MUL2);
  110. adc_oversample_mode_enable(ADC1);
  111. #endif
  112. /* ADC external trigger enable */
  113. adc_external_trigger_source_config(ADC1, ADC_INSERTED_CHANNEL, ADC_TRIGGER_NONE);
  114. adc_external_trigger_config(ADC1, ADC_INSERTED_CHANNEL, ENABLE);
  115. /* enable ADC interface */
  116. adc_enable(ADC1);
  117. delay_ms(1);
  118. /* ADC calibration and reset calibration */
  119. adc_calibration_enable(ADC1);
  120. /* ADC software trigger enable */
  121. adc_software_trigger_enable(ADC1, ADC_INSERTED_CHANNEL);
  122. }
  123. static void adc_gpio_init(void) {
  124. rcu_periph_clock_enable(RCU_AF);
  125. /* configure ADC pin, current sampling -- ADC_IN1(PA1) ADC_IN12(PC2) ADC_IN13(PC3) */
  126. #ifdef U_PHASE_ADC_GROUP
  127. rcu_periph_clock_enable(U_PHASE_ADC_RCU);
  128. gpio_init(U_PHASE_ADC_GROUP, U_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, U_PHASE_ADC_PIN);
  129. #endif
  130. #ifdef V_PHASE_ADC_GROUP
  131. rcu_periph_clock_enable(V_PHASE_ADC_RCU);
  132. gpio_init(V_PHASE_ADC_GROUP, V_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, V_PHASE_ADC_PIN);
  133. #endif
  134. #ifdef W_PHASE_ADC_GROUP
  135. rcu_periph_clock_enable(W_PHASE_ADC_RCU);
  136. gpio_init(W_PHASE_ADC_GROUP, W_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, W_PHASE_ADC_PIN);
  137. #endif
  138. #ifdef VBUS_V_ADC_GROUP
  139. rcu_periph_clock_enable(VBUS_V_ADC_RCU);
  140. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  141. gpio_init(VBUS_V_ADC_GROUP, VBUS_V_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_V_ADC_PIN);
  142. #endif
  143. #ifdef THROTTLE_V_ADC_GROUP
  144. rcu_periph_clock_enable(THROTTLE_V_ADC_RCU);
  145. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  146. gpio_init(THROTTLE_V_ADC_GROUP, THROTTLE_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_V_ADC_PIN);
  147. #endif
  148. #ifdef TEMP_V_ADC_GROUP
  149. rcu_periph_clock_enable(TEMP_V_ADC_GROUP);
  150. /* configure ADC pin, temperature sampling -- ADC_IN11(PC1) */
  151. gpio_init(TEMP_V_ADC_GROUP, TEMP_V_ADC_MODE, GPIO_OSPEED_50MHZ, TEMP_V_ADC_PIN);
  152. #endif
  153. #ifdef U_VOL_ADC_GROUP
  154. rcu_periph_clock_enable(U_VOL_ADC_RCU);
  155. gpio_init(U_VOL_ADC_GROUP, U_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, U_VOL_ADC_PIN);
  156. #endif
  157. #ifdef V_VOL_ADC_GROUP
  158. rcu_periph_clock_enable(V_VOL_ADC_RCU);
  159. gpio_init(V_VOL_ADC_GROUP, V_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, V_VOL_ADC_PIN);
  160. #endif
  161. #ifdef W_VOL_ADC_GROUP
  162. rcu_periph_clock_enable(W_VOL_ADC_RCU);
  163. gpio_init(W_VOL_ADC_GROUP, W_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, W_VOL_ADC_PIN);
  164. #endif
  165. #ifdef MOS_TEMP_ADC_CHAN
  166. rcu_periph_clock_enable(MOS_TEMP_ADC_RCU);
  167. gpio_init(MOS_TEMP_ADC_CHAN, MOS_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP_ADC_PIN);
  168. #endif
  169. #ifdef MOTOR_TEMP_ADC_CHAN
  170. rcu_periph_clock_enable(MOTOR_TEMP_ADC_RCU);
  171. gpio_init(MOTOR_TEMP_ADC_CHAN, MOTOR_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOTOR_TEMP_ADC_PIN);
  172. #endif
  173. }
  174. void adc_init(void) {
  175. adc_gpio_init();
  176. #ifdef REG_CHAN_DMA
  177. adc_dma_init();
  178. #endif
  179. adc0_init();
  180. adc1_init();
  181. adc_current_sample_config(0);
  182. }
  183. u16 adc_get_vbus(void) {
  184. return adc_buffer[0];
  185. }
  186. u16 adc_get_throttle(void) {
  187. return adc_buffer[1];
  188. }
  189. void adc_get_uvw_phaseV(u16 *uvw) {
  190. uvw[0] = adc_buffer[2];
  191. uvw[1] = adc_buffer[3];
  192. uvw[2] = adc_buffer[4];
  193. }
  194. u16 adc_get_mos_temp(void) {
  195. return adc_buffer[5];
  196. }
  197. u16 adc_get_motor_temp(void) {
  198. return adc_buffer[6];
  199. }
  200. void adc_start_convert(void) {
  201. int drop = 2;
  202. /* clear the ADC flag */
  203. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  204. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  205. adc_enable_ext_trigger();
  206. while(drop-- > 0) {
  207. while (adc_flag_get(ADC0, ADC_FLAG_EOIC) == RESET);
  208. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  209. }
  210. /* enable ADC interrupt */
  211. adc_interrupt_enable(ADC0, ADC_INT_EOIC);
  212. adc_update_ext_trigger(ADC_TRIGGER_PHASE);
  213. }
  214. void adc_stop_convert(void) {
  215. adc_disable_ext_trigger();
  216. /* disable ADC interrupt */
  217. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  218. /* clear the ADC flag */
  219. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  220. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  221. }
  222. s32 adc_sample_regular_channel(int channel, int times) {
  223. #ifndef REG_CHAN_DMA
  224. u32 adc_device = ADC0;
  225. int value = 0;
  226. int count = 0;
  227. int min = 0xFFFFF;
  228. int max = -0xFFFFF;
  229. u64 start_time;
  230. adc_channel_length_config(adc_device, ADC_REGULAR_CHANNEL, 1);
  231. adc_regular_channel_config(adc_device, 0, channel, ADC_REGCHAN_SAMPLE_TIME);
  232. while(count < times){
  233. restart:
  234. start_time = shark_get_mseconds();
  235. adc_software_trigger_enable(adc_device, ADC_REGULAR_CHANNEL);
  236. while(SET != adc_flag_get(adc_device, ADC_FLAG_EOC)){
  237. if (shark_get_mseconds() - start_time >= 2){
  238. goto restart;
  239. }
  240. };
  241. int one = adc_regular_data_read(adc_device);
  242. adc_flag_clear(adc_device, ADC_FLAG_EOC);
  243. value += (one & 0xFFF);
  244. count ++;
  245. if (one > max){
  246. max = one;
  247. }
  248. if (one < min) {
  249. min = one;
  250. }
  251. }
  252. if (times <= 2) {
  253. return value/times;
  254. }
  255. return (value - min - max)/(times-2);
  256. #else
  257. return 0;
  258. #endif
  259. }