打印
[技术问答]

M058S的HCLK时钟源设置方式,寄存器与库函数差异

[复制链接]
550|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
上面的寄存器配置方式是例子中的,例子未能使用库函数配置。我查找库函数找到了一条说明与上面寄存器配置说明一样的函数,不知道是否是一样的。

另外看,库函数包含了寄存器的这四条操作内容,但是多了一些其他的考虑,是否说,库函数做的更加保险?
void CLK_SetHCLK(uint32_t u32ClkSrc, uint32_t u32ClkDiv)
{
    uint32_t u32HIRCSTB;

    /* Read HIRC clock source stable flag */
    u32HIRCSTB = CLK->CLKSTATUS & CLK_CLKSTATUS_OSC22M_STB_Msk;

    /* Switch to HIRC for Safe. Avoid HCLK too high when applying new divider. */
    CLK->PWRCON |= CLK_PWRCON_OSC22M_EN_Msk;
    CLK_WaitClockReady(CLK_CLKSTATUS_OSC22M_STB_Msk);
    CLK->CLKSEL0 = (CLK->CLKSEL0 & (~CLK_CLKSEL0_HCLK_S_Msk)) | CLK_CLKSEL0_HCLK_S_HIRC;

    /* Apply new Divider */
    CLK->CLKDIV = (CLK->CLKDIV & (~CLK_CLKDIV_HCLK_N_Msk)) | u32ClkDiv;

    /* Switch HCLK to new HCLK source */
    CLK->CLKSEL0 = (CLK->CLKSEL0 & (~CLK_CLKSEL0_HCLK_S_Msk)) | u32ClkSrc;

    /* Update System Core Clock */
    SystemCoreClockUpdate();

    /* Disable HIRC if HIRC is disabled before switching HCLK source */
    if(u32HIRCSTB == 0)
        CLK->PWRCON &= ~CLK_PWRCON_OSC22M_EN_Msk;
}


使用特权

评论回复
沙发
yiy| | 2023-10-10 15:24 | 只看该作者
这个差异应该是个花招,应该左移24,再右移24,最后就又折腾回去了。这个在编译阶段就给还原了。

使用特权

评论回复
板凳
yiy| | 2023-10-10 15:25 | 只看该作者
推荐使用寄存器这个,这个考虑更加全面。

使用特权

评论回复
地板
华力电子| | 2023-10-10 17:23 | 只看该作者
这个问题,可以找新唐技术支持问一下qq 1593449604

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

180

主题

2301

帖子

8

粉丝