时钟的配置

news2024/9/23 0:13:17

        在使用51单片机时,系统使用的时钟源是一个外部晶体振荡器,频率为12M。由于51单片机每个指令周期都是12分频的,所以实际工作频率仅为1M。2440作为一种性能远高于51的Soc,主频肯定要远远高于51,因此2440有着比51单片机复杂的多的时钟系统。从mini2440原理图中可以看出,此开发板也安装了一个12M外部晶体振荡器,实际上到目前为止,我们的程序就运行在12M频率下。但2440内部的时钟控制系统能够使程序运行在更高的频率下。

        接下来我们就需要将2440配置到手册推荐的频率工作。这个频率为:Fclk=400M,Hclk=100M,Pclk = 50M。

        这里引入了三个频率,Fclk、Hclk、Pclk。其中Fclk就是我们经常说的主频,也就是arm内核的工作频率,其实也是代码执行的速率。那么后面两个是什么含义呢?这里我们要理解Soc内部的两大总线AHB和APB。由于Soc有很多外设,这些外设工作时的速率各不相同。如果采用像51那种方法,所有外设工作频率都一样的话,那么对于那些低速外设来说,消耗的功耗就太大了。由于amr内核通常用于便携式设备,而便携式设备对于功耗来说是个非常敏感的问题。所以2440内部被设计出AHB和APB两大总线,分别用于连接高速设备和低速设备,从而尽可能地降低功耗。这里Hclk用于给高速设备AHB总线设备, Pclk用于低速设备

        2440推荐的时钟远高于晶体振荡器所提供的时钟。这是怎么做到的呢?这里就不得不介绍一下PLL这个神器了。PLL(phase locked loop)称之为锁相环,它是一段电路,主要起倍频的作用。我们可以简单理解为,2440内部有几个PLL电路,它们能够把12M频率翻倍到更高的频率上。那么这里至少我们应该知道两种神器:倍频和分频。它们的作用刚好是相反的。配置2440在指定频率下工作。需要参考《2440全套手册》的《时钟发生模块框图》,如下:



        上图是时钟框图中的左上角部分,红圈这个部分是一个选通器,意思是2440的时钟源可以选择:外部晶体振荡器或者是外部时钟。到底用哪个是由2440的两个引脚决定的,从mini2440原理图中可以查到OM2和OM3这两个引脚。发现它们都是接地的,也就是逻辑0。

注:选通器是一种可能有多个输入,但只有一个输出的器件。

        由晶体振荡器输入的12M经过MPLL进行倍频处理,2440中有两个PLL,MPLL和UPLL。其中UPLL用于配置USB设备的工作频率,我么现在用不上,所以我们主要要配置的是MPLL。

        为了操作方便,2440设置了一个名字也叫MPLL的寄存器,这个寄存器中有三个域P,M,S。根据这三个域的值,MPLL将输入的12M倍频出我们需要的Fclk

        上图可以看出,MPLL输出之后经由CLKCNTL寄存器输出了一个Fclk,这个Fclk兵分三路,一路直接共arm920T使用,另外两路各自又进行了一次分频。这里很好理解,由于Fclk经过倍频之后是400M,那么HDIVN需要为4就能分出一个100M来,这就是Hclk;同理如果PDIVN为8那么就是50M,这就是Pclk。
        到此,我们的思路就是配置MPLL寄存器,想办法让它输出一个400M,再找找用于分频的寄存器,把Hclk和Pclk分频成100和50。

        MPLLCON寄存器就是上述用来配置MPLL的。这个寄存器里面的三个部分MDIV、PDIV、SDIV经过合理的设置之后,MPLL就能够产生400M了。这三个值的设置手册给了一个公式:

        很明显,就算有个公式也很难把我们需要的值算出来,好在三星公司直接给出了这三个数的典型值。

由于晶振大小为12M,我们按照红圈给定的值设置就行了

        2440中的大多数外设是可以被关闭的,关闭的方法其实就是不提供时钟,时钟控制寄存器就是用来管理这些外设的时钟的。好在默认这些时钟是使能的,所以我们可以暂时不用管这个寄存器

时钟慢速控制(CLKSLOW )寄存器主要用于开关或选择三大时钟的,恰好,默认值就是我们需要的

时钟分频控制寄存器很重要,它决定了Pclk和Hclk的大小。这个寄存器有三个部分,其中DIVN_UPLL是给USB设备用的,我们用不上。先看PDIVN这个给Pclk分频的部分,很明显,为了使Pclk为50这里应该设置为01。

至此,代码的筹备工作已经完成,完整代码如下:

void init_timer4(void)
{
	unsigned int t;
	t = TCFG0;
	t &= ~(0xFF << 8);
	t |= (24 << 8);
	TCFG0 = t;

	TCFG1 &= ~(0x0F << 16); //2M / 2 = 1M

	TCNTB4 = 0xFFFF;
    TCON |= (1 << 21);
	TCON &= ~(1 << 21);
	TCON |= (1 << 22);
 
	TCON |= (1 << 20);
}

注意:这两个寄存器在设置时是先设置分频寄存器再设置倍频寄存器的。这是因为如果在没有设置分频的情况下直接把系统主频设置到400M的话,pclk和hclk的值我们是不知道的。这样的话可能某些外设由于频率太高而导致无法工作,这样情况下就算再把频率降下来也无法恢复。所以我们应该先配置好分频,再设置倍频。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2156184.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Android】DataBinding的运用

引言 之前对databinding有了基础的运用与介绍&#xff0c;但databinding的用处不单单在于Text的绑定&#xff0c;接下来就一起看看吧&#xff01; 意义&#xff1a;让布局文件承担了部分原本属于页面的工作&#xff0c;使页面与布局耦合度进一步降低。允许用户界面&#xff0…

Maven-一、分模块开发

Maven进阶 文章目录 Maven进阶前言创建新模块向新模块装入内容使用新模块把模块部署到本地仓库补充总结 前言 分模块开发可以把一个完整项目中的不同功能分为不同模块管理&#xff0c;然后模块间可以相互调用&#xff0c;该篇以一个SSM项目为目标展示如何使用maven分模块管理。…

操作系统之I/O设备管理

I/O系统的组成 I/O系统的结构 微机I/O系统 总线型I/O系统结构,CPU与内存之间可以直接进行信息交换&#xff0c;但是不能与设备直接进行信息交换&#xff0c;必须经过设备控制器。 主机I/O系统 I/O系统可能采用四级结构&#xff0c;包括主机、通道、控制器和设备。一个通道…

神经网络面试题目

1. 批规范化(Batch Normalization)的好处都有啥&#xff1f;、 A. 让每一层的输入的范围都大致固定 B. 它将权重的归一化平均值和标准差 C. 它是一种非常有效的反向传播(BP)方法 D. 这些均不是 正确答案是&#xff1a;A 解析&#xff1a; ‌‌‌‌  batch normalization 就…

TikTokDownloader 开源项目操作教程

TikTokDownloader TikTokDownloader 是一个开源的多功能视频下载工具&#xff0c;它专门用于从抖音和TikTok平台下载无水印的视频、图集和直播内容。这个工具支持批量下载账号作品、收藏内容&#xff0c;并可以采集详细数据。它提供了命令行和Web界面&#xff0c;具有多线程下…

图像处理基础知识点简记

简单记录一下图像处理的基础知识点 一、取样 1、释义 图像的取样就是图像在空间上的离散化处理,即使空间上连续变化的图像离散化, 决定了图像的空间分辨率。 2、过程 简单描述一下图象取样的基本过程,首先用一个网格把待处理的图像覆盖,然后把每一小格上模拟图像的各个…

re题(38)BUUCTF-[FlareOn6]Overlong

BUUCTF在线评测 (buuoj.cn) 运行一下.exe文件 查壳是32位的文件&#xff0c;放到ida反汇编 对unk_402008前28位进行一个操作&#xff0c;我们看到运行.exe文件的窗口正好是28个字符&#xff0c;而unk_402008中不止28个数据&#xff0c;所以猜测MessageBoxA&#xff08;&#x…

十一、 JDK17 新特性梳理

文章目录 为什么是JDK17语法层面新特性1、文本块2 、Switch 表达式增强3、instanceof的模式匹配4、var 局部变量推导 模块化及类封装1、记录类 record2 、隐藏类 Hidden Classes3 、密封类 Sealed Classes4、模块化 Module System1 、什么是模块化2、声明一个module3 、require…

从零开始讲DDR(4)——Xilinx方案

本文依据的是xilinx的PG150文档&#xff0c;主要介绍的是xilinx的ultrascale系列中内存资源的使用。 一、方案概述 Xilinx UltraScale™架构中的DDR3/DDR4 SDRAM ip核旨在支持高性能的内存接口解决方案。这些ip可以用于将DDR3和DDR4 SDRAM内存类型集成到设计中&#xff0c;提供…

干货 | 2024数智新时代制造业数字化创新实践白皮书(免费下载)

导读&#xff1a;本白皮书将对制造业发展历程、现状、趋势与核心难题做深入解读&#xff0c;并在此基础上提出了相应的制造行业解决方案,结合业内实践成功的客户案例来详析信息化转型的有效方法&#xff0c;以供生产制造行业的从业者参考交流。

计算机毕业设计 基于SpringBoot框架的网上蛋糕销售系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

解决SVN蓝色问号的问题

桌面或文件夹右键&#xff0c;选择TortoiseSVN->Settings打开设置对话框&#xff0c;选择Icon Overlays->Overlay Handlers->取消钩选Unversioned。确定&#xff0c;重启系统即可

扫码挪车是怎么实现的呢?一篇文章带你了解一下!扫码挪车小程序基础版上线了!!!

挪车小程序系统源码的功能特点 快速定位与挪车请求&#xff1a;车主通过小程序可以快速定位车辆位置&#xff0c;并发送挪车请求。系统会自动将请求发送给附近的车主&#xff0c;提醒其尽快挪车。实时通信与交互&#xff1a;小程序支持实时通信功能&#xff0c;车主之间可以通…

【安当产品应用案例100集】017-助力软件服务商高效集成多因素认证

一、企业案例背景 在本案例中&#xff0c;某企业作为一家软件技术服务商&#xff0c;为包括银行、政府机构在内的多个行业提供定制化的软件服务。由于各个行业的安全需求各异&#xff0c;例如银行和政府机构倾向于使用UKEY进行身份验证&#xff0c;而其他企业则可能偏好使用数…

[Python学习日记-26] Python 中的文件操作

[Python学习日记-26] Python 中的文件操作 简介 操作模式 循环文件 其他功能 混合模式 修改文件 简介 在 Python 中的文件操作其实和我们平时使用的 Word 的操作是比较类似的&#xff0c;我们先说一下 Word 的操作流程&#xff0c;流程如下&#xff1a; 找到文件&#x…

Leetcode Hot 100刷题记录 -Day19(回文链表)

回文链表 问题描述&#xff1a; 给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为回文链表。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,2,1] 输出&#xff1a;true示例 2&#xff…

UnLua访问C++属性、动态生成Actor

一、访问C属性、动态生成Actor 1、在C类MyBaseActor中新增蓝图可编辑属性:Name public:UPROPERTY(EditAnywhere)FString Name;2、在继承自C的蓝图子类BP_BaseActor中给Name赋值 3、在Lua中实现点击按钮动态生成Actor,并访问其Name属性 function WBP_FirstLua_C:Construct()s…

FreeRTOS下UART的封装

FreeRTOS下UART的封装_哔哩哔哩_bilibili Git使用的一个BUG&#xff1a; 当出现这个问题是因为git本身的安全证书路径有问题&#xff0c;我们需要重新指定路径 P1:UART程序层次

AIGC时代算法工程师的面试秘籍(第二十二式2024.9.2-9.15) |【三年面试五年模拟】

写在前面 【三年面试五年模拟】旨在整理&挖掘AI算法工程师在实习/校招/社招时所需的干货知识点与面试经验&#xff0c;力求让读者在获得心仪offer的同时&#xff0c;增强技术基本面。也欢迎大家提出宝贵的优化建议&#xff0c;一起交流学习&#x1f4aa; 欢迎大家关注Rocky…

【VLM小白指北 (1) 】An Introduction to Vision-Language Modeling

开一个新坑Vision-Language Modeling (VLM) &#xff0c;原文76页&#xff0c;慢慢更&#xff0c;for beginners&#xff0c;但也不能之前啥都不会啊。 原文链接&#xff1a;An Introduction to Vision-Language Modeling Introduction 存在的问题&#xff1a;将语言与视觉相…