pwm.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #ifndef _PWM_H__
  2. #define _PWM_H__
  3. #include "bsp/bsp.h"
  4. #include "os/os_types.h"
  5. #include "bsp/dma.h"
  6. #define TIMxCCER_MASK_CH012 ((uint16_t) (TIMER_CHCTL2_CH0EN|TIMER_CHCTL2_CH0NEN|\
  7. TIMER_CHCTL2_CH1EN|TIMER_CHCTL2_CH1NEN|\
  8. TIMER_CHCTL2_CH2EN|TIMER_CHCTL2_CH2NEN))
  9. #define pwm_enable_channel() {TIMER_CHCTL2(pwm_timer) |= TIMxCCER_MASK_CH012;}
  10. #define pwm_disable_channel() {TIMER_CHCTL2(pwm_timer) &= ~TIMxCCER_MASK_CH012;}
  11. #define ch0_update_duty(duty) TIMER_CH0CV(pwm_timer) = (uint32_t)duty
  12. #define ch1_update_duty(duty) TIMER_CH1CV(pwm_timer) = (uint32_t)duty
  13. #define ch2_update_duty(duty) TIMER_CH2CV(pwm_timer) = (uint32_t)duty
  14. #define update_adc_trigger(time) TIMER_CH3CV(pwm_timer) = (uint32_t)time
  15. #ifdef CONFIG_PWM_UV_SWAP
  16. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  17. do {\
  18. ch0_update_duty(dutyC);\
  19. ch1_update_duty(dutyB);\
  20. ch2_update_duty(dutyA);\
  21. }while(0)
  22. #else
  23. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  24. do {\
  25. ch0_update_duty(dutyA);\
  26. ch1_update_duty(dutyB);\
  27. ch2_update_duty(dutyC);\
  28. }while(0)
  29. #endif
  30. #define pwm_update_2smaples(samp1, sampl2) \
  31. do { \
  32. TIMER_CH3CV(pwm_timer) = (uint32_t)samp1; \
  33. }while(0)
  34. #define enable_pwm_timer_dma() TIMER_DMAINTEN(pwm_timer) |= (uint32_t) TIMER_DMA_CH3D
  35. #define disable_pwm_timer_dma() TIMER_DMAINTEN(pwm_timer) &= ~((uint32_t) TIMER_DMA_CH3D)
  36. #define pwm_clear_updata() \
  37. timer_flag_clear(pwm_timer, TIMER_FLAG_UP);
  38. #define pwm_wait_and_clear_updata() \
  39. do { \
  40. while ( timer_flag_get(pwm_timer, TIMER_FLAG_UP) == RESET ); \
  41. timer_flag_clear(pwm_timer, TIMER_FLAG_UP); \
  42. }while(0)
  43. #define pwm_change_t3_mode(m) \
  44. do { \
  45. if (((TIMER_CHCTL1(pwm_timer) >> 12) & 0x7) != m) { \
  46. TIMER_CHCTL1(pwm_timer) &= (~(uint32_t)TIMER_CHCTL1_CH3COMCTL); \
  47. TIMER_CHCTL1(pwm_timer) |= (uint32_t)((uint32_t)(m) << 8U); \
  48. } \
  49. }while(0)
  50. #define pwm_brake_enable(n) \
  51. do { \
  52. if (n) { \
  53. nvic_irq_enable(TIMER0_BRK_IRQn, EBREAK_IRQ_PRIORITY, 0); \
  54. }else { \
  55. nvic_irq_disable(TIMER0_BRK_IRQn); \
  56. } \
  57. }while(0)
  58. #define pwm_up_enable(n) \
  59. do { \
  60. if (n) { \
  61. timer_flag_clear(pwm_timer, TIMER_FLAG_UP); \
  62. timer_interrupt_enable(pwm_timer, TIMER_INT_UP); \
  63. }else { \
  64. timer_flag_clear(pwm_timer, TIMER_FLAG_UP); \
  65. timer_interrupt_disable(pwm_timer, TIMER_INT_UP); \
  66. } \
  67. }while(0)
  68. void pwm_3phase_init(void);
  69. void pwm_3phase_sides(bool hon, bool lon);
  70. void pwm_start(void);
  71. void pwm_stop(void);
  72. void pwm_turn_on_low_side(void);
  73. void pwm_enable_output(bool enable);
  74. void pwm_update_sample(u32 samp1, u32 samp2, u8 sector);
  75. #endif /*_PWM_H__*/