1.6. mcpwm

mcpwm模块支持两路同时输出pwm,共6组,支持故障保护功能,支持复用。

1.6.1. mcpwm_init

mcpwm功能初始化。

原型:

int mcpwm_init(struct mcpwm_config *mcpwm_cfg);

参数:

mcpwm_cfg

mcpwm配置

返回值

mcpwm配置句柄(id号)

1.6.2. mcpwm_deinit

mcpwm功能初始化取消。

原型:

void mcpwm_deinit(int mcpwm_cfg_id);

参数:

rdec_cfg_id

init时返回的句柄(id号)

返回值

1.6.3. mcpwm_start

mcpwm功能启动。

原型:

void mcpwm_start(int mcpwm_cfg_id);

参数:

rdec_cfg_id

init时返回的句柄(id号)

返回值

1.6.4. mcpwm_pause

mcpwm功能暂停。

原型:

void mcpwm_pause(int mcpwm_cfg_id);

参数:

rdec_cfg_id

init时返回的句柄(id号)

返回值

1.6.5. mcpwm_resume

mcpwm功能恢复。

原型:

void mcpwm_resume(int mcpwm_cfg_id);

参数:

rdec_cfg_id

init时返回的句柄(id号)

返回值

1.6.6. mcpwm_set_frequencys

设置mcpwm输出频率,单位Hz。

原型:

void mcpwm_set_frequency(int mcpwm_cfg_id, mcpwm_aligned_mode_type align, u32 frequency);

参数:

rdec_cfg_id

init时返回的句柄(id号)

align

对齐方式:中心对齐、边沿对齐

frequency

频率,单位:Hz

返回值

1.6.7. mcpwm_set_duty

设置mcpwm输出占空比。

原型:

void mcpwm_set_duty(int mcpwm_cfg_id, u16 duty);
参数:

rdec_cfg_id

init时返回的句柄(id号)

duty

占空比,如:5123,51.23%

返回值

1.6.8. mcpwm参考demo

struct mcpwm_config  usr_mcpwm_cfg;

usr_mcpwm_cfg.ch = MCPWM_CH0;                       //通道号
usr_mcpwm_cfg.aligned_mode = MCPWM_EDGE_ALIGNED;    //边沿对齐
usr_mcpwm_cfg.frequency = 1000;                     //1KHz
usr_mcpwm_cfg.duty = 5000;                          //占空比50%
usr_mcpwm_cfg.h_pin = IO_PORTC_00;                  //任意引脚输出,不需要就填-1
usr_mcpwm_cfg.l_pin = IO_PORTC_01;                  //任意引脚输出,不需要就填-1
usr_mcpwm_cfg.complementary_en = 0;                 //两个引脚的波形, 0: 同步, 1: 互补,互补波形的占空比体现在H引脚上
usr_mcpwm_cfg.detect_port = MCPWM_FPIN_NONE;        //选择一个通道作故障保护功能,不需要就填 MCPWM_FPIN_NONE
usr_mcpwm_cfg.edge = MCPWM_EDGE_FAILL;              //检测方式,下升沿触发
usr_mcpwm_cfg.irq_cb = usr_mcpwm_detect_test_func;  //故障保护回调函数
usr_mcpwm_cfg.irq_priority = 1;                     //优先级默认为1
int ch0_id = mcpwm_init(&usr_mcpwm_cfg);
mcpwm_start(ch0_id);