s5pv210的时钟系统概述

发布者:温暖微笑最新更新时间:2024-12-19 来源: elecfans关键字:s5pv210  时钟系统  DRAM控制器 手机看文章 扫描二维码
随时随地手机看文章

S5PV210的时钟系统 (外部晶振+内部时钟发生器+内部PLL产生高频时钟+内部分频器分频得到各种频率的时钟)


1.为什么要时钟系统?

SoC内部有很多器件,譬如CPU、串口、DRAM控制器、GPIO等内部外设,这些东西要彼此协同工作,需要一个同步的时钟系统来指挥


2.为什么要内部先高频然后再分频?

主要因为SoC内部有很多部件都需要时钟,而且各自需要的时钟频率不同,没法统一供应。因此设计思路是PLL后先得到一个最高的频率(1GHz、1.2GHz),然后各外设都有自己的分频器再来分频得到自己想要的频率。


3.S5PV210建议工作频率800MHz~1.2GHz,一般我们都设置到1GHz主频(CPU的频率,最高的频率,外设均比这个频率低)。若1.2GHz就叫超频。超频的时候系统性能会提升,但是发热也会增大,因此会影响系统稳定性。(可用液氮降温,但不能长期这种情况下工作;部分CPU热量太高会重启)


4、时钟和外设编程的关联

(1)每个外设都需要一定频率的时钟,时钟的设置可以用编程控制,通过时钟来源,分频系统还有 倍频等来获取时钟

(2)开关每个外设用时钟就行,不给它时钟频率就相当于关闭了它,不用的外设需要关闭,否则会产生不必要的热量


S5PV210把整个内部的时钟划分为3大块,叫做3个域。(参考数据手册P353)

1.分析时钟域 (CLOCK DOMAINS)

(1)MSYS: CPU(Cortex-A8内核)、DRAM控制器(DMC0和DMC1)、IRAM&IROM······

(2)DSYS: 都是和视频显示、编解码等有关的模块

(3)PSYS: 和内部的各种外设时钟有关,譬如串口、SD接口、I2C、AC97、USB等。(时钟频率相对比较小)


为什么内部要分为3个域,怎么划分的?

因为210内部的这些模块彼此工作时钟速率差异太大了,所以有必要把高速的放一起,相对低速的放一起。


2.倍频器PLL的作用对象:APLL、MPLL、EPLL、VPLL(参考数据手册P357)

APLL:Cortex-A8内核 MSYS域.....

MPLL&EPLL:DSYS PSYS....

VPLL:Video视频相关模块....


3.S5PV210时钟域详解结合上面的分析时钟域(P356)

3.1、MSYS域:

ARMCLK: 给cpu内核工作的时钟,也就是所谓的主频。

HCLK_MSYS: MSYS域的高频时钟,给DMC0和DMC1使用

PCLK_MSYS: MSYS域的低频时钟

HCLK_IMEM:给iROM和iRAM(合称iMEM)使用


3.2、DSYS域:

HCLK_DSYS:DSYS域的高频时钟

PCLK_DSYS:DSYS域的低频时钟


3.3、PSYS域:

HCLK_PSYS:PSYS域的高频时钟

PCLK_PSYS:PSYS域的低频时钟

SCLK_ONENAND:


总结:210内部的各个外设都是接在(内部AMBA总线)总线上面的,AMBA总线有1条高频分支叫AHB,有一条低频分支叫APB。上面的各个域都有各自对应的HCLK_XXX和PCLK_XXX,其中HCLK_XXX就是XXX这个域中AHB总线的工作频率;PCLK_XXX就是XXX这个域中APB总线的工作频率。

SoC内部的各个外设其实是挂在总线上工作的,也就是说这个外设的时钟来自于他挂在的总线,譬如串口UART挂在PSYS域下的APB总线上,因此串口的时钟来源是PCLK_PSYS。


4、各时钟典型值(默认值,iROM中设置的值,BLO上初始设置的值)

(1)当210刚上电时,默认是外部晶振+内部时钟发生器产生的24MHz频率的时钟直接给ARMCLK的,这时系统的主频就是24MHz,运行非常慢。

(2)iROM代码(BL0)执行时第6步中初始化了时钟系统,这时给了系统一个默认推荐运行频率。

(3)各时钟的典型值:


freq(ARMCLK) = 1000 MHz

freq(HCLK_MSYS) = 200 MHz

freq(HCLK_IMEM) = 100 MHz

freq(PCLK_MSYS) = 100 MHz

freq(HCLK_DSYS) = 166 MHz

freq(PCLK_DSYS) = 83 MHz

freq(HCLK_PSYS) = 133 MHz

freq(PCLK_PSYS) = 66 MHz

freq(SCLK_ONENAND) = 133 MHz, 166 MHz


* S5PV210的时钟树:(P361)

每一个MUX和分频器均有某个寄存器的某个位进行控制(寄存器中的clock source x就是在设置MUX开关;clock divider control寄存器就是在设置分频器分频系数)


时钟开启程序一般流程:

1.关看门狗(WTCON)


2.初始化时钟 1:设置各种开关,先不使用PLL(0x0 -> CLK_SRC0)

2: 设置锁定时间 (0X0000FFFF -> APLL_LOCK)和 (0X0000FFFF -> MPLL_LOCK)

3:设置分频(0X0x14131440 -> CLK_DIV0) 0x14131440这个值的含义分析:(查看时钟树图)


PCLK_PSYS = HCLK_PSYS / 2

HCLK_PSYS = MOUT_PSYS / 5

PCLK_DSYS = HCLK_DSYS / 2

HCLK_DSYS = MOUT_DSYS / 4

PCLK_MSYS = HCLK_MSYS / 2

HCLK_MSYS = ARMCLK / 5

SCLKA2M = SCLKAPLL / 5

ARMCLK = MOUT_MSYS / 1


4:设置PLL(我们设置了APLL和MPLL两个,其他两个没有管。

APLL和MPLL设置的关键都是M、P、S三个值,这三个值都来自于官方数据手册的推荐值)参考P357

5:设置时钟开关,使用PLL(0x10001111 ->CLK_SRC0 )

3.设置栈ldr sp, =SVC_STACK //(0xd0037d80)


4.开/关icache


mrc p15,0,r0,c1,c0,0;    // 读出cp15的c1到r0中

//bic r0, r0, #(1<<12)    // bit12 置0 关icache

orr r0, r0, #(1<<12)    // bit12 置1 开icache

mcr p15,0,r0,c1,c0,0;

 


关键字:s5pv210  时钟系统  DRAM控制器 引用地址:s5pv210的时钟系统概述

上一篇:LCD platform_device(s5pv210)
下一篇:S5PV210 串口实验(中断方式)

推荐阅读最新更新时间:2026-03-23 10:33

S5PV210时钟系统
1.6.1.SoC时钟系统简介 1.6.1.1、什么是时钟?SoC为什么需要时钟? (1)时钟是同步工作系统的同步节拍。 (2)SoC内部有很多器件,譬如CPU、串口、DRAM控制器、GPIO等内部外设,这些东西要彼此协同工作,需要一个同步的时钟系统来指挥。这个就是我们SoC的时钟系统。 1.6.1.2、时钟一般如何获得 (1)SoC的时钟获得一般有: * 外部直接输入时钟信号,SoC有个引脚用来输入外部时钟信号,用的很少。 * 外部晶振+内部时钟发生器产生时钟,大部分低频单片机都是这么工作的。 * 外部晶振+内部时钟发生器+内部PLL产生高频时钟+内部分频器分频得到各种频率的时钟,210属于这种。 (2)S5PV210属于第三种
[单片机]
ARM芯片的时钟系统详解(S5PV210芯片)
1、时钟介绍 时钟是同步工作系统的同步节拍,时钟的快慢就是我们常说的工作频率,以赫兹(HZ)为单位。时钟系统指导器件的运行,我们分析器件的工作特性时,常常会看器件的时序图,时序图中的时钟周期就是时钟系统来决定的。 2、时钟来源 2.1、 三种时钟配置 1、外部直接输入时钟信号,SoC有个引脚用来输入外部时钟信号,用的很少。 2、外部晶振+内部时钟发生器产生时钟,大部分低频单片机都是这么工作的。 3、外部晶振+内部时钟发生器+内部PLL产生高频时钟+内部分频器分频得到各种频率的时钟。 2.2、S5PV210的时钟来源 S5PV210的时钟来源属于第三种,也可以说复杂的Soc都是第三种,因为复杂Soc的内部器件是很多的,具体原
[单片机]
ARM芯片的<font color='red'>时钟</font><font color='red'>系统</font>详解(<font color='red'>S5PV210</font>芯片)
基于当代DRAM结构的存储器控制器设计
基于当代DRAM结构的存储器控制器设计 1、引言 当代计算机系统越来越受存储性能的限制。处理器性能每年以60%的速率增长,存储器芯片每年仅仅增加10%的带宽,本文就如何设计一种符合当代DRAM结构的高效存储器控制器进行研究。 本文第二部分介绍当代DRAM结构特点;第三部分介绍存储器控制器结构以及调度算法;第四部分介绍模拟环境以及性能表现。 2、当代DRAM结构 为了提高存储器的性能,存储器控制器的设计必须充分利用当代DRAM的特点。DRAM是3D的存储器(体行列),每个体独立于其他体操作并且一次存取整行。当存储阵列的一行被存取(行激活),存储阵列的整行被传输到这个体的行缓冲。当一行在行缓冲中处于激活态,任何的读写(列存
[模拟电子]
嵌入式系统DRAM控制器的CPLD解决方案
摘要: 介绍怎样在嵌入式CPU 80C186XL DRAM刷新控制单元的基础上,利用CPLD技术和80C196XL的时序特征设计一个低价格、功能完整的DRAM控制器的方法,并采用VHDL语言编程实现。 关键词: 刷新控制单元(RCU) DRAM控制器 状态机 CPLD VHDL语言 80C186XL16 位嵌入式微处理器 是Intel公司在嵌入式微处理器市场的上导产品之一,已广泛应用于电脑终端、程控交换和工控等领域。在该嵌入式微处理器片内,集成有DRAM RCU单元,即DRAM刷新控制单元。RCU单元可以自动产生DRAM刷新总线周期,它工作于微处理器的增益模式下。经适当编程后,RCU将向将处理器的 BIU(总线
[嵌入式]
嵌入式<font color='red'>系统</font>中<font color='red'>DRAM</font><font color='red'>控制器</font>的CPLD解决方案
80C186XL嵌入式系统DRAM控制器的CPLD解决方案
    摘要: 介绍怎样在嵌入式CPU 80C186XL DRAM刷新控制单元的基础上,利用CPLD技术和80C196XL的时序特征设计一个低价格、功能完整的DRAM控制器的方法,并采用VHDL语言编程实现。     关键词: 刷新控制单元(RCU) DRAM控制器 状态机 CPLD VHDL语言 80C186XL16位嵌入式微处理器 是Intel公司在嵌入式微处理器市场的上导产品之一,已广泛应用于电脑终端、程控交换和工控等领域。在该嵌入式微处理器片内,集成有DRAM RCU单元,即DRAM刷新控制单元。RCU单元可以自动产生DRAM刷新总线周期,它工作于微处理器的增益模式下。经适当编程后
[应用]
80C186XL嵌入式系统DRAM控制器的CPLD解决方案
    摘要: 介绍怎样在嵌入式CPU 80C186XL DRAM刷新控制单元的基础上,利用CPLD技术和80C196XL的时序特征设计一个低价格、功能完整的DRAM控制器的方法,并采用VHDL语言编程实现。     关键词: 刷新控制单元(RCU) DRAM控制器 状态机 CPLD VHDL语言 80C186XL16位嵌入式微处理器 是Intel公司在嵌入式微处理器市场的上导产品之一,已广泛应用于电脑终端、程控交换和工控等领域。在该嵌入式微处理器片内,集成有DRAM RCU单元,即DRAM刷新控制单元。RCU单元可以自动产生DRAM刷新总线周期,它工作于微处理器的增益模式下。经适当编程后
[嵌入式]
S5PV210 uboot中的 MMU代码分析(1)
1:经过上一节的分析,如果采用SECTION虚拟地址映射的话; 程序员只需要做的事情: (1) 建立转换表,Tanslation Table; (2) 将TTB(转换表基地址Tanslation Table Base)写入协处理器CP15的C2寄存器,这里要注意转换表 基地址为16K对齐的(因为4096*32bit=16K)所以TTB的bit0-bit13为0。 (3) 使能MMU,将CP15的C1寄存器0bit写1; (4) 设置域的访问权限;设置C3寄存器; CPU/MMU做的事情: (1) CPU核心看到和用到的只是虚拟地址VA,至于VA如果去对应物理地址PA,CPU核心不理会,MVA是除CPU核心 外的其他部分看到的虚拟地
[单片机]
<font color='red'>S5PV210</font> uboot中的 MMU代码分析(1)
S5PV210 固件烧写 u-boot烧写
首先阅读CW210_CD自带光盘中CW210 开发板使用手册.pdf 使用usb 拨码开关置成usb启动。xx可以是ON或OFF。开发板上面也有丝印提示 usb线接好,串口线接好 使用DNW下载 自带光盘的usb驱动(x210 usb Driver)只适用于XP系统,如果在Windows 7下使用usb下载,只能使用linux dnw代替 配置DNW串口和下载地址,0xd0020010是x210_usb.bin的下载地址 连接串口,显示连接成功 此时,长按开发板复位按键 直到USB连接显示OK 现在可以通过usb发送文件,首先发送x210_usb.bin 修改下载地址,0x23e00000是u-boot.bin的下
[单片机]
<font color='red'>S5PV210</font> 固件烧写 u-boot烧写
小广播
最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

厂商技术中心

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2026 EEWORLD.com.cn, Inc. All rights reserved