enc_intf.c 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. #include "bsp/bsp_driver.h"
  2. #include "libs/logger.h"
  3. static void _io_init(void) {
  4. rcu_periph_clock_enable(ENC_A_RCU);
  5. rcu_periph_clock_enable(ENC_B_RCU);
  6. rcu_periph_clock_enable(ENC_PWM_RCU);
  7. rcu_periph_clock_enable(ENC_I_RCU);
  8. #ifdef TIMER2_PB4_PB5_REMAP
  9. gpio_pin_remap_config(TIMER2_PB4_PB5_REMAP, ENABLE);
  10. #endif
  11. #ifdef TIMER1_PA15_REMAP
  12. gpio_pin_remap_config(TIMER1_PA15_REMAP, ENABLE);
  13. #endif
  14. gpio_init(ENC_A_GROUP, ENC_A_MODE, GPIO_OSPEED_50MHZ, ENC_A_PIN);
  15. gpio_init(ENC_B_GROUP, ENC_B_MODE, GPIO_OSPEED_50MHZ, ENC_B_PIN);
  16. gpio_init(ENC_PWM_GROUP, ENC_PWM_MODE, GPIO_OSPEED_50MHZ, ENC_PWM_PIN);
  17. gpio_init(ENC_I_GROUP, ENC_I_MODE, GPIO_OSPEED_50MHZ, ENC_I_PIN);
  18. }
  19. static void z_io_init_irq(void) {
  20. #ifdef ENC_I_IRQ
  21. gpio_exti_source_select(ENC_I_EXIT_SRC_GROUP, ENC_I_EXIT_SRC_PIN);
  22. exti_init(ENC_I_EXTI, EXTI_INTERRUPT, EXTI_TRIG_RISING);
  23. exti_interrupt_flag_clear(ENC_I_EXTI);
  24. exti_interrupt_enable(ENC_I_EXTI);
  25. nvic_irq_enable(ENC_I_IRQ, ENC_I_EXIT_IRQ_PRIORITY, 0U);
  26. #endif
  27. }
  28. void enc_intf_init(u32 rate) {
  29. _io_init();
  30. enc_intf_pwm_counter();
  31. enc_intf_quadrature_init(rate);
  32. z_io_init_irq();
  33. enc_intf_z_counter();
  34. }
  35. void enc_intf_quadrature_init(u32 rate) {
  36. timer_parameter_struct timer_initpara;
  37. timer_ic_parameter_struct timer_icinitpara;
  38. u32 timer = ENC_TIMER;
  39. rcu_periph_clock_enable(ENC_TIMER_RCU);
  40. timer_deinit(timer);
  41. /* TIMER configuration */
  42. timer_struct_para_init(&timer_initpara);
  43. timer_initpara.prescaler = 0;//TIM_CLOCK/PWM_TIME_CLK - 1;
  44. timer_initpara.alignedmode = TIMER_COUNTER_EDGE;
  45. timer_initpara.counterdirection = TIMER_COUNTER_UP;
  46. timer_initpara.period = rate-1;
  47. timer_initpara.clockdivision = TIMER_CKDIV_DIV1;
  48. timer_initpara.repetitioncounter = 0;
  49. timer_init(timer,&timer_initpara);
  50. /* initialize TIMER channel input parameter struct */
  51. timer_channel_input_struct_para_init(&timer_icinitpara);
  52. /* TIMER2 CH0 input capture configuration */
  53. timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING;
  54. timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
  55. timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
  56. timer_icinitpara.icfilter = CONFIG_ENC_FILTER_NR;//采样频率120M, 这个必须要加入滤波,否则AB的计数可能不对
  57. timer_input_capture_config(timer,TIMER_CH_0,&timer_icinitpara);
  58. timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING;
  59. timer_input_capture_config(timer,TIMER_CH_1,&timer_icinitpara);
  60. timer_quadrature_decoder_mode_config(timer ,TIMER_ENCODER_MODE2,TIMER_IC_POLARITY_FALLING, TIMER_IC_POLARITY_RISING);
  61. /* auto-reload preload enable */
  62. timer_auto_reload_shadow_enable(timer);
  63. timer_interrupt_flag_clear(timer, TIMER_INT_FLAG_UP);
  64. //timer_interrupt_enable(timer, TIMER_INT_UP);
  65. //nvic_irq_enable(ENC_TIMER_IRQ, ENC_TIMER_IRQ_PRIORITY, 0);
  66. /* TIMER2 counter enable */
  67. timer_enable(timer);
  68. }
  69. void enc_intf_pwm_counter(void) {
  70. timer_ic_parameter_struct timer_icinitpara;
  71. timer_parameter_struct timer_initpara;
  72. u32 timer = ENC_PWM_TIMER;
  73. rcu_periph_clock_enable(ENC_PWM_TIMER_RCU);
  74. timer_deinit(timer);
  75. /* TIMER configuration */
  76. timer_struct_para_init(&timer_initpara);
  77. timer_initpara.prescaler = TIM_CLOCK/PWM_TIME_CLK - 1;
  78. timer_initpara.alignedmode = TIMER_COUNTER_EDGE;
  79. timer_initpara.counterdirection = TIMER_COUNTER_UP;
  80. timer_initpara.period = 65535;
  81. timer_initpara.clockdivision = TIMER_CKDIV_DIV1;
  82. timer_initpara.repetitioncounter = 0;
  83. timer_init(timer,&timer_initpara);
  84. timer_channel_input_struct_para_init(&timer_icinitpara);
  85. /* TIMER CH0 PWM input capture configuration */
  86. timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING;
  87. timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
  88. timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
  89. timer_icinitpara.icfilter = CONFIG_PWM_FILTER_NR;
  90. timer_input_pwm_capture_config(timer, ENC_PWM_TIMER_CHAN, &timer_icinitpara);
  91. /* slave mode selection: TIMER */
  92. timer_input_trigger_source_select(timer, TIMER_SMCFG_TRGSEL_CI0FE0);
  93. timer_slave_mode_select(timer, TIMER_SLAVE_MODE_RESTART);
  94. /* select the master slave mode */
  95. timer_master_slave_mode_config(timer, TIMER_MASTER_SLAVE_MODE_ENABLE);
  96. /* auto-reload preload enable */
  97. timer_auto_reload_shadow_enable(timer);
  98. /* clear channel 0 interrupt bit */
  99. timer_interrupt_flag_clear(timer, ENC_PWM_TIMER_INT_FLG);
  100. /* channel 0 interrupt enable */
  101. timer_interrupt_enable(timer, ENC_PWM_TIMER_IRQ_CH);
  102. nvic_irq_enable(ENC_PWM_TIMER_IRQ, ENC_PWM_IRQ_PRIORITY, 0);
  103. /* TIMER2 counter enable */
  104. timer_enable(timer);
  105. }
  106. void enc_intf_z_counter(void) {
  107. #ifdef ENC_I_TIMER
  108. timer_ic_parameter_struct timer_icinitpara;
  109. timer_parameter_struct timer_initpara;
  110. u32 timer = ENC_I_TIMER;
  111. rcu_periph_clock_enable(ENC_I_TIMER_RCU);
  112. timer_deinit(timer);
  113. /* TIMER configuration */
  114. timer_struct_para_init(&timer_initpara);
  115. timer_initpara.prescaler = TIM_CLOCK/PWM_TIME_CLK - 1;
  116. timer_initpara.alignedmode = TIMER_COUNTER_EDGE;
  117. timer_initpara.counterdirection = TIMER_COUNTER_UP;
  118. timer_initpara.period = 65535;
  119. timer_initpara.clockdivision = TIMER_CKDIV_DIV1;
  120. timer_initpara.repetitioncounter = 0;
  121. timer_init(timer,&timer_initpara);
  122. timer_channel_input_struct_para_init(&timer_icinitpara);
  123. /* TIMER CH0 PWM input capture configuration */
  124. timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING;
  125. timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
  126. timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
  127. timer_icinitpara.icfilter = CONFIG_PWM_FILTER_NR;
  128. timer_input_capture_config(timer, ENC_I_TIMER_CHAN, &timer_icinitpara);
  129. /* slave mode selection: TIMER */
  130. timer_input_trigger_source_select(timer, TIMER_SMCFG_TRGSEL_CI0FE0);
  131. timer_slave_mode_select(timer, TIMER_SLAVE_MODE_RESTART);
  132. /* select the master slave mode */
  133. timer_master_slave_mode_config(timer, TIMER_MASTER_SLAVE_MODE_ENABLE);
  134. /* auto-reload preload enable */
  135. timer_auto_reload_shadow_enable(timer);
  136. /* clear channel 0 interrupt bit */
  137. timer_interrupt_flag_clear(timer, ENC_I_TIMER_INT_FLG);
  138. /* channel 0 interrupt enable */
  139. timer_interrupt_enable(timer, ENC_I_TIMER_IRQ_CH);
  140. nvic_irq_enable(ENC_I_TIMER_IRQ, ENC_I_EXIT_IRQ_PRIORITY, 0);
  141. /* TIMER2 counter enable */
  142. timer_enable(timer);
  143. #endif
  144. }
  145. __weak void ENC_TIMER_Overflow(void) {
  146. }
  147. void ENC_TIMER_IRQHandler(void) {
  148. if (SET == timer_interrupt_flag_get(ENC_TIMER, TIMER_INT_FLAG_UP)) {
  149. timer_interrupt_flag_clear(ENC_TIMER, TIMER_INT_FLAG_UP);
  150. ENC_TIMER_Overflow();
  151. }
  152. }
  153. __weak void ENC_ABI_IRQHandler(void) {
  154. }
  155. void ABI_I_IRQHandler(void) {
  156. #ifdef ENC_I_IRQ
  157. ENC_ABI_IRQHandler();
  158. #endif
  159. }
  160. void ENC_I_IRQHandler(void) {
  161. #ifdef ENC_I_TIMER
  162. if(SET == timer_interrupt_flag_get(ENC_I_TIMER, ENC_I_TIMER_INT_FLG)){
  163. /* clear channel 0 interrupt bit */
  164. timer_interrupt_flag_clear(ENC_I_TIMER, ENC_I_TIMER_INT_FLG);
  165. ENC_ABI_IRQHandler();
  166. }
  167. #endif
  168. }
  169. __weak void ENC_PWM_Duty_Handler(float t, float d) {
  170. }
  171. static float pwm_freq = 0.0f;
  172. void ENC_PWM_IRQHandler(void) {
  173. if(SET == timer_interrupt_flag_get(ENC_PWM_TIMER, ENC_PWM_TIMER_INT_FLG)){
  174. /* clear channel 0 interrupt bit */
  175. timer_interrupt_flag_clear(ENC_PWM_TIMER, ENC_PWM_TIMER_INT_FLG);
  176. /* read channel 0 capture value */
  177. u32 ic0value = TIMER_CH0CV(ENC_PWM_TIMER)+1;
  178. u32 ic1value = TIMER_CH1CV(ENC_PWM_TIMER)+1;
  179. float p_calc = ENC_PWM_Calc_P(ic0value);
  180. float d_calc = ENC_PWM_Calc_P(ic1value);
  181. ENC_PWM_Duty_Handler(p_calc, d_calc);
  182. pwm_freq = (float)PWM_TIME_CLK/((float)ic0value);
  183. }
  184. }
  185. float enc_get_pwm_freq(void) {
  186. return pwm_freq;
  187. }