70 lines
2.6 KiB
C
70 lines
2.6 KiB
C
#ifndef _MCPWM_H_
|
||
#define _MCPWM_H_
|
||
|
||
|
||
#include "typedef.h"
|
||
|
||
|
||
/* 对齐方式选择 */
|
||
typedef enum {
|
||
pwm_edge_aligned, ///< 边沿对齐模式
|
||
pwm_center_aligned, ///< 中心对齐模式
|
||
} pwm_aligned_mode_type;
|
||
|
||
/* pwm通道选择 */
|
||
typedef enum {
|
||
pwm_ch0,
|
||
pwm_ch1,
|
||
pwm_ch2,
|
||
pwm_ch3,
|
||
pwm_ch4,
|
||
pwm_ch5,
|
||
pwm_ch_max,
|
||
} pwm_ch_num_type;
|
||
|
||
/* pwm timer通道选择 */
|
||
typedef enum {
|
||
pwm_timer0,
|
||
pwm_timer1,
|
||
pwm_timer2,
|
||
pwm_timer3,
|
||
pwm_timer4,
|
||
pwm_timer5,
|
||
pwm_timer_max,
|
||
} pwm_timer_num_type;
|
||
|
||
/* MCPWM TIMER寄存器 */
|
||
typedef struct _pwm_timer_reg {
|
||
volatile u32 tmr_con;
|
||
volatile u32 tmr_cnt;
|
||
volatile u32 tmr_pr;
|
||
} PWM_TIMER_REG;
|
||
|
||
/* MCPWM通道寄存器 */
|
||
typedef struct _pwm_ch_reg {
|
||
volatile u32 ch_con0;
|
||
volatile u32 ch_con1;
|
||
volatile u32 ch_cmph;
|
||
volatile u32 ch_cmpl;
|
||
} PWM_CH_REG;
|
||
|
||
/* 初始化要用的参数结构体 */
|
||
struct pwm_platform_data {
|
||
u32 frequency; ///< 初始共同频率,CH0, CH, CH2, CH3, CH4
|
||
pwm_ch_num_type pwm_ch_num; ///< 选择pwm通道
|
||
pwm_timer_num_type pwm_timer_num; ///< 选择timer时基
|
||
u16 duty; ///< 初始占空比,0~10000 对应 0%~100% 。每个通道可以有不同的占空比。互补模式的占空比体现在高引脚的波形上。
|
||
pwm_aligned_mode_type pwm_aligned_mode; ///< PWM对齐方式选择
|
||
u8 h_pin; ///< 一个通道的高引脚,建议选择硬件引脚。填入-1 表示没有此引脚。当选择非硬件引脚时,不仅该引脚会输出波形,对应的硬件引脚也会有波形输出。
|
||
u8 l_pin; ///< 一个通道的低引脚,建议选择硬件引脚。填入-1 表示没有此引脚。当选择非硬件引脚时,不仅该引脚会输出波形,对应的硬件引脚也会有波形输出。
|
||
u8 h_pin_output_ch_num; ///< 当高引脚选择了非硬件引脚时,该参数才有效。选用第几个gpio_output_channle, 值:0~2。
|
||
u8 l_pin_output_ch_num; ///< 当高引脚选择了非硬件引脚时,该参数才有效。选用第几个gpio_output_channle, 值:0~2。不能与h_pin_output_ch_num的值一样。
|
||
u8 complementary_en; ///< 该通道的两个引脚输出的波形是否需要互补。1: 同步, 0: 互补
|
||
};
|
||
|
||
|
||
|
||
|
||
#endif
|
||
|