调整pwm占空比

int led_set_pwm(int pwm_num, struct nled_setting* led)
{
/*
struct pwm_spec_config pwm_setting;
int time_index = 0;
pwm_setting.pwm_no = pwm_num;
pwm_setting.mode = PWM_MODE_OLD;
    
        //LEDS_DEBUG("[LED]led_set_pwm: mode = %d, pwm_no = %d\n", led->nled_mode, pwm_num);  
// Only old PWM mode with 32kHz clock source can work in the system sleep mode
pwm_setting.clk_src = PWM_CLK_OLD_MODE_32K;


switch (led->nled_mode)
{


            
case 1 :
pwm_setting.PWM_MODE_OLD_REGS.THRESH = 8100;
pwm_setting.clk_div = CLK_DIV1;
pwm_setting.PWM_MODE_OLD_REGS.DATA_WIDTH = 8100;
break;
            


}


pwm_setting.PWM_MODE_FIFO_REGS.IDLE_VALUE = 0;
pwm_setting.PWM_MODE_FIFO_REGS.GUARD_VALUE = 0;
pwm_setting.PWM_MODE_FIFO_REGS.WAVE_NUM = 0;
pwm_setting.PWM_MODE_OLD_REGS.GDURATION = 8100;




pwm_set_spec_config(&pwm_setting);
*/
    struct pwm_spec_config pwm_setting;  
    pwm_setting.pwm_no = pwm_num;  
    pwm_setting.mode = PWM_MODE_FIFO; //new mode fifo and periodical mode  
    pwm_setting.clk_div = CLK_DIV1;  
    pwm_setting.clk_src = PWM_CLK_NEW_MODE_BLOCK;//PWM_CLK_NEW_MODE_BLOCK_DIV_BY_1625;  
      
    pwm_setting.PWM_MODE_FIFO_REGS.IDLE_VALUE = 0;  
    pwm_setting.PWM_MODE_FIFO_REGS.GUARD_VALUE = 0;  
    pwm_setting.PWM_MODE_FIFO_REGS.STOP_BITPOS_VALUE = 63;  
    pwm_setting.PWM_MODE_FIFO_REGS.HDURATION = 4;  
    pwm_setting.PWM_MODE_FIFO_REGS.LDURATION = 4;  
    pwm_setting.PWM_MODE_FIFO_REGS.GDURATION = 0;  
    pwm_setting.PWM_MODE_FIFO_REGS.WAVE_NUM = 0;  
    u32 level = 20;
    //LEDS_DEBUG("[LED]backlight_set_pwm:duty is %d\n", level);  
    if(level <= 32)  
    {  
        pwm_setting.PWM_MODE_FIFO_REGS.SEND_DATA0 =  (1 << level) - 1 ;  
        pwm_setting.PWM_MODE_FIFO_REGS.SEND_DATA1 = 0 ;  
    }else if(level>32 && level <=64)  
    {  
       //level -= 32;//32  
       if(level>28)level=28; //鍥犱负纭欢鐨勪寒搴︾瓑绾ф槸0--31,32涓瓑绾с€傛垜浠妸纭欢鐨勬渶澶т寒搴︾瓑绾ц缃负28锛屼篃杈惧埌浜嗙洰鐨勩€? 
        pwm_setting.PWM_MODE_FIFO_REGS.SEND_DATA0 =  0xFFFFFFFF ;  
        pwm_setting.PWM_MODE_FIFO_REGS.SEND_DATA1 = (1 << level) - 1;  
    }else  
    {  
        //LEDS_DEBUG("[LED]Error level in backlight\n");  
    }  
  
    pwm_set_spec_config(&pwm_setting);  
return 0;

}




mt_set_gpio_mode(GPIO129, 1);
mt_set_gpio_dir(GPIO129, GPIO_DIR_OUT);
//mt_set_gpio_out(GPIO129, GPIO_OUT_ONE);
struct nled_setting led_tmp_setting = {1,0,0};
       led_set_pwm(1, &led_tmp_setting);

在STM32中,可以使用外部中断来触发定时器的更新事件,从而实现PWM占空比调整。具体步骤如下: 1. 初始化外部中断,使其可以触发定时器的更新事件。 2. 初始化定时器,设置PWM的周期和初始占空比。 3. 在定时器中断处理函数中,根据外部中断的触发来更新PWM占空比。 下面是一个简单的示例代码: ```c #include "stm32f10x.h" void EXTI0_IRQHandler(void) // 外部中断处理函数 { TIM_OCInitTypeDef TIM_OCInitStructure; if (EXTI_GetITStatus(EXTI_Line0) != RESET) { TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; TIM_OCInitStructure.TIM_Pulse = 1000; // 占空比为50% TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; TIM_OC1Init(TIM1, &TIM_OCInitStructure); EXTI_ClearITPendingBit(EXTI_Line0); } } int main(void) { GPIO_InitTypeDef GPIO_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; // 使能外部中断所在的GPIO和外部中断线 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource0); EXTI_InitTypeDef EXTI_InitStructure; EXTI_InitStructure.EXTI_Line = EXTI_Line0; EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt; EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising; EXTI_InitStructure.EXTI_LineCmd = ENABLE; EXTI_Init(&EXTI_InitStructure); // 使能定时器时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE); // 配置定时器为PWM输出模式 TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_TimeBaseStructure.TIM_Period = 2000 - 1; // PWM周期为2ms TIM_TimeBaseStructure.TIM_Prescaler = 72 - 1; // 定时器分频系数为72 TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure); TIM_Cmd(TIM1, ENABLE); // 配置定时器的PWM通道 TIM_OCInitTypeDef TIM_OCInitStructure; TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; TIM_OCInitStructure.TIM_Pulse = 1000; // 初始占空比为50% TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; TIM_OC1Init(TIM1, &TIM_OCInitStructure); // 配置外部中断的中断向量 NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); while (1) { // 主循环中可以执行其他任务 } } ``` 相关问题: 1. 怎样通过stm32控制pwm输出? 2. 外部中断有哪些触发方式? 3. stm32的定时器有哪些工作模式?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值