pwm.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #ifndef _PWM_H__
  2. #define _PWM_H__
  3. #include "bsp/bsp.h"
  4. #include "os/os_types.h"
  5. #define TIMER_CHCTL2_CH0EN BIT(0) /*!< channel 0 capture/compare function enable */
  6. #define TIMER_CHCTL2_CH0P BIT(1) /*!< channel 0 capture/compare function polarity */
  7. #define TIMER_CHCTL2_CH0NEN BIT(2) /*!< channel 0 complementary output enable */
  8. #define TIMER_CHCTL2_CH0NP BIT(3) /*!< channel 0 complementary output polarity */
  9. #define TIMER_CHCTL2_CH1EN BIT(4) /*!< channel 1 capture/compare function enable */
  10. #define TIMER_CHCTL2_CH1P BIT(5) /*!< channel 1 capture/compare function polarity */
  11. #define TIMER_CHCTL2_CH1NEN BIT(6) /*!< channel 1 complementary output enable */
  12. #define TIMER_CHCTL2_CH1NP BIT(7) /*!< channel 1 complementary output polarity */
  13. #define TIMER_CHCTL2_CH2EN BIT(8) /*!< channel 2 capture/compare function enable */
  14. #define TIMER_CHCTL2_CH2P BIT(9) /*!< channel 2 capture/compare function polarity */
  15. #define TIMER_CHCTL2_CH2NEN BIT(10) /*!< channel 2 complementary output enable */
  16. #define TIMER_CHCTL2_CH2NP BIT(11) /*!< channel 2 complementary output polarity */
  17. #define TIMxCCER_MASK_CH012 ((uint16_t) (TIMER_CHCTL2_CH0EN|TIMER_CHCTL2_CH0NEN|\
  18. TIMER_CHCTL2_CH1EN|TIMER_CHCTL2_CH1NEN|\
  19. TIMER_CHCTL2_CH2EN|TIMER_CHCTL2_CH2NEN))
  20. #define TIMxCCER_MASK_CP ((uint16_t) TIMER_CHCTL2_CH0NP | TIMER_CHCTL2_CH1NP |TIMER_CHCTL2_CH2NP)
  21. #define pwm_enable_channel() {MOS_PWM_TIMER->cctrl |= TIMxCCER_MASK_CH012;}
  22. #define pwm_disable_channel() {MOS_PWM_TIMER->cctrl &= ~TIMxCCER_MASK_CH012;}
  23. #define pwm_channel_is_enabled() ((MOS_PWM_TIMER->cctrl & TIMxCCER_MASK_CH012) != 0)
  24. #define ch0_update_duty(duty) MOS_PWM_TIMER->c1dt = (uint32_t)duty
  25. #define ch1_update_duty(duty) MOS_PWM_TIMER->c2dt = (uint32_t)duty
  26. #define ch2_update_duty(duty) MOS_PWM_TIMER->c3dt = (uint32_t)duty
  27. #define update_adc_trigger(time) MOS_PWM_TIMER->c4dt = (uint32_t)time
  28. #ifdef CONFIG_PWM_UV_SWAP
  29. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  30. do {\
  31. ch0_update_duty(dutyC);\
  32. ch1_update_duty(dutyB);\
  33. ch2_update_duty(dutyA);\
  34. }while(0)
  35. #else
  36. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  37. do {\
  38. ch0_update_duty(dutyA);\
  39. ch1_update_duty(dutyB);\
  40. ch2_update_duty(dutyC);\
  41. }while(0)
  42. #endif
  43. #define pwm_update_2smaples(samp1, sampl2) \
  44. do { \
  45. MOS_PWM_TIMER->c4dt = (uint32_t)samp1; \
  46. }while(0)
  47. #define pwm_clear_updata() \
  48. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT);
  49. #define pwm_wait_and_clear_updata() \
  50. do { \
  51. while ( tmr_flag_get(MOS_PWM_TIMER, TMR_OVF_INT) == RESET ); \
  52. timer_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  53. }while(0)
  54. #define pwm_change_t3_mode(m) \
  55. do { \
  56. if (MOS_PWM_TIMER->cm2_output_bit.c4octrl != m) { \
  57. MOS_PWM_TIMER->cm2_output_bit.c4octrl = m; \
  58. } \
  59. }while(0)
  60. #define pwm_brake_enable(n) \
  61. do { \
  62. if (n) { \
  63. nvic_irq_enable(TMR1_BRK_TMR9_IRQn, EBREAK_IRQ_PRIORITY, 0); \
  64. }else { \
  65. nvic_irq_disable(TMR1_BRK_TMR9_IRQn); \
  66. } \
  67. }while(0)
  68. #define pwm_up_enable(n) \
  69. do { \
  70. if (n) { \
  71. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  72. tmr_interrupt_enable(MOS_PWM_TIMER, TMR_OVF_INT, TRUE); \
  73. }else { \
  74. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  75. tmr_interrupt_enable(MOS_PWM_TIMER, TMR_OVF_INT, FALSE); \
  76. } \
  77. }while(0)
  78. #define get_deadtime() (MOS_PWM_TIMER->brk_bit.dtc)
  79. #define PWM_Direction_Down() true
  80. void pwm_3phase_init(void);
  81. void pwm_3phase_sides(bool hon, bool lon);
  82. void pwm_start(void);
  83. void pwm_stop(void);
  84. void pwm_turn_on_low_side(void);
  85. void pwm_enable_output(bool enable);
  86. void pwm_update_sample(u32 samp1, u32 samp2, u8 sector);
  87. #endif /*_PWM_H__*/