ARM—时钟(CLOCK)—定时器(EPIT / GPT)

一、时钟(clock)

<1>. 硬件概念:

  • 时钟概念:在电子系统中是一个产生稳定、周期性振荡信号的电路或组件。这个信号像节拍器或心跳一样,为数字电路中的各种操作提供同步时序基准。
  • 实时时钟(RTC real time clock): 是微处理器中的一个功能模块,用于在系统主电源关闭的情况下,继续提供精确的日历和时间信息。
  • 时钟源:晶体振荡器(工作原理:将石英晶体切割成音叉,施加电压,会产生稳定的震荡)
  • 外设工作频率分配:外部时钟源构建的时钟树通过物理线路供应给外设需要的工作频率,其中也包括供应kernal的工作频率(396M,最大1.3G)

PPL(Phase-Locked Loop):锁相环电路,可以倍频输出

IMX6ULL中共有7个PLL

  • 允许输入一个固定频率,输出固定频率*n(n 倍频系数)

Prescal:预分频器,可以分频

PFD(Phase Fractional Divier):相位分数分频器,输出频率可升可降

IMX6ULL中共有8个PFD(PLL2和PLL3各四个)

<2>. 代码编写

  1. kernal: CCM_ANALOG_PLL_ARMn
    PLL的配置流程

  2. 528 PLL:CCM_ANALOG_PFD_528n

  3. 480 PLL:CCM_ANALOG_PFD_480n

    2和三根据参考手册配置将位置1或置0

  4. AHB_CLK_ROOT(最高频率132M):Advanced High-performance Bus(高级高性能总线),用于驱动高速外设

  • CBCMRPRE_PERIPH_CLK_SEL
  • CBCDRPERIPH_CLK_SEL
  • CBCDRAHB_PODF
  1. IPG_CLK_ROOT(最高频率66M):Internal Peripheral Bus Clock(内部外设总线时钟),用于驱动低速外设
  • CBCDRIPG_PODF
  1. PERCLK_CLK_ROOT(最高频率66M):
  • CSCMR1PERCLK_CLK_SEL
  • CSCMR1PERCLK_PODF

二、定时器

<1> EPIT(Enhanced Periodic Interrupt Timer):增强型周期中断定时器

EPIT定时器的两种工作模式:

  • set-and-forget 模式:在此模式下 EPIT 的计数器从加载寄存器 (EPITx_LR) 中获取初始值,不能直接向计数器寄存器写入数据。不管什么时候,只要计数器计数到 0,那么就会从加载寄存器 EPITx_LR 中重新加载数据到计数器中,周而复始。
  • free-running 模式 :在此模式下,当计数器计数到 0 以后会重新从0XFFFFFFFF 开始计数,并
    不是从加载寄存器 EPITx_LR 中获取数据

EPIT工作原理简述

  1. 通过多路选择器,从 三个时钟中选择一个作为输入时钟
    【ipg_clk(内部外设总线时钟)、ipg_clk_32k(32kHz 低速时钟)、ipg_clk_highfreq(高频时钟)或 "Clock off"(时钟关闭)】
  2. 12 位预分频:对第一步选择的时钟进行"12 bit Prescaler"(12 位预分频器),可设置分频系数 (1~4096)对时钟进一步分频,得到 "Prescaled Clock"(预分频后时钟),用于驱动计数器。
  3. 计数器与寄存器协作:
  • 计数器寄存器(Counter Register):32 位宽,在预分频时钟驱动下递减计数
  • 加载寄存器(Load Register):32 位宽,存储计数器的初始值(或重载值)。当计数器减到特定值(如与比较寄存器匹配,或减到 0)时,会从加载寄存器重新加载数值,实现周期性计数。
    【实现通过将EPIT_CR(contral register)寄存器设置为:设置并忘记模式】
  • 比较寄存器(Compare Register):32 位宽,与存储的预设的 "目标值"进行比较。
  1. 比较与中断 / 输出触发比较器(CMP):将计数器当前值与比较寄存器的值对比。当两者匹配时,会触发:
  • 输出触发(ITIF):可通过输出模式(OM)模块(OM模块会使输出信号翻转),生成 EPITn_OUT 输出信号(用于外设控制等场景)。
  • 中断触发:若中断使能位(ITIE)开启,会产生中断请求,用于通知 CPU 执行定时任务(如 LED 闪烁、数据采样等)。

<2> GPT(General Purpose Timer):通用目的定时器

  • GPT 定时器(高精度定时器)是一个32 位向上定时器(也就是从0X00000000 开始向上递增计数)
  • GPT 定时器特性如下
    ① 一个可选时钟源的 32 位向上计数器;
    ② 两个输入捕获通道,可以设置触发方式;
    ③ 三个输出比较通道,可以设置输出模式;
    ④ 可以生成捕获中断、比较中断和溢出中断;
    ⑤ 计数器可以运行在重新启动(restart)或(自由运行)free-run 模式。
    GPT的两种工作模式:
  • 重新启动(restart)模式:在此模式下,当计数值和比较寄存器中的值相等的话计数值就会清零,然后重新从0X00000000 开始向上计数,只有比较通道 1 才有此模式!向比较通道 1 的比较寄存器写入任何数据都会复位 GPT 计数器。对于其他两路比较通道(通道 2 和 3),当发生比较事件以后不会复位计数器。
  • 自由运行(free-run)模式 :当在此模式下,此模式适用于所有三个比较通道,当比较事件发生以后并不会复位计数器,而是继续计数,直到计数值为 0XFFFFFFFF,然后重新回滚到 0X00000000。

GPT工作原理简述

相关推荐
kishu_iOS&AI1 天前
LLM —— 基础知识(Bert&GPT&T5)浅析
人工智能·gpt·bert
人工智能培训1 天前
从GPT到开源大模型
人工智能·gpt·深度学习·机器学习·容器·知识图谱
程序员佳佳1 天前
我在 Windows 和低配 Linux 上做 RAG:Milvus、FAISS、向量 API 中转的中立实测
linux·人工智能·windows·gpt·aigc·milvus·faiss
鲁子狄1 天前
lrnev:让 AI 协作开发「有记忆、可追溯」的项目治理引擎 | 零模型依赖,文件即真相
人工智能·笔记·gpt·ai·ai编程
searchforAI1 天前
利用AI翻译视频做双语笔记,一套视频翻译到知识库沉淀的完整方案
人工智能·笔记·gpt·音视频·语音识别·知识图谱·机器翻译
向量引擎2 天前
腾讯混元 API 接入与国内模型统一入口实践:API Key、OpenAI 兼容调用、向量引擎中转配置与企业安全检查
人工智能·gpt·aigc·ai编程·ai写作·agi·api调用
ACP广源盛139246256732 天前
GSV2221 显示转换芯片@ACP#赋能 RTX Spark 端侧 AI 设备,构建多屏全模态视觉交互新生态
大数据·人工智能·嵌入式硬件·gpt·spark·电脑·音视频
库拉大叔2 天前
GPT-5.5 多模态能力实战:2026 年 AI 工具进阶使用指南
人工智能·gpt·aigc
振南的单片机世界2 天前
HAL_Delay(1000)真准吗?SysTick的1ms基准从哪来
arm开发·stm32·单片机·嵌入式硬件
沉默王二2 天前
不用 GPT-Image2,DeepSeek V4/GLM-5.1 + draw.io 就很顶!
gpt·ai编程·deepseek