adc.c 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  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 ADC1_NUM 3
  7. #define ADC2_NUM 3
  8. #define U_VOL_BUFF_IDX 0
  9. #define V_VOL_BUFF_IDX 1
  10. #define W_VOL_BUFF_IDX 2
  11. #define VBUS_I_BUFF_IDX 3
  12. #define MOS_TEMP_BUFF_IDX 4
  13. #define VBUS_V_BUFF_IDX 5
  14. #define REG_CHAN_NUM (ADC1_NUM + ADC2_NUM)
  15. u16 adc_buffer[REG_CHAN_NUM];
  16. static bool adc_inited = false;
  17. static void analog_gpio_init(gpio_type *gpiox, u32 pin) {
  18. gpio_init_type gpio_init_struct = {0};
  19. /* gpio configuration */
  20. gpio_default_para_init(&gpio_init_struct);
  21. gpio_init_struct.gpio_mode = GPIO_MODE_ANALOG;
  22. gpio_init_struct.gpio_pins = pin;
  23. gpio_init(gpiox, &gpio_init_struct);
  24. }
  25. static void adc01_dma_init(void)
  26. {
  27. dma_init_type dma_init_struct;
  28. /* dma clock configuration */
  29. crm_periph_clock_enable(CRM_DMA1_PERIPH_CLOCK, TRUE);
  30. /* dma configuration */
  31. dma_reset(DMA1_CHANNEL1);
  32. dma_default_para_init(&dma_init_struct);
  33. dma_init_struct.buffer_size = REG_CHAN_NUM/2;
  34. dma_init_struct.direction = DMA_DIR_PERIPHERAL_TO_MEMORY;
  35. dma_init_struct.memory_base_addr = (uint32_t)adc_buffer;
  36. dma_init_struct.memory_data_width = DMA_MEMORY_DATA_WIDTH_WORD;
  37. dma_init_struct.memory_inc_enable = TRUE;
  38. dma_init_struct.peripheral_base_addr = (uint32_t)&(ADC1->odt);
  39. dma_init_struct.peripheral_data_width = DMA_PERIPHERAL_DATA_WIDTH_WORD;
  40. dma_init_struct.peripheral_inc_enable = FALSE;
  41. dma_init_struct.priority = DMA_PRIORITY_HIGH;
  42. dma_init_struct.loop_mode_enable = TRUE;
  43. dma_init(DMA1_CHANNEL1, &dma_init_struct);
  44. /* Flexible Mode Channel Cofig */
  45. dma_flexible_config(DMA1, FLEX_CHANNEL1, DMA_FLEXIBLE_ADC1);
  46. dma_channel_enable(DMA1_CHANNEL1, TRUE);
  47. }
  48. static void adc_preempt_channel_set_samples(adc_type *adc_x, adc_channel_select_type adc_channel, adc_sampletime_select_type adc_sampletime)
  49. {
  50. switch(adc_channel)
  51. {
  52. case ADC_CHANNEL_0:
  53. adc_x->spt2_bit.cspt0 = adc_sampletime;
  54. break;
  55. case ADC_CHANNEL_1:
  56. adc_x->spt2_bit.cspt1 = adc_sampletime;
  57. break;
  58. case ADC_CHANNEL_2:
  59. adc_x->spt2_bit.cspt2 = adc_sampletime;
  60. break;
  61. case ADC_CHANNEL_3:
  62. adc_x->spt2_bit.cspt3 = adc_sampletime;
  63. break;
  64. case ADC_CHANNEL_4:
  65. adc_x->spt2_bit.cspt4 = adc_sampletime;
  66. break;
  67. case ADC_CHANNEL_5:
  68. adc_x->spt2_bit.cspt5 = adc_sampletime;
  69. break;
  70. case ADC_CHANNEL_6:
  71. adc_x->spt2_bit.cspt6 = adc_sampletime;
  72. break;
  73. case ADC_CHANNEL_7:
  74. adc_x->spt2_bit.cspt7 = adc_sampletime;
  75. break;
  76. case ADC_CHANNEL_8:
  77. adc_x->spt2_bit.cspt8 = adc_sampletime;
  78. break;
  79. case ADC_CHANNEL_9:
  80. adc_x->spt2_bit.cspt9 = adc_sampletime;
  81. break;
  82. case ADC_CHANNEL_10:
  83. adc_x->spt1_bit.cspt10 = adc_sampletime;
  84. break;
  85. case ADC_CHANNEL_11:
  86. adc_x->spt1_bit.cspt11 = adc_sampletime;
  87. break;
  88. case ADC_CHANNEL_12:
  89. adc_x->spt1_bit.cspt12 = adc_sampletime;
  90. break;
  91. case ADC_CHANNEL_13:
  92. adc_x->spt1_bit.cspt13 = adc_sampletime;
  93. break;
  94. case ADC_CHANNEL_14:
  95. adc_x->spt1_bit.cspt14 = adc_sampletime;
  96. break;
  97. case ADC_CHANNEL_15:
  98. adc_x->spt1_bit.cspt15 = adc_sampletime;
  99. break;
  100. case ADC_CHANNEL_16:
  101. adc_x->spt1_bit.cspt16 = adc_sampletime;
  102. break;
  103. case ADC_CHANNEL_17:
  104. adc_x->spt1_bit.cspt17 = adc_sampletime;
  105. break;
  106. default:
  107. break;
  108. }
  109. }
  110. static void adc01_init(void){
  111. adc_base_config_type adc_base_struct;
  112. /* adc clock configuration */
  113. crm_adc_clock_div_set(CRM_ADC_DIV_8); /* PCLK2 Max. CLK = 100M Hz, ADC_CLK = 100/4 = 25M Hz */
  114. crm_periph_clock_enable(CRM_ADC1_PERIPH_CLOCK, TRUE);
  115. crm_periph_clock_enable(CRM_ADC2_PERIPH_CLOCK, TRUE);
  116. adc_reset(ADC1);
  117. adc_reset(ADC2);
  118. /* select adc mster-slave mode */
  119. adc_combine_mode_select(ADC_ORDINARY_SMLT_PREEMPT_SMLT_MODE);
  120. adc_base_struct.sequence_mode = TRUE;
  121. adc_base_struct.repeat_mode = TRUE;
  122. adc_base_struct.data_align = ADC_RIGHT_ALIGNMENT;
  123. adc_base_struct.ordinary_channel_length = ADC1_NUM;
  124. adc_base_config(ADC1, &adc_base_struct);
  125. adc_base_config(ADC2, &adc_base_struct);
  126. /* ordinary channel configuration */
  127. adc_ordinary_channel_set(ADC1, U_VOL_ADC_CHAN, 1, ADC_REGCHAN_SAMPLE_TIME);
  128. adc_ordinary_channel_set(ADC1, W_VOL_ADC_CHAN, 2, ADC_REGCHAN_SAMPLE_TIME);
  129. adc_ordinary_channel_set(ADC1, MOS_TEMP_ADC_CHAN, 3, ADC_REGCHAN_SAMPLE_TIME);
  130. adc_ordinary_conversion_trigger_set(ADC1, ADC12_ORDINARY_TRIG_SOFTWARE, TRUE);
  131. adc_dma_mode_enable(ADC1, TRUE);
  132. adc_ordinary_channel_set(ADC2, V_VOL_ADC_CHAN, 1, ADC_REGCHAN_SAMPLE_TIME);
  133. adc_ordinary_channel_set(ADC2, VBUS_I_CHAN, 2, ADC_REGCHAN_SAMPLE_TIME);
  134. adc_ordinary_channel_set(ADC2, VBUS_V_CHAN, 3, ADC_REGCHAN_SAMPLE_TIME);
  135. adc_ordinary_conversion_trigger_set(ADC2, ADC12_ORDINARY_TRIG_SOFTWARE, TRUE);
  136. adc_preempt_channel_length_set(ADC1, 1);
  137. adc_preempt_channel_set(ADC1, U_PHASE_I_CHAN, 1, ADC_INSERT_SAMPLE_TIME);
  138. adc_preempt_channel_set_samples(ADC1, V_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  139. adc_preempt_channel_set_samples(ADC1, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  140. /* adc prempt trigger source */
  141. adc_preempt_conversion_trigger_set(ADC1, ADC12_PREEMPT_TRIG_TMR1CH4, TRUE);
  142. adc_preempt_channel_length_set(ADC2, 1);
  143. adc_preempt_channel_set(ADC2, V_PHASE_I_CHAN, 1, ADC_INSERT_SAMPLE_TIME);
  144. adc_preempt_channel_set_samples(ADC2, U_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  145. adc_preempt_channel_set_samples(ADC2, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  146. /* adc prempt trigger source */
  147. adc_preempt_conversion_trigger_set(ADC2, ADC12_PREEMPT_TRIG_TMR1CH4, TRUE);
  148. //adc_tempersensor_vintrv_enable(TRUE);
  149. /* ADC enable and calibration */
  150. adc_enable(ADC1, TRUE);
  151. adc_calibration_init(ADC1);
  152. while(adc_calibration_init_status_get(ADC1));
  153. adc_calibration_start(ADC1);
  154. while(adc_calibration_status_get(ADC1));
  155. adc_enable(ADC2, TRUE);
  156. adc_calibration_init(ADC2);
  157. while(adc_calibration_init_status_get(ADC2));
  158. adc_calibration_start(ADC2);
  159. while(adc_calibration_status_get(ADC2));
  160. nvic_irq_enable(ADC1_2_IRQn, ADC_IRQ_PRIORITY, 0);
  161. adc_disable_ext_trigger();
  162. adc_current_sample_config(PHASE_AB);
  163. adc_ordinary_software_trigger_enable(ADC1, TRUE);
  164. }
  165. static void adc_gpio_init(void) {
  166. #ifdef U_PHASE_ADC_GROUP
  167. crm_periph_clock_enable(U_PHASE_ADC_RCU, TRUE);
  168. analog_gpio_init(U_PHASE_ADC_GROUP, U_PHASE_ADC_PIN);
  169. #endif
  170. #ifdef V_PHASE_ADC_GROUP
  171. crm_periph_clock_enable(V_PHASE_ADC_RCU, TRUE);
  172. analog_gpio_init(V_PHASE_ADC_GROUP, V_PHASE_ADC_PIN);
  173. #endif
  174. #ifdef W_PHASE_ADC_GROUP
  175. crm_periph_clock_enable(W_PHASE_ADC_RCU, TRUE);
  176. analog_gpio_init(W_PHASE_ADC_GROUP, W_PHASE_ADC_PIN);
  177. #endif
  178. #ifdef VBUS_V_ADC_GROUP
  179. crm_periph_clock_enable(VBUS_V_ADC_RCU, TRUE);
  180. analog_gpio_init(VBUS_V_ADC_GROUP, VBUS_V_ADC_PIN);
  181. #endif
  182. #ifdef VBUS_I_ADC_GROUP
  183. crm_periph_clock_enable(VBUS_I_ADC_RCU, TRUE);
  184. analog_gpio_init(VBUS_I_ADC_GROUP, VBUS_I_ADC_PIN);
  185. #endif
  186. #ifdef U_VOL_ADC_GROUP
  187. crm_periph_clock_enable(U_VOL_ADC_RCU, TRUE);
  188. analog_gpio_init(U_VOL_ADC_GROUP, U_VOL_ADC_PIN);
  189. #endif
  190. #ifdef V_VOL_ADC_GROUP
  191. crm_periph_clock_enable(V_VOL_ADC_RCU, TRUE);
  192. analog_gpio_init(V_VOL_ADC_GROUP, V_VOL_ADC_PIN);
  193. #endif
  194. #ifdef W_VOL_ADC_GROUP
  195. crm_periph_clock_enable(W_VOL_ADC_RCU, TRUE);
  196. analog_gpio_init(W_VOL_ADC_GROUP, W_VOL_ADC_PIN);
  197. #endif
  198. #ifdef MOS_TEMP_ADC_GROUP
  199. crm_periph_clock_enable(MOS_TEMP_ADC_RCU, TRUE);
  200. analog_gpio_init(MOS_TEMP_ADC_GROUP, MOS_TEMP_ADC_PIN);
  201. #endif
  202. }
  203. void adc_init(bool mot_ind) {
  204. if (adc_inited) {
  205. return;
  206. }
  207. adc_gpio_init();
  208. adc01_dma_init();
  209. adc01_init();
  210. adc_inited = true;
  211. }
  212. void adc_set_vref_calc(float v) {
  213. }
  214. void adc_set_5vref_calc(float v) {
  215. }
  216. static float vref_compestion_filter = 1.0f;
  217. #define VREF_3V3_COMPESTION() (vref_compestion_filter)
  218. float adc_vref_compesion(void) {
  219. return vref_compestion_filter;
  220. }
  221. static float vref_5v_compestion_filter = 1.0f;
  222. #define VREF_5V_COMPESTION() (vref_5v_compestion_filter)
  223. float adc_5vref_compesion(void) {
  224. return vref_5v_compestion_filter;
  225. }
  226. void adc_vref_filter(void) {
  227. }
  228. u16 adc_get_vbus(void) {
  229. return (float)adc_buffer[VBUS_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  230. }
  231. u16 adc_get_acc(void) {
  232. return adc_get_vbus();
  233. }
  234. u16 adc_get_ibus(void) {
  235. return (float)adc_buffer[VBUS_I_BUFF_IDX] * VREF_5V_COMPESTION();
  236. }
  237. u16 adc_get_throttle(void) {
  238. return 0;
  239. }
  240. u16 adc_get_throttle2(void) {
  241. return adc_get_throttle();
  242. }
  243. u16 adc_get_thro_5v(void) {
  244. return 0;
  245. }
  246. u16 adc_get_thro2_5v(void) {
  247. return 0;
  248. }
  249. void adc_get_uvw_phaseV(u16 *uvw) {
  250. uvw[0] = adc_buffer[U_VOL_BUFF_IDX];
  251. uvw[1] = adc_buffer[V_VOL_BUFF_IDX];
  252. uvw[2] = adc_buffer[W_VOL_BUFF_IDX];
  253. }
  254. u16 adc_get_mos_temp(void) {
  255. return adc_buffer[MOS_TEMP_BUFF_IDX];
  256. }
  257. u16 adc_get_motor_temp(void) {
  258. return 0;
  259. }
  260. u16 adc_get_vref(void) {
  261. return 0;
  262. }
  263. u16 adc_get_5v_ref(void) {
  264. return 0;
  265. }
  266. void adc_start_convert(void) {
  267. int drop = 16;
  268. /* clear the ADC flag */
  269. adc_flag_clear(ADC1, ADC_PCCE_FLAG);
  270. adc_flag_clear(ADC2, ADC_PCCE_FLAG);
  271. adc_enable_ext_trigger();
  272. while(drop-- > 0) {
  273. while (adc_flag_get(ADC1, ADC_PCCE_FLAG) == RESET);
  274. adc_flag_clear(ADC1, ADC_PCCE_FLAG);
  275. }
  276. /* enable ADC interrupt */
  277. adc_interrupt_enable(ADC1, ADC_PCCE_INT, TRUE);
  278. adc_update_ext_trigger(ADC_TRIGGER_PHASE);
  279. }
  280. void adc_stop_convert(void) {
  281. adc_disable_ext_trigger();
  282. /* disable ADC interrupt */
  283. adc_interrupt_enable(ADC1, ADC_PCCE_INT, FALSE);
  284. /* clear the ADC flag */
  285. adc_flag_clear(ADC1, ADC_PCCE_FLAG);
  286. adc_flag_clear(ADC2, ADC_PCCE_FLAG);
  287. }