adc.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  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. #if (CONFIG_MC105_HW_VERSION==2)
  7. #define ADC01_NUM 6
  8. #define MOS_TEMP_BUFF_IDX 0
  9. #define VBUS_V_BUFF_IDX 1
  10. #define VREF5v_BUFF_IDX 2 //需要跳线修改mos的第二路温感采集模拟5v
  11. #define ACC_V_BUFF_IDX 3
  12. #define U_VOL_BUFF_IDX 4
  13. #define VBUS_I_BUFF_IDX 5
  14. #define V_VOL_BUFF_IDX 6
  15. #define THROTTLE_BUFF_IDX 7
  16. #define W_VOL_BUFF_IDX 8
  17. #define VREF_BUFF_IDX 10
  18. #define MOTOR_TEMP_BUFF_IDX 11
  19. #define REG_CHAN_NUM (ADC01_NUM + ADC01_NUM)
  20. #define ADC_DUAL_MODE ADC_DAUL_REGULAL_PARALLEL_INSERTED_PARALLEL
  21. #elif (CONFIG_MC105_HW_VERSION==3)
  22. #define ADC01_NUM (9)
  23. #define MOS_TEMP_BUFF_IDX 0
  24. #define VBUS_V_BUFF_IDX 1
  25. #define MOTOR_TEMP_BUFF_IDX 2
  26. #define ACC_V_BUFF_IDX 3
  27. #define THROTTLE_BUFF_IDX 4
  28. #define VBUS_I_BUFF_IDX 5
  29. #define THROTTLE2_BUFF_IDX 6
  30. #define V_VOL_BUFF_IDX 7
  31. //zero chan 8
  32. #define W_VOL_BUFF_IDX 9
  33. #define VREF_BUFF_IDX 10
  34. //zero chan 11
  35. #define THROTTLE2_5V_BUFF_IDX 12
  36. #define THROTTLE_5V_BUFF_IDX 13
  37. #define U_VOL_BUFF_IDX 14
  38. //zero chan 15
  39. //zero chan 16
  40. #define VREF5v_BUFF_IDX 17
  41. #define REG_CHAN_NUM (ADC01_NUM + ADC01_NUM)
  42. #define ADC_DUAL_MODE ADC_DAUL_REGULAL_PARALLEL_INSERTED_PARALLEL
  43. #endif
  44. s16 adc_buffer[REG_CHAN_NUM];
  45. float vref_adc = 1408.0f;
  46. float vref_5v_adc = 2047.0f;
  47. #define VREF_ADC_DATA 1509.0F //1498, 1.21/3.3*4095
  48. static void adc01_dma_init(void)
  49. {
  50. dma_parameter_struct dma_init_struct;
  51. rcu_periph_clock_enable(RCU_DMA0);
  52. dma_deinit(DMA0, DMA_CH0);
  53. dma_init_struct.direction = DMA_PERIPHERAL_TO_MEMORY;
  54. dma_init_struct.memory_addr = (uint32_t)adc_buffer;
  55. dma_init_struct.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  56. dma_init_struct.memory_width = DMA_MEMORY_WIDTH_32BIT;
  57. dma_init_struct.number = REG_CHAN_NUM/2;
  58. dma_init_struct.periph_addr = (uint32_t)(&ADC_RDATA(ADC0));
  59. dma_init_struct.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  60. dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_32BIT;
  61. dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH;
  62. dma_init(DMA0, DMA_CH0, &dma_init_struct);
  63. dma_circulation_enable(DMA0, DMA_CH0);
  64. dma_memory_to_memory_disable(DMA0, DMA_CH0);
  65. dma_channel_enable(DMA0, DMA_CH0);
  66. }
  67. static void adc01_init(void) {
  68. /* config ADC clock */
  69. rcu_adc_clock_config(RCU_CKADC_CKAPB2_DIV4); //APB2 clk 120M, adc clk 30M
  70. rcu_periph_clock_enable(RCU_ADC0);
  71. rcu_periph_clock_enable(RCU_ADC1);
  72. adc_deinit(ADC0);
  73. adc_deinit(ADC1);
  74. /* config work mode */
  75. adc_special_function_config(ADC0, ADC_CONTINUOUS_MODE, ENABLE);
  76. adc_special_function_config(ADC0, ADC_SCAN_MODE, ENABLE);
  77. adc_special_function_config(ADC1, ADC_CONTINUOUS_MODE, ENABLE);
  78. adc_special_function_config(ADC1, ADC_SCAN_MODE, ENABLE);
  79. /* configure ADC data alignment */
  80. adc_data_alignment_config(ADC0, ADC_DATAALIGN_RIGHT);
  81. adc_data_alignment_config(ADC1, ADC_DATAALIGN_RIGHT);
  82. /* configure ADC regular channel */
  83. #if (CONFIG_MC105_HW_VERSION==2)
  84. adc_channel_length_config(ADC0, ADC_REGULAR_CHANNEL, ADC01_NUM);
  85. adc_regular_channel_config(ADC0, 0, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  86. adc_regular_channel_config(ADC0, 1, MOS_TEMP1_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  87. adc_regular_channel_config(ADC0, 2, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  88. adc_regular_channel_config(ADC0, 3, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  89. adc_regular_channel_config(ADC0, 4, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  90. adc_regular_channel_config(ADC0, 5, ADC_CHANNEL_17, ADC_REGCHAN_SAMPLE_TIME);//3.3vref
  91. adc_tempsensor_vrefint_enable();
  92. adc_channel_length_config(ADC1, ADC_REGULAR_CHANNEL, ADC01_NUM);
  93. adc_regular_channel_config(ADC1, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  94. adc_regular_channel_config(ADC1, 1, ACC_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  95. adc_regular_channel_config(ADC1, 2, VBUS_I_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  96. adc_regular_channel_config(ADC1, 3, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  97. adc_regular_channel_config(ADC1, 4, ADC_CHANNEL_10, ADC_REGCHAN_SAMPLE_TIME); //dumy
  98. adc_regular_channel_config(ADC1, 5, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  99. #else
  100. adc_channel_length_config(ADC0, ADC_REGULAR_CHANNEL, ADC01_NUM);
  101. adc_regular_channel_config(ADC0, 0, MOS_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  102. adc_regular_channel_config(ADC0, 1, MOTOR_TEMP_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  103. adc_regular_channel_config(ADC0, 2, THROTTLE_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  104. adc_regular_channel_config(ADC0, 3, THROTTLE2_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  105. adc_regular_channel_config(ADC0, 4, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  106. adc_regular_channel_config(ADC0, 5, ADC_CHANNEL_17, ADC_REGCHAN_SAMPLE_TIME); //mcu内部vref
  107. adc_regular_channel_config(ADC0, 6, THROTTLE2_5V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  108. adc_regular_channel_config(ADC0, 7, U_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  109. adc_regular_channel_config(ADC0, 8, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  110. adc_tempsensor_vrefint_enable();
  111. adc_channel_length_config(ADC1, ADC_REGULAR_CHANNEL, ADC01_NUM);
  112. adc_regular_channel_config(ADC1, 0, VBUS_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  113. adc_regular_channel_config(ADC1, 1, ACC_V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  114. adc_regular_channel_config(ADC1, 2, VBUS_I_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  115. adc_regular_channel_config(ADC1, 3, V_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  116. adc_regular_channel_config(ADC1, 4, W_VOL_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  117. adc_regular_channel_config(ADC1, 5, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  118. adc_regular_channel_config(ADC1, 6, THROTTLE_5V_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  119. adc_regular_channel_config(ADC1, 7, ZERO_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME); //insert zero vol
  120. adc_regular_channel_config(ADC1, 8, DC5V_ADC_CHAN, ADC_REGCHAN_SAMPLE_TIME);
  121. #endif
  122. adc_buffer[VREF_BUFF_IDX] = VREF_ADC_DATA; //1.21/3.3*4095
  123. /* configure ADC regular channel trigger */
  124. adc_external_trigger_source_config(ADC0, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  125. adc_external_trigger_source_config(ADC1, ADC_REGULAR_CHANNEL, ADC0_1_2_EXTTRIG_REGULAR_NONE);
  126. adc_external_trigger_config(ADC0, ADC_REGULAR_CHANNEL, ENABLE);
  127. adc_external_trigger_config(ADC1, ADC_REGULAR_CHANNEL, ENABLE);
  128. /* configure ADC inserted channel length */
  129. adc_channel_length_config(ADC0, ADC_INSERTED_CHANNEL, INJ_CHAN_NUM);
  130. adc_inserted_channel_config(ADC0, 0, V_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  131. #if (INJ_CHAN_NUM==4)
  132. adc_inserted_channel_config(ADC0, 1, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  133. adc_inserted_channel_config(ADC0, 2, V_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  134. adc_inserted_channel_config(ADC0, 3, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  135. #endif
  136. adc_channel_length_config(ADC1, ADC_INSERTED_CHANNEL, INJ_CHAN_NUM);
  137. adc_inserted_channel_config(ADC1, 0, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  138. #if (INJ_CHAN_NUM==4)
  139. adc_inserted_channel_config(ADC1, 1, V_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  140. adc_inserted_channel_config(ADC1, 2, W_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  141. adc_inserted_channel_config(ADC1, 3, V_PHASE_I_CHAN, ADC_INSERT_SAMPLE_TIME);
  142. #endif
  143. adc_mode_config(ADC_DUAL_MODE);
  144. /* configure ADC inserted channel trigger */
  145. adc_external_trigger_source_config(ADC0, ADC_INSERTED_CHANNEL, ADC_TRIGGER_PHASE);
  146. /* ADC external trigger enable */
  147. adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
  148. /* ADC1 external trigger disable */
  149. adc_external_trigger_source_config(ADC1, ADC_INSERTED_CHANNEL, ADC_TRIGGER_NONE);
  150. adc_external_trigger_config(ADC1, ADC_INSERTED_CHANNEL, ENABLE);
  151. /* enable ADC interface */
  152. adc_enable(ADC0);
  153. delay_ms(1);
  154. /* ADC calibration and reset calibration */
  155. adc_calibration_enable(ADC0);
  156. adc_enable(ADC1);
  157. delay_ms(1);
  158. /* ADC calibration and reset calibration */
  159. adc_calibration_enable(ADC1);
  160. adc_dma_mode_enable(ADC0);
  161. adc_disable_ext_trigger();
  162. nvic_irq_enable(ADC0_1_IRQn, ADC_IRQ_PRIORITY, 0);
  163. //start regular channels
  164. adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
  165. }
  166. static void adc_gpio_init(void) {
  167. rcu_periph_clock_enable(RCU_AF);
  168. /* configure ADC pin, current sampling -- ADC_IN1(PA1) ADC_IN12(PC2) ADC_IN13(PC3) */
  169. #ifdef U_PHASE_ADC_GROUP
  170. rcu_periph_clock_enable(U_PHASE_ADC_RCU);
  171. gpio_init(U_PHASE_ADC_GROUP, U_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, U_PHASE_ADC_PIN);
  172. #endif
  173. #ifdef V_PHASE_ADC_GROUP
  174. rcu_periph_clock_enable(V_PHASE_ADC_RCU);
  175. gpio_init(V_PHASE_ADC_GROUP, V_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, V_PHASE_ADC_PIN);
  176. #endif
  177. #ifdef W_PHASE_ADC_GROUP
  178. rcu_periph_clock_enable(W_PHASE_ADC_RCU);
  179. gpio_init(W_PHASE_ADC_GROUP, W_PHASE_ADC_MODE, GPIO_OSPEED_50MHZ, W_PHASE_ADC_PIN);
  180. #endif
  181. #ifdef VBUS_V_ADC_GROUP
  182. rcu_periph_clock_enable(VBUS_V_ADC_RCU);
  183. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  184. gpio_init(VBUS_V_ADC_GROUP, VBUS_V_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_V_ADC_PIN);
  185. #endif
  186. #ifdef VBUS_I_ADC_GROUP
  187. rcu_periph_clock_enable(VBUS_I_ADC_RCU);
  188. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  189. gpio_init(VBUS_I_ADC_GROUP, VBUS_I_ADC_MODE, GPIO_OSPEED_50MHZ, VBUS_I_ADC_PIN);
  190. #endif
  191. #ifdef ACC_V_ADC_GROUP
  192. rcu_periph_clock_enable(ACC_V_ADC_RCU);
  193. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  194. gpio_init(ACC_V_ADC_GROUP, ACC_V_ADC_MODE, GPIO_OSPEED_50MHZ, ACC_V_ADC_PIN);
  195. #endif
  196. #ifdef THROTTLE_V_ADC_GROUP
  197. rcu_periph_clock_enable(THROTTLE_V_ADC_RCU);
  198. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  199. gpio_init(THROTTLE_V_ADC_GROUP, THROTTLE_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_V_ADC_PIN);
  200. #endif
  201. #ifdef THROTTLE2_V_ADC_GROUP
  202. rcu_periph_clock_enable(THROTTLE2_V_ADC_RCU);
  203. gpio_init(THROTTLE2_V_ADC_GROUP, THROTTLE2_V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_V_ADC_PIN);
  204. #endif
  205. #ifdef THROTTLE_5V_ADC_GROUP
  206. rcu_periph_clock_enable(THROTTLE_5V_ADC_RCU);
  207. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  208. gpio_init(THROTTLE_5V_ADC_GROUP, THROTTLE_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE_5V_ADC_PIN);
  209. #endif
  210. #ifdef THROTTLE2_5V_ADC_GROUP
  211. rcu_periph_clock_enable(THROTTLE2_5V_ADC_RCU);
  212. /* configure ADC pin, bus voltage sampling -- ADC_IN0(PA0) */
  213. gpio_init(THROTTLE2_5V_ADC_GROUP, THROTTLE2_5V_ADC_MODE, GPIO_OSPEED_50MHZ, THROTTLE2_5V_ADC_PIN);
  214. #endif
  215. #ifdef U_VOL_ADC_GROUP
  216. rcu_periph_clock_enable(U_VOL_ADC_RCU);
  217. gpio_init(U_VOL_ADC_GROUP, U_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, U_VOL_ADC_PIN);
  218. #endif
  219. #ifdef V_VOL_ADC_GROUP
  220. rcu_periph_clock_enable(V_VOL_ADC_RCU);
  221. gpio_init(V_VOL_ADC_GROUP, V_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, V_VOL_ADC_PIN);
  222. #endif
  223. #ifdef W_VOL_ADC_GROUP
  224. rcu_periph_clock_enable(W_VOL_ADC_RCU);
  225. gpio_init(W_VOL_ADC_GROUP, W_VOL_ADC_MODE, GPIO_OSPEED_50MHZ, W_VOL_ADC_PIN);
  226. #endif
  227. #ifdef MOS_TEMP_ADC_GROUP
  228. rcu_periph_clock_enable(MOS_TEMP_ADC_RCU);
  229. gpio_init(MOS_TEMP_ADC_GROUP, MOS_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP_ADC_PIN);
  230. #endif
  231. #ifdef MOS_TEMP1_ADC_GROUP
  232. rcu_periph_clock_enable(MOS_TEMP1_ADC_RCU);
  233. gpio_init(MOS_TEMP1_ADC_GROUP, MOS_TEMP1_ADC_MODE, GPIO_OSPEED_50MHZ, MOS_TEMP1_ADC_PIN);
  234. #endif
  235. #ifdef MOTOR_TEMP_ADC_GROUP
  236. rcu_periph_clock_enable(MOTOR_TEMP_ADC_RCU);
  237. gpio_init(MOTOR_TEMP_ADC_GROUP, MOTOR_TEMP_ADC_MODE, GPIO_OSPEED_50MHZ, MOTOR_TEMP_ADC_PIN);
  238. #endif
  239. #ifdef ZERO_ADC_GROUP
  240. rcu_periph_clock_enable(ZERO_ADC_RCU);
  241. gpio_init(ZERO_ADC_GROUP, ZERO_ADC_MODE, GPIO_OSPEED_50MHZ, ZERO_ADC_PIN);
  242. #endif
  243. #ifdef DC5V_ADC_GROUP
  244. rcu_periph_clock_enable(DC5V_ADC_RCU);
  245. gpio_init(DC5V_ADC_GROUP, DC5V_ADC_MODE, GPIO_OSPEED_50MHZ, DC5V_ADC_PIN);
  246. #endif
  247. }
  248. void adc_init(void) {
  249. adc_gpio_init();
  250. adc01_dma_init();
  251. adc01_init();
  252. adc_current_sample_config(0);
  253. }
  254. void adc_set_vref_calc(float v) {
  255. vref_adc = v;
  256. }
  257. void adc_set_5vref_calc(float v) {
  258. vref_5v_adc = v;
  259. }
  260. #define VREF_COMP_LFP_CEOF (0.0001F)
  261. static float vref_compestion_filter = 1.0f;
  262. #define VREF_3V3_COMPESTION() (vref_adc/(float)adc_buffer[VREF_BUFF_IDX])
  263. void adc_3v3ref_filter(void) {
  264. float value = VREF_3V3_COMPESTION();
  265. LowPass_Filter(vref_compestion_filter, value, VREF_COMP_LFP_CEOF);
  266. }
  267. float adc_vref_compesion(void) {
  268. return vref_compestion_filter;
  269. }
  270. static float vref_5v_compestion_filter = 1.0f;
  271. #define VREF_5V_COMPESTION() (vref_5v_adc/(float)adc_buffer[VREF5v_BUFF_IDX])
  272. void adc_5vref_filter(void) {
  273. float value = VREF_5V_COMPESTION();
  274. LowPass_Filter(vref_5v_compestion_filter, value, VREF_COMP_LFP_CEOF);
  275. }
  276. float adc_5vref_compesion(void) {
  277. return vref_5v_compestion_filter;
  278. }
  279. void adc_vref_filter(void) {
  280. adc_3v3ref_filter();
  281. adc_5vref_filter();
  282. }
  283. u16 adc_get_vbus(void) {
  284. return (float)adc_buffer[VBUS_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  285. }
  286. u16 adc_get_acc(void) {
  287. return (float)adc_buffer[ACC_V_BUFF_IDX] * VREF_3V3_COMPESTION();
  288. }
  289. u16 adc_get_ibus(void) {
  290. return (float)adc_buffer[VBUS_I_BUFF_IDX] * VREF_5V_COMPESTION();
  291. }
  292. u16 adc_get_throttle(void) {
  293. #if CONFIG_MC105_HW_VERSION==3
  294. if (gpio_board_id() == CONFIG_MC105_VER3_ID2) { //v3 和 V4 adc 通道交换了一下
  295. return adc_buffer[THROTTLE_BUFF_IDX] * VREF_3V3_COMPESTION();
  296. }else {
  297. return adc_buffer[MOTOR_TEMP_BUFF_IDX] * VREF_3V3_COMPESTION();
  298. }
  299. #else
  300. return adc_buffer[THROTTLE_BUFF_IDX] * VREF_3V3_COMPESTION();
  301. #endif
  302. }
  303. u16 adc_get_throttle2(void) {
  304. #ifdef THROTTLE2_BUFF_IDX
  305. return adc_buffer[THROTTLE2_BUFF_IDX] * VREF_3V3_COMPESTION();
  306. #else
  307. return adc_get_throttle();
  308. #endif
  309. }
  310. u16 adc_get_thro_5v(void) {
  311. #ifdef THROTTLE_5V_BUFF_IDX
  312. return adc_buffer[THROTTLE_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  313. #else
  314. return 0xFFFF;
  315. #endif
  316. }
  317. u16 adc_get_thro2_5v(void) {
  318. #ifdef THROTTLE2_5V_BUFF_IDX
  319. return adc_buffer[THROTTLE2_5V_BUFF_IDX] * VREF_3V3_COMPESTION();
  320. #else
  321. return 0xFFFF;
  322. #endif
  323. }
  324. void adc_get_uvw_phaseV(u16 *uvw) {
  325. uvw[0] = adc_buffer[U_VOL_BUFF_IDX];
  326. uvw[1] = adc_buffer[V_VOL_BUFF_IDX];
  327. uvw[2] = adc_buffer[W_VOL_BUFF_IDX];
  328. }
  329. u16 adc_get_mos_temp(void) {
  330. return adc_buffer[MOS_TEMP_BUFF_IDX];
  331. }
  332. u16 adc_get_motor_temp(void) {
  333. #if CONFIG_MC105_HW_VERSION==3
  334. if (gpio_board_id() == CONFIG_MC105_VER3_ID2) {
  335. return adc_buffer[MOTOR_TEMP_BUFF_IDX];
  336. }else {
  337. return adc_buffer[THROTTLE_BUFF_IDX];
  338. }
  339. #else
  340. return adc_buffer[MOTOR_TEMP_BUFF_IDX];
  341. #endif
  342. }
  343. u16 adc_get_vref(void) {
  344. return adc_buffer[VREF_BUFF_IDX];
  345. }
  346. u16 adc_get_5v_ref(void) {
  347. return adc_buffer[VREF5v_BUFF_IDX];
  348. }
  349. void adc_start_convert(void) {
  350. int drop = 16;
  351. /* clear the ADC flag */
  352. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  353. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  354. adc_enable_ext_trigger();
  355. while(drop-- > 0) {
  356. while (adc_flag_get(ADC0, ADC_FLAG_EOIC) == RESET);
  357. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  358. }
  359. /* enable ADC interrupt */
  360. adc_interrupt_enable(ADC0, ADC_INT_EOIC);
  361. adc_update_ext_trigger(ADC_TRIGGER_PHASE);
  362. }
  363. void adc_stop_convert(void) {
  364. adc_disable_ext_trigger();
  365. /* disable ADC interrupt */
  366. adc_interrupt_disable(ADC0, ADC_INT_EOIC);
  367. /* clear the ADC flag */
  368. adc_flag_clear(ADC0, ADC_FLAG_EOIC);
  369. adc_flag_clear(ADC1, ADC_FLAG_EOIC);
  370. }
  371. s32 adc_sample_regular_channel(int channel, int times) {
  372. #ifndef REG_CHAN_DMA
  373. u32 adc_device = ADC0;
  374. int value = 0;
  375. int count = 0;
  376. int min = 0xFFFFF;
  377. int max = -0xFFFFF;
  378. u64 start_time;
  379. adc_channel_length_config(adc_device, ADC_REGULAR_CHANNEL, 1);
  380. adc_regular_channel_config(adc_device, 0, channel, ADC_REGCHAN_SAMPLE_TIME);
  381. while(count < times){
  382. restart:
  383. start_time = shark_get_mseconds();
  384. adc_software_trigger_enable(adc_device, ADC_REGULAR_CHANNEL);
  385. while(SET != adc_flag_get(adc_device, ADC_FLAG_EOC)){
  386. if (shark_get_mseconds() - start_time >= 2){
  387. goto restart;
  388. }
  389. };
  390. int one = adc_regular_data_read(adc_device);
  391. adc_flag_clear(adc_device, ADC_FLAG_EOC);
  392. value += (one & 0xFFF);
  393. count ++;
  394. if (one > max){
  395. max = one;
  396. }
  397. if (one < min) {
  398. min = one;
  399. }
  400. }
  401. if (times <= 2) {
  402. return value/times;
  403. }
  404. return (value - min - max)/(times-2);
  405. #else
  406. return 0;
  407. #endif
  408. }