STM8S TIM2 输出PWM初始化函数

/*
  * @brief  Simple calulate square  number.
  * @param1  Base number
  * @param2  Exponent number       
  * @retval Number of base^number
  * @author: icerol

*/

unsigned long pow(uint base , uint exponent)
{
    uint temp = 1;
    for(uint i=0; i< exponent; i++)
    {
        temp *= base;
    }
    return  temp;
}

#define TIM2_CH1 0x01
#define TIM2_CH2 0x02
#define TIM2_CH3 0x04
#define F_MASTER 16000000UL
/*
  * @brief  Initial timer2 for pwm output.
  * @param1  PWM output channal, TIM2_CH1 | TIM2_CH2 | TIM2_CH3
  * @param2  PWM putput frequency, Unit: Hz                    
  * @param3-5 PWM duty for CH1-3, range:0-100
  * @retval None
  * @author: icerol

*/
void  timer2_pwm_Init(unsigned char channal, unsigned long hz,unsigned char pwm1, unsigned char pwm2,unsigned char pwm3)
{
    unsigned char pscr=0;
    double tim2_clk;
    for(pscr=0;pscr<0x10;pscr++)
    {
      tim2_clk = F_MASTER/(pow(2,pscr));
      if((tim2_clk/hz)<0xffff)
      {
        break;
      }
    }

    double basecycle = 1000000000/tim2_clk;//us
    double hzcycle=1000000000/hz;
    double arr = hzcycle/basecycle;
    TIM2_ARRH = (unsigned int)(arr)/256;
    TIM2_ARRL = (unsigned int)(arr)%256;
    
    if(channal & TIM2_CH1)
    {
         TIM2_CCMR1 |= 0x70;
         TIM2_CCER1 |= 0x03;      //通道1使能,低电平有效,配置为输出
         TIM2_CCR1H = ((arr*pwm1)/100)/256;
         TIM2_CCR1L = ((arr*pwm1)/100)%256;
    }
    if(channal & TIM2_CH2)
    {
         TIM2_CCMR2 |= 0x70;
         TIM2_CCER1 |= 0x30;      //通道2
         TIM2_CCR2H = ((arr*pwm2)/100)/256;
         TIM2_CCR2L = ((arr*pwm2)/100)%256;
         
    }
   if((channal & TIM2_CH3))
    {
         TIM2_CCMR3 |= 0x70;       //01110000
         TIM2_CCER2 |= 0x03;     //通道3
         TIM2_CCR3H = ((arr*pwm3)/100)/256;
         TIM2_CCR3L = ((arr*pwm3)/100)%256;
         
    }
    TIM2_PSCR = pscr;
    TIM2_CR1 = TIM2_CR1 | 0x01;
    CLK_PCKENR1 = 0x20;
}

 
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值