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]
相关推荐
祈安_20 小时前
C语言内存函数
c语言·后端
郑州光合科技余经理2 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1232 天前
matlab画图工具
开发语言·matlab
dustcell.2 天前
haproxy七层代理
java·开发语言·前端
norlan_jame2 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone2 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054962 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
czy87874752 天前
除了结构体之外,C语言中还有哪些其他方式可以模拟C++的面向对象编程特性
c语言
遥遥江上月2 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
悠哉悠哉愿意3 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习