pwm.h 3.8 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 ch0_update_duty(duty) MOS_PWM_TIMER->c1dt = (uint32_t)duty
  24. #define ch1_update_duty(duty) MOS_PWM_TIMER->c2dt = (uint32_t)duty
  25. #define ch2_update_duty(duty) MOS_PWM_TIMER->c3dt = (uint32_t)duty
  26. #define update_adc_trigger(time) MOS_PWM_TIMER->c4dt = (uint32_t)time
  27. #ifdef CONFIG_PWM_UV_SWAP
  28. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  29. do {\
  30. ch0_update_duty(dutyC);\
  31. ch1_update_duty(dutyB);\
  32. ch2_update_duty(dutyA);\
  33. }while(0)
  34. #else
  35. #define pwm_update_duty(dutyA, dutyB, dutyC) \
  36. do {\
  37. ch0_update_duty(dutyA);\
  38. ch1_update_duty(dutyB);\
  39. ch2_update_duty(dutyC);\
  40. }while(0)
  41. #endif
  42. #define pwm_update_2smaples(samp1, sampl2) \
  43. do { \
  44. MOS_PWM_TIMER->c4dt = (uint32_t)samp1; \
  45. }while(0)
  46. #define pwm_clear_updata() \
  47. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT);
  48. #define pwm_wait_and_clear_updata() \
  49. do { \
  50. while ( tmr_flag_get(MOS_PWM_TIMER, TMR_OVF_INT) == RESET ); \
  51. timer_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  52. }while(0)
  53. #define pwm_change_t3_mode(m) \
  54. do { \
  55. if (MOS_PWM_TIMER->cm2_output_bit.c4octrl != m) { \
  56. MOS_PWM_TIMER->cm2_output_bit.c4octrl = m; \
  57. } \
  58. }while(0)
  59. #define pwm_brake_enable(n) \
  60. do { \
  61. if (n) { \
  62. nvic_irq_enable(TMR1_BRK_TMR9_IRQn, EBREAK_IRQ_PRIORITY, 0); \
  63. }else { \
  64. nvic_irq_disable(TMR1_BRK_TMR9_IRQn); \
  65. } \
  66. }while(0)
  67. #define pwm_up_enable(n) \
  68. do { \
  69. if (n) { \
  70. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  71. tmr_interrupt_enable(MOS_PWM_TIMER, TMR_OVF_INT, TRUE); \
  72. }else { \
  73. tmr_flag_clear(MOS_PWM_TIMER, TMR_OVF_INT); \
  74. tmr_interrupt_enable(MOS_PWM_TIMER, TMR_OVF_INT, FALSE); \
  75. } \
  76. }while(0)
  77. #define get_deadtime() (MOS_PWM_TIMER->brk_bit.dtc)
  78. #define PWM_Direction_Down() true
  79. void pwm_3phase_init(void);
  80. void pwm_3phase_sides(bool hon, bool lon);
  81. void pwm_start(void);
  82. void pwm_stop(void);
  83. void pwm_turn_on_low_side(void);
  84. void pwm_enable_output(bool enable);
  85. void pwm_update_sample(u32 samp1, u32 samp2, u8 sector);
  86. #endif /*_PWM_H__*/