历史上的今天
返回首页

历史上的今天

今天是:2024年12月08日(星期日)

正在发生

2021年12月08日 | 第三章、Tiny4412 U-BOOT移植三 时钟设置

2021-12-08 来源:eefocus

这一章说明配置时钟频率基本原理

OK,接着说,这次先讲讲CPU的系统时钟。U-BOOT在启动的过程中,需要配置系统时钟,没有这东西,CPU就跑不起来。配置系统时钟,大致是以下几个步骤:

(1)设置系统PLL锁定时间

(2)配置PLL

(3)配置各模块分频系数

(4)切换到PLL时钟


一、基本原理

如下图3-1所示是Tiny4412 (Exynos4412)的核心板,板子最上面的是27MHz的晶振,下面一颗是24MHz,顺便讲一下另外几片东西,最左边的两片是内存DDR3-800,这表示数据传输频率为800MHz,外部时钟频率200MHz,内部时钟频率为100MHz(时钟可能有误),背面还有两片;下面的MCL FLASH,外部时钟频率133MHz。



图3-1、Tiny4412核心板图


1、倍频的原理



图3-2、Exynos4412上电启动时序图

上电后时钟设置和上电时序的详细介绍见手册第7章和第60章。上图截取第60章,上电后的XXTI输出的频率变化图,XXTI频率从小变到指定频率需要一段时间(图中标红框的部分),当CPU频率在变化的时候,比如由复位后的初始化值为400MHZ,我要升到1400MHZ,这时,首先把CPU的频率锁定,因为此时CPU的频率是变化的,频率变化,则CPU的状态就无法确定,所以,此时用PLL--phase-lockedloop锁相环,将CPU频率锁定一段时间,直到我的频率输出稳定为止。芯片手册上第2837页上显示APLL默认的设置时间最大要100us(100微秒)。



图3-3、Exynos4412PLL 锁定时间表

锁定频率后,此时,应该设置一个倍频因子,在Exynos4412手册中去查表7-2到7-4中,P,M,S设置对应位的值,然后,将频率提升,比如从晶振输出的24HZ,抬升到1400MHz。



图3-4、P,M,S设置值查找表

接着就是分频了,设置分频相关寄存器中不同的位即可实现分频,比如,设置某一位为0,那么,分频时,原来频率假设为1000MHZ,那么频率就被分为1000/1=1000MHz,这样就可以分给ARMCLK等使用了。


2、开始分析

下图3-5取自芯片手册section02_system的第3章 CLOCKCONTROLLER,在开篇的P353页的第一张图就是这个。


图3-5、Exynos4412时钟框图

Exnnos4412的Clock分为5个大的domain,分别是LEFTBUSS,MAUDIO(CMU_TOP),DMC,CPU,RIGTHBUS,这五个区域分别管理不同的设备,为不同的设备提供不同的频率,如下表3-1所示。


表3-1、Exynos4412时钟频率说明表


再往下翻,这些不同设备的频率是如何产生的呢?可以查看手册P451页图表,下图3-6为部分图片截图。



图3-6、Exynos4412各模块时钟产生过程

由上图3-6可知,通过XOM[0]选择产生频率输入源,由于启动设置时,XOM[0]被设置为0,那么APLL的时钟源应是XXTI,但电路板中XXTI是没有用的,通过一个电阻接地了,如下图2-7所示,这一点我也一直没有想明白?有谁明白了可以告诉我。我暂且认为内部有什么寄存器,可以改变这个值,设置成了1,通过APLL倍频后得到时钟FOUTapll,可以做为新的时钟源进行分频后给其他IP核使用。


那么,在硬件上是如何实现的呢?观察开发板上晶振有三颗,一个24MHz,一个27MHz。晶振,(全名晶体振荡器,成份石英(二氧化硅),晶振用于通过压电效应给CPU提出振荡频率,再通过别的电路,将例如正弦曲线波转换成方波,相当于CPU的起搏器,有了晶振,CPU才有频率输出)。如果CPU输入24MHz频率后,此时,就需要把频率放大了(否则CPU才24MHz的频率能干吗呢?所以,CPU并不是一上电就跑到几GHz上面去了,跑车再好,跑的再快,从0加速到100码,也需要一段时间,所以没有一上电就几G这回事儿),在频率放大的过程中,首先需要考虑的一个问题就是——锁相环。简单的说,比如复位后,CPU默认工作频率在400MHz,现在需要升到1400MHz工作,那么从400-->1400MHz需要一个过程,假设为时间t1,在t1这段时间内,CPU的频率是变化的,那么CPU的状态就是不稳定的,此时,就需要把频率锁定,设置锁定时间,直到CPU稳定的输出频率。



图3-7、Exynos4412外部时钟连接图

CPU第一次启动时,第五章中已有说明,IROM中的代码将PLL已默认的初始化了,在芯片手册找到93页,可查看到其默认的初始频率:



图3-8、Exynos4412默认频率设置说明图

可见,当外部晶振是24MHz时,内部APLL和MPLL分别为400MHZ

 

由上图3-8查出可知,ARMCLK的默认频率为400MHz

1)查看芯片手册的P444页,查出总共有以下几种由CMU输出的时钟

有四种PLLs(APLL,MPLL,EPLL,HPLL),还包括USB_OTGPHY clock。

The components to generate internalclocks are:

•APLL uses FINPLL as input to generatefrequencies from 22 to 1400 MHz.

•MPLL uses FINPLL as input to generatefrequencies from 22 to 1400 MHz.

•EPLL uses FINPLL as input to generatefrequencies from 22 to 1400 MHz. This PLL generates a 192 MHz clock for theAudio Sub-system. It divides EPLL output to generate 24 MHz SLIMbus clock.

•VPLL uses FINPLL or SCLK_HDMI24M asinput to generate frequencies from 22 to 1400 MHz. This PLL generates 54 MHzvideo clock or G3D clock.

•USB Device PHY uses XUSBXTI to generatefrequencies of 30 and 48 MHz.

•HDMI PHY uses XUSBXTI to generate 54MHz.

常用的APLL/MPLL/EPLL/VPLL是干什么的呢?看P446页

APLLmainly drives the CPU_BLK clocks. It generates frequencies up to 1.4 GHz with aduty ratio of 49:51. APLL also generates DMC_BLK, LEFTBUS_BLK, RIGHTBUS_BLK,and CMU_TOP clocks as supplement of MPLL.

•MPLL mainly drives the DMC_BLK,LEFTBUS_BLK, RIGHTBUS_BLK, and CMU_TOP clocks. It generates frequencies up to 1GHz with a duty ratio of 49:51. MPLL also generates CPU_BLK clocks when itblocks APLL for locking during the Dynamic Voltage Frequency Scaling(DVFS).  

•EPLL mainly generates an audio clock.

•VPLL mainly generates video systemoperating clock of 54 MHz, or a G3D clock, or 440 MHz clock at 1.1 V.

先查看APLLPMS的倍频表,如下表3-2所示,看P447的Table7-2 APLL and MPLL PMS Value。  

表3-2、APLLand MPLL PMS Value





可查看到设置P/M/S的值,可以将频率拉升到我们想要的频率。设置的寄存器名称一般是:xPLL_CONx。如APLL的倍频寄存器的为APLL_CON0。

但在倍频之前,我们说过,先要让锁相环锁频功能成功,前面说过我们要等待一定的locktime时间,而手册上显示APLL的locktime最大为100us,如果是晶振输出的频率是24MHZ,locktime取值30毫秒,那么PLL_LOCKTIME是720,也就是0x2D0。那么我们就用这个值去设置APLL_LOCK寄存器。

翻看查找手册,基他相关的寄存器地址如下:

• (APLL_LOCK,R/W, Address = 0x1004_0000)

• (MPLL_LOCK, R/W, Address =0x1004_0000)

• (EPLL_LOCK, R/W, Address = 0x1003_0000)

• (VPLL_LOCK, R/W, Address =0xE010_0020)


下一节,结合实际的代码来说明如何设置这些值。

推荐阅读

史海拾趣

FILTRAN公司的发展小趣事

对于固态非易失性精密电位器构成的温度测量电路,网友可能关心的问题以及相应的回答如下:

  1. 固态非易失性精密电位器的工作原理是什么?
    • 回答:固态非易失性精密电位器(如X9C102/103/104/503)包含有99个电阻单元的电阻阵列。滑动单元的位置由CS、U/D和INC三个输入端控制,并且这个位置可以被存储在一个非易失性存储器中,因此在下一次上电时可以被重新调用。
  2. 这种电位器在温度测量电路中的具体应用是怎样的?
    • 回答:非易失性数控电位器如X9312可以构成温度测量电路,作为记数式模数转换电路。通过电位器的电阻值变化来反映温度的变化,实现温度的测量。
  3. 电位器的精度和分辨率如何?
    • 回答:非易失性数控电位器的分辨率等于最大的电阻值被99除。例如,X9C503(50kΩ)的每个抽头间的阻值为505Ω。精密电位器的精度可达0.1%。
  4. 非易失性存储器中的数据可以保存多久?
    • 回答:所有的Xicor非易失性存储器都设计成并经过测试能够用于持久地保存数据的应用场合。滑动端位置数据可保存100年。
  5. 这种电路对温度变化的响应速度如何?
    • 回答:由于参考文章中没有直接提及电位器对温度变化的响应速度,因此无法给出确切的数值。但一般来说,电位器的阻值变化与温度有一定的线性关系,可以较快地反映温度的变化。
  6. 在实际应用中需要注意哪些问题?
    • 回答:在实际应用中,需要注意电位器的额定功率、标称阻值、允许误差等级等参数。此外,电位器在低温环境下使用时需说明,以便采用特制的耐低温油脂。同时,电位器的轴或滑柄长度应尽量短,以提高稳定性和减少晃动。
  7. 电路的稳定性如何?
    • 回答:由于非易失性数控电位器具有非易失性存储功能,因此电路在上电时可以重新调用之前保存的电位器位置数据,从而保证了电路的稳定性。此外,电位器本身也具有较好的稳定性和可靠性。

以上是对固态非易失性精密电位器构成的温度测量电路网友可能关心的问题及相应回答的归纳和总结。

Echelon_Corporation公司的发展小趣事

进入21世纪后,Echelon继续拓展其业务范围,于2003年推出了网络能源服务系统(NES)。该系统是一个开放式的电表基础设施,旨在提高能源使用效率和管理水平。NES系统很快在全球范围内得到了广泛应用,特别是在意大利的智慧型电表基础建设中,Echelon的技术得到了大量使用,连接了数以千万计的电表。随着NES系统的成功推广,Echelon在能源管理领域的地位得到了进一步提升。

德国ACAM公司的发展小趣事

德国ACAM公司成立于1996年,总部位于施图登湖,毗邻斯图加特和卡尔斯鲁厄。公司从创立之初,就专注于时间到数字转换技术及其应用的研发。ACAM公司凭借其创新的技术和卓越的研发实力,在极短的时间内就取得了显著的成果。特别是在时间数字转换器(TDC)技术上,ACAM公司成功开发出业界领先的产品,为后续的快速发展奠定了坚实的基础。

爱普特半导体(APTSEMI)公司的发展小趣事

随着国产芯片产业的快速发展,人才短缺问题日益凸显。爱普特半导体深知人才是企业发展的核心资源,因此,公司积极构建高端半导体人才队伍。通过引进国内外优秀人才、加强内部培训、建立激励机制等多种措施,爱普特成功打造了一支技术过硬、经验丰富的研发团队。这支团队为公司的技术创新和产品研发提供了有力保障,推动了公司的快速发展。

EIC [EIC discrete Semiconductors]公司的发展小趣事

EIC公司非常重视人才培养和团队建设。公司注重员工的技能培训和职业发展规划,为员工提供了广阔的发展空间和良好的职业前景。同时,EIC还积极引进国内外优秀人才,打造了一支高素质、专业化的研发团队和管理团队。这些人才为公司的发展提供了强有力的智力支持,也为公司的持续创新提供了源源不断的动力。

GardTec Inc公司的发展小趣事

背景:为了满足全球客户的需求,GardTec开始实施全球化战略,在亚洲和美国等地设立全球制造厂和库存地。

发展:通过在全球范围内的战略布局,GardTec不仅提升了产品的供应效率,还更好地服务了世界各地的客户。公司的全球化布局进一步巩固了其在风扇配件市场的领先地位。

影响:全球化战略的实施,使得GardTec的产品能够迅速响应市场变化,满足不同地区客户的多样化需求,从而增强了公司的市场竞争力。

问答坊 | AI 解惑

汽车导航系统电源设计

现代汽车不断增加越来越复杂的电子系统。市场调研公司 Allied Business Intelligence 预测,到 2007 年,汽车半导体市场将增长到一年超过 170 亿美元,而去年这一市场为 123 亿美元。另一家市场调研公司 Strategy Analytics 也持有同样乐观的看法: ...…

查看全部问答>

求s7-200编程

我现在正在用西门子的S7-200,程序主要是实现欧姆龙拨码开关(A7PS)量通过显示器(D1SA)显示出来,这个程序该怎么写呀?急求,谢谢!…

查看全部问答>

2440启动出现错误

MDValidateRomChain: XIP (00000000 -> 00000000) doesn\'t exist in OEMAddressTable ERROR! XIP region span accross discontigious memory!!! System Halted! s3c2440 WIN-CE5.0…

查看全部问答>

在EVC里面 如何使用自定义的命令按钮和如何改变命令按钮上的文字颜色阿??

如题,在EVC里面 创建基于对话框的工程,在使用命令按钮时,为了界面的美观和风格统一,如何使用自定义的命令按钮和如何改变命令按钮上的文字颜色阿?? 谢谢各位了…

查看全部问答>

有谁用过用单片机控制SHT15温湿度传感器啊?

有谁用过用单片机控制SHT15温湿度传感器啊? 求助通信时序问题?…

查看全部问答>

菜鸟请教D12驱动应用程序问题

菜鸟请教D12驱动应用程序问题 小弟使用D12和51做一个大量数据传输的东西。 固件使用ZLG的,驱动是用DriverStudio3.1直接生成的。 使用DS里面的函数OpenByInterf()打开USB设备,用ReadFile()阻塞模式来读取USB数据 因为在51那里是连续发的,所 ...…

查看全部问答>

有需要IC芯片的可以找我啊,呵呵

各位朋友好,本人现在在北京一家公司做IC销售,我们家一般都是从国外订货,质量有保证,如果没有库存,订货一般7-10天,我们家常做的厂家有altera, intel,on,maxim,atmel,st,ad,ti等等的。欢迎各位朋友给小女子我捧场啊,在这里我先谢谢各位朋友啦 ...…

查看全部问答>

THS3201放大后整体偏置呢?

本帖最后由 dontium 于 2015-1-23 13:23 编辑 我做了关于THS3201的放大电路,反向放大时整体偏置,同相放大时会自激振荡也会整体偏置。请问有人使用过吗?有高见么? …

查看全部问答>

LM3S2B93的内部LDO问题

做了两块LM3S2B93的板子,结果全部因为2B93的内部LDO问题失效,第一块板运行成功一段时间后,突然失效,最后检测结果2B93中LDO短路,第二块板运行成功一段时间后,同样失效,检测2B93中LDO电压降为0.8V,3.3V电路正常。 1.2V电路仅接了去耦电容X5R ...…

查看全部问答>