adc.c 13 KB

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