RT
看源码,只有设置外设时钟的代码,如:刚设置TMR3_S,又设置TMR1_S,这个时候TMR3_S位被赋值为0.如下面的代码
DrvSYS_SelectIPClockSource(E_SYS_TMR0_CLKSRC, 0);
DrvSYS_SelectIPClockSource(E_SYS_TMR1_CLKSRC, 0);
DrvSYS_SelectIPClockSource(E_SYS_TMR2_CLKSRC, 0);
DrvSYS_SelectIPClockSource(E_SYS_TMR3_CLKSRC, 0);
函数DrvSYS_SelectIPClockSource(******)如下
int32_t DrvSYS_SelectIPClockSource(E_SYS_IP_CLKSRC eIpClkSrc, uint8_t u8ClkSrcSel)
{
switch(eIpClkSrc)
{
case E_SYS_FRQDIV_CLKSRC:
SYSCLK->CLKSEL2.FRQDIV_S = u8ClkSrcSel;
break;
case E_SYS_I2S_CLKSRC:
SYSCLK->CLKSEL2.I2S_S = u8ClkSrcSel;
break;
case E_SYS_PWM67_CLKSRC:
SYSCLK->CLKSEL2.PWM67_S = u8ClkSrcSel;
break;
case E_SYS_PWM45_CLKSRC:
SYSCLK->CLKSEL2.PWM45_S = u8ClkSrcSel;
break;
case E_SYS_PWM23_CLKSRC:
SYSCLK->CLKSEL1.PWM23_S = u8ClkSrcSel;
break;
case E_SYS_PWM01_CLKSRC:
SYSCLK->CLKSEL1.PWM01_S = u8ClkSrcSel;
break;
case E_SYS_UART_CLKSRC:
SYSCLK->CLKSEL1.UART_S = u8ClkSrcSel;
break;
case E_SYS_TMR3_CLKSRC:
SYSCLK->CLKSEL1.TMR3_S = u8ClkSrcSel;
break;
case E_SYS_TMR2_CLKSRC:
SYSCLK->CLKSEL1.TMR2_S = u8ClkSrcSel;
break;
case E_SYS_TMR1_CLKSRC:
SYSCLK->CLKSEL1.TMR1_S = u8ClkSrcSel;
break;
case E_SYS_TMR0_CLKSRC:
SYSCLK->CLKSEL1.TMR0_S = u8ClkSrcSel;
break;
case E_SYS_ADC_CLKSRC:
SYSCLK->CLKSEL1.ADC_S = u8ClkSrcSel;
break;
case E_SYS_WDT_CLKSRC:
SYSCLK->CLKSEL1.WDT_S = u8ClkSrcSel;
break;
default:
return E_DRVSYS_ERR_IPSRC;
}
return E_SUCCESS;
}
倒是GPIO的寄存器倒是按照读,修改,写的方式赋值的/
有奖活动 | |
---|---|
“我踩过的那些坑”主题活动——第002期 | |
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |