目录
1. FOSC
2. Fsys和 Fusb4x
H549的系统时钟是通过CLOCK_CFG配置的。写CLOCK_CFG前必须先进入安全模式。复位后的默认状态下,Fosc=24MHz,Fpll=96MHz,Fusb4x=48MHz,Fsys=12MHz。
内部时钟或者外部时钟经过二选一后作为原始时钟 Fosc,都为24MHz。
SAFE_MOD = 0x55;
SAFE_MOD = 0xAA;
#if OSC_EN_XT
CLOCK_CFG |= bOSC_EN_XT; //使能外部晶振
CLOCK_CFG &= ~bOSC_EN_INT; //关闭内部晶振
#else
CLOCK_CFG |= bOSC_EN_INT; //使能内部晶振
CLOCK_CFG &= ~bOSC_EN_XT; //关闭外部晶振
#endif
Fosc经过PLL倍频后产生 Fpll 高频时钟,然后分为2组频率,一组专门给USB使用,固定48MHz,而另一种是系统时钟Fsys,由CLOCK_CFG配置。Fsys提供时钟给所有外设。
SAFE_MOD = 0x55;SAFE_MOD = 0xAA;
#if FOSC == 48000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x07; // 48MHz
#endif
#if FOSC == 32000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x06; // 32MHz
#endif
#if FOSC == 24000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x05; // 24MHz
#endif
#if FOSC == 16000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x04; // 16MHz
#endif
#if FOSC == 12000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x03; // 12MHz
#endif
#if FOSC == 3000000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x02; // 3MHz
#endif
#if FOSC == 750000LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x01; // 750KHz
#endif
#if FOSC == 187500LCLOCK_CFG = CLOCK_CFG & ~ MASK_SYS_CK_SEL | 0x00; // 187.5KHz
#endifSAFE_MOD = 0x00;
本文发布于:2024-01-29 15:04:50,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170651189416127.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |