找回密码
 注册
搜索
查看: 620|回复: 0

[综合资料] 教你如何设置S3C2440时钟

[复制链接]
发表于 2013-11-11 17:30:12 | 显示全部楼层 |阅读模式



S3C2440 的时钟设置时间:  
一个嵌入式系统中,晶振就像心脏。必须先确定晶振,设置好系统的时钟,
WDT,UART,PWM,TIMER 等模块才能正常工作。   
  
和51 系列单片机相比,S3C2440 的时钟电路很复杂。   
  
首先通过引脚OM2,OM3 来选择时钟源。   
  
  
  
以TQ2440 开发板为例,OM2,OM3 都接地,外接12M 晶振,主时钟源和USB 时钟源都是
外部晶振。   
  
S3C2440 具有2 个PLL(Phase Locked Loop:用来产生高频的电路),一个是MPLL,  用于
产生FCLK,  HCLK,  PCLK 三种频率,  这三种频率分别有不同的用途:   
  
  
FCLK 是CPU 提供的时钟信号,如果提到CPU 的主频是400MHz,就是指的这个时钟信号。   
  
  
HCLK 是为AHB 总线提供的时钟信号,  Advanced High-performance Bus,主要用于高速
外设,比如内存控制器,中断控制器,LCD 控制器,  DMA  以及USB host  。   
  
  
PCLK 是为APB 总线提供的时钟信号,Advanced  Peripherals  Bus,主要用于低速外设,
比如WATCHDOG,IIS, I2C,  SDI/MMC, GPIO,RTC  ,UART,PWM,ADC and SPI 等等。   
  
  
另外一个是UPLL,专门用于驱动USB host/Device。并且驱动USB host/Device 的频率必
须为48MHz。   
  
  
  
时钟电路相关寄存器总共有7 个,下面分别介绍。   
  
MPLLCON(0X4C00 0004)和UPLLCON(0X4C00 0008)   
  
这两个寄存器用来设置主锁相环产生的时钟和USB 锁相环产生的时钟。   
  
MPLL=(2*m*Fin)/(p*2^s) UPLL=(m*Fin)/(p*2^s)   
  
其中m=(MDIV+8),p=(PDIV+2),s=SDIV   
P,M 范围:1<=P<=62,1<=M<=248   


----------------------- Page 2-----------------------

注意:MDIV 【19:12】,PDIV 【9:4】,SDIV 【1:0】,当设置MPLL 和UPLL 值的时候,需要
先设置UPLL 再设置MPLL。   
  
例如:MPLLCON = (92<<12) | (1<<4) |(1);//FCLK=400M   
这里MDIV=92,PDIV=1,SDIV=1,那么m=100,p=3,s=1,且Fin=12M,所以FCLK=400M   
  
  
  
CLKCON(0X4C00  000C)  控制各种模块如 SPI,IIC,UART  等的时钟电路开关以及系统的
SLEEP,IDLE 模式,以便降低系统功耗。默认值是全部时钟电路打开,系统工作在正常模式。   
  
  
  
CLKSLOW(0X4C00  0010)用来选择系统是否进入慢模式,以及是否关闭MPLL 或UPLL,
和在慢模式下的分频率。   
  
  
  
CLKDIVN(0X4C00  0014)和CAMDIVN(0X4C00  0018 照相机时钟分割寄存器)两个寄存器
配合来确定FCLK,HCLK,PCLK 的比例。   
  
  
  
LOCKTIME(0X4C00 0000)设置MPLL,UPLL 的锁存时间,采用默认值0XFFFF FFFF,锁存
时间各为300us。   
  
说到锁存时间,就要分析下S3C2440 的时钟工作过程。   
  
在系统复位时,晶振起振稳定后,PLL  开始按照默认值开始工作,但是在复位时,PLL  工
作是不稳定的,所以 S3C2440                          用 FIN      (12M )作为 MPLL 。只到一个新的值写入
MPLLCON,UPLLCON,即使用户不想改变复位后PLLCON 的默认值,仍然需要把这个默认
值写入PLLCON,写入值之后,系统会自动插入一个PLL LOCK TIME,也就是LOCKTIME
寄存器中设置的300us。300us 后,PLL 就开始正常工作。   
  深圳专业嵌入式ARM、Linux、单片机技术实训。学习顾问郭老师:QQ754634522
在系统正常工作时,如果要改变FCLK,写入新值到MPLLCON 后,系统也会插入一个PLL  
LOCK TIME,300us 后FCLK 就变成新的频率。  
高级模式
B Color Image Link Quote Code Smilies

本版积分规则

Archiver|手机版|小黑屋|52RD我爱研发网 ( 沪ICP备2022007804号-2 )

GMT+8, 2024-11-23 20:51 , Processed in 0.046179 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表