ARM时钟配置

RTC是用来记时间的

XTAL是内部用于运算的

PLL:锁相环----用于倍频

预分频器:用于分频

分频器:类似上面二者组合,可以倍频和分频

一、PLL1的配置

PLL1为ARM内核提供时钟,将其配置为1056MHz,之后经分频器2分频得到528MHz供ARM内核使用。

由于担心分频/倍频过于频繁,最后的频率老是确定不了,导致收到错乱的时钟,使得工作极其不稳定,因此先给最后接上晶振,等待分频/倍频配置完成之后,再给其接上

|-------------------------------------------------|
| 1、先选择osc_clk,让step_clk为 24MHz。 |
| 2、再将PLL1的输出改 成step_clk,让ARM暂时工作在24HZ |
| 3、配置PLL为1056,注意设置倍频因子之前先把PPL之后的二分频设置好,避免ARM内核故障 |
| 4、最后再改回去 |

1、先根据下面寄存器,先将step_sel选为24M,再改为step_clk(最后记得配置完改回pll1_main_clk)

2、再根据下面寄存器,先给13位置1使能,再根据公式算出div_select填入最后

3、根据下面寄存器,将其配置001设置为二分频

cpp 复制代码
    CCM->CCSR &= ~(1<<8);
    CCM->CCSR |= (1<<2);

    unsigned int tmp = CCM->CACRR;
    tmp &= ~(0x7 << 0);
    tmp |= (0x1<<0);
    CCM->CACRR = tmp;

    tmp = CCM_ANALOG->PLL_ARM;
    tmp &= ~(0x03<<14);
    tmp |=(0x1<<13);
    tmp &= ~(0x7f<<0);
    tmp |=(88<<0);
    CCM->CACRR = tmp;
    CCM->CCSR &= ~(1<<2);

二、配置PLL2
此PLL下有四 个PFD

现在我们需要配置这四个PFD,建议值为:352、594 、400(其实是396)和297

根据下面描述来配置,此次选择CCM_ANALOG_PFD_528n PFD值为528*18/N其中N是要填入寄存器的值

cpp 复制代码
    tmp = CCM_ANALOG->PFD_528;
    tmp %= (0x3f << 0) | (0x3f << 8) | (0x3f << 16) | (0x3f << 24);
    tmp |= (27 << 0) | (16 << 8) | (24 << 16) | (48 << 24);
    CCM_ANALOG->PFD_528 = tmp;

三、配置PPL3

方法与上面类似,此次选择CCM_ANALOG_PFD_480n,PFD值为480*18/N其中N是要填入寄存器的值

cpp 复制代码
    tmp = CCM_ANALOG->PFD_480;
    tmp %= (0x3f << 0) | (0x3f << 8) | (0x3f << 16) | (0x3f << 24);
    tmp |= (12 << 0) | (16 << 8) | (17 << 16) | (19 << 24);
    CCM_ANALOG->PFD_480 = tmp;

四、配置最后的分频器等

根据最上图,此次需配置PERCLK_CLK_ROOT、AHB_CLK_ROOT、IPG_CLK_ROOT这些常用,根据图片配置其分频器与选择器件

cpp 复制代码
    tmp = CCM->CBCDR;
    tmp &= ~(0x07 << 10);
    tmp |= (0x2 << 10);
    tmp &= ~(0x1<<25); 
    CCM -> CBCDR = tmp;

    tmp = CCM->CBCMR;
    tmp &= ~(0x3 << 18);
    tmp |= (1 << 18);
    CCM ->CBCMR = tmp;

    tmp = CCM -> CBCDR;
    tmp &= ~(0x3 << 8);
    tmp |= (0x1 << 8);
    CCM -> CBCDR = tmp;
    
    tmp = CCM ->CSCMR1;
    tmp &= ~(0x7f<<0);
    CCM -> CSCMR1 = tmp;
相关推荐
想放学的刺客2 小时前
单片机嵌入式试题(第34期)嵌入式开发的利器:逻辑分析仪与示波器深度解析
arm开发·stm32·单片机·嵌入式硬件·物联网
CinzWS16 小时前
A53电源管理(下):DVFS与热管理的硬件实现——ARM芯片的“冷静艺术“
arm开发·嵌入式·芯片验证·原型验证·a53
誰能久伴不乏1 天前
剥开协议的伪装:用 Wireshark 显微镜级拆解 TCP 握手与挥手
arm开发·tcp/ip·wireshark
somi71 天前
ARM-驱动-10自定义通信协议
linux·arm开发·自用
疏星浅月2 天前
虚拟内存三大核心作用详解
linux·c语言·arm开发·嵌入式硬件
somi72 天前
ARM-驱动-08-LM75(I2C)和 ADXL345(SPI)
arm开发
somi72 天前
ARM-驱动-09-LCD FrameBuffer
arm开发·驱动开发·算法·自用
每天进步一点点️2 天前
透视 SOC 内部:APU Cluster 如何驱动 DB15 的 CAN/ETH 信号输出
arm开发·soc·芯片
xiaoyaohou112 天前
032、部署优化(三):OpenVINO与ARM平台(NCNN、TNN)部署
arm开发·人工智能·openvino
路溪非溪2 天前
抓取手机的蓝牙HCI日志并分析
linux·arm开发·驱动开发·智能手机