STC32G 时钟系统

时钟系统

系统时钟有4个时钟源可供选择:

  • 内部高精度IRC
  • 内部32KHzIRC(精度较低)
  • 外部晶振
  • 内部PLL输出时钟

主要关心的是两个指标:SYSclk和HSCLK

  • SYSclk是系统的时钟,决定了指令执行速度的快慢。
  • HSCLK是高速时钟,决定外设PWM以及SPI的工作速度。

完整的时钟系统如下
在这里插入图片描述

代码配置

相信大家在学习STC16/32的时候,都在头疼每次下载程序的时候,还要在stc-isp软件中手动选择内部IRC频率。这就很鸡肋了,那玩意儿默认的频率是11.0592MHz,但一般都配置为24MHz或者30MHz,稍不注意主频就被改变了,PWM发出来的信号都是错的,后果可忒严重了。

细看STC32的时钟系统中,有固定频率为48MHz的内部IRC时钟源。想法就来了,我能不能用这玩意儿配置到想要的SYSclk和HSCLK呢?

斗胆试了配置了一下,以IRC48MHz为时钟源,主时钟也选择IRC48MHz,对主时钟进行二分频得到24MHz作为系统时钟SYSclk。为了保持一致性,配置HCLKDIV二分频得到与系统时钟同频的高速时钟HSCLK。代码如下:

void InitClock()
{
	EAXFR = 1;
	CKCON = 0x00;
	WTST = 0x00;

	IRC48MCR = 0x80; // 启动内部48M IRC
	while(!(IRC48MCR & 1)); // 等待稳定
	CLKDIV = 0x02; // 主时钟二分频为系统时钟
	CLKSEL = 0x0c; // 时钟源选择IRC48M
	
	HSCLKDIV = 2; // 高速时钟与系统时钟保持一致
	
	EAXFR = 0;
}

为了验证一下该代码的效果是不是我想要的系统时钟和高速时钟都24MHz。配置MCLKODIV然后输出到外部IO口,外接一个示波器看它的频率。
注:MCKODIV如果太低的话,示波器可能因为信号的频率实在太高而测不出来,因此需要一定的分频,如10分频。

编写测试代码

void TestClock(uint8 port, uint8 div)
{
	EAXFR = 1;
	if (div > 128)
		div = 128;
	
	if(port == 1)
	{
		MCLKOCR = div;
		MCLKOCR &= 0x7F; // 输出到P54
	}
	else if(port == 2)
	{
		MCLKOCR = div;
		MCLKOCR |= 0x80; // 输出到P16
	}
	else
	{
		MCLKOCR = 0x00;
	} 
	
	EAXFR = 0;
}

测试的结果就不放图了,后面写小车循迹一直都用的这样子的代码配置,从此摆脱下载程序的时候手段选择IRC频率的麻烦操作。

总结

通过配置STC32G时钟源为内部IRC固定的48MHz,并对起进行二分频作为固定的时钟频率和高速时钟频率。就不用在下载的时候选择调整内部IRC频率了。

回顾一下STC16的时钟系统。
在这里插入图片描述
STC16是没法选择一个固定的IRC的,每次下载都要手动选择IRC频率。一言难尽。

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今天美美吃饭啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值