day4(IMX6ULL)<定时器>

定时器 (EPIT GPT): 是一个通过对已知频率的时钟信号进行计数,来实现定时、延时或事件计数功能的硬件模块或软件机制。
时钟(clock): 在电子系统中是一个产生稳定、周期性振荡信号的电路或组件。这个信号像节拍器或心跳一样,为数字电路中的各种操作提供同步时序基准。

实时时钟(RTC real time clock): 是微处理器中的一个功能模块,用于在系统主电源关闭的情况下,继续提供精确的日历和时间信息。

一、硬件概念

(1)时钟源:

晶体整荡器:工作做原理是将石英晶体切割成音叉,施加电压,会产生稳定的震荡。

(2)PLL(phase locked loop)锁相环电路(倍频):

锁相环(PLL) 是一种反馈控制系统,能够使输出信号与参考信号的相位和频率保持同步。

(3)Prescale 分频器( 分频):

Prescale (预分频器)是一种整数分频电路 ,用于将输入时钟频率按固定比例降低 。它是数 字系统中最基础、最常用的时钟分频模块。

(4)PFD(phase fractional Prescale)相位分数分频器(输出频率可升可降):

分数分频器 是一种能够实现非整数分频比的分频器,例如 N.5、N.25 等。它解决了传统整数 分频器分辨率受限的问题。

二、代码编写

(1)kernal: CCM_ANALOG_PLL_ARMn

(1)先选择osc_clk,让step_clk为24MHz

(2)再将PLL1的输出改成step_clk,让ARM暂时工作在24MHz;

(3)配置PLL为1056,注意设置倍频因子之前先把PLL之后的二分频设置好,避免ARM内核故障!!

(4)最后改回pll1_main_clk

(2)528 PLL:CCM_ANALOG_PFD_528n

(3)480 PLL:CCM_ANALOG_PFD_480n

(4)AHB_CLK_ROOT(132M)

cpp 复制代码
		CBCMR[PRE_PERIPH_CLK_SEL]
		CBCDR[PERIPH_CLK_SEL]
		CBCDR[AHB_PODF]

(5)IPG_CLK_ROOT(66M)

bash 复制代码
		CBCDR[IPG_PODF]

(6)PERCLK_CLK_ROOT(66M)

cpp 复制代码
		CSCMR1[PERCLK_CLK_SEL]	
		CSCMR1[PERCLK_PODF]
相关推荐
阿里嘎多学长1 天前
2026-02-16 GitHub 热点项目精选
开发语言·程序员·github·代码托管
啊吧怪不啊吧1 天前
C++之基于正倒排索引的Boost搜索引擎项目usuallytool部分代码及详解
开发语言·c++·搜索引擎·项目
CeshirenTester1 天前
9B 上端侧:多模态实时对话,难点其实在“流”
开发语言·人工智能·python·prompt·测试用例
发现你走远了1 天前
Windows 下手动安装java JDK 21 并配置环境变量(详细记录)
java·开发语言·windows
java干货1 天前
如何让 iPhone 用上 Type-C 充电器?适配器模式详解
c语言·iphone·适配器模式
游乐码1 天前
c#类和对象
开发语言·c#
黎雁·泠崖1 天前
Java常用类核心详解(一):Math 类超细讲解
java·开发语言
代码改善世界1 天前
C语言项目实战:学生成绩管理系统(支持登录注册、随机考试、分数区间统计)
c语言·网络·课程设计
懒惰成性的1 天前
12.Java的异常
java·开发语言
-To be number.wan1 天前
Python数据分析:时间序列数据分析
开发语言·python·数据分析