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]
相关推荐
sramdram19 分钟前
基于MCU微控制器的电子血压计应用解决方案
单片机·嵌入式硬件·mcu·mcu微控制器
伊灵eLing23 分钟前
GoLang 语言基础
开发语言·后端·golang
两年半的个人练习生^_^23 分钟前
JMM 进阶:彻底理解 synchronized 实现原理
java·开发语言
小白不白11125 分钟前
Invoke的用法
开发语言·人工智能·数码相机·计算机视觉·c#
techdashen28 分钟前
What is maintenance, anyway?
开发语言·后端·rust
Szime30 分钟前
AD9218 国产替代方向:双通道 10 位 105MSPS ADC 选型支持
单片机·嵌入式硬件·fpga开发·汽车
万法若空31 分钟前
C/C++基本类型表示范围
c语言·开发语言·c++
yijianace34 分钟前
Python爬虫实战:BooksToScrape 多线程爬取与图片下载
开发语言·爬虫·python
凡人叶枫41 分钟前
Effective C++ 条款15:在资源管理类中提供对原始资源的访问
linux·开发语言·c++·stm32·单片机
swordbob41 分钟前
Spring Boot 2.0 改 CGLIB 后,接口实现是否有影响
java·开发语言·spring