分类: LINUX
2015-03-19 11:15:24
参考链接:http://blog.csdn.net/mjx91282041/article/details/8887729
在移植Nboot时,发现串口输出乱码,检查串口配置没问题后,觉得应该是时钟配置没配好,修改后果然ok,所以补习一下!
2440时钟配置详细说明,以上电为顺序讲述:
2、 有4种时钟:FCLK,HCLK,PCLK,UCLK具体分工如下:
FCLK is used by ARM920T.
HCLK is used for AHB bus, which is used by the ARM920T, the memory controller, the interrupt controller, the LCD
controller, the DMA and USB host block.
PCLK is used for APB bus, which is used by the peripherals such as WDT, IIS, I2C, PWM timer, MMC interface,
ADC, UART, GPIO, RTC and SPI.
UCLK专门为USB供电,有UPLL输出。
3、有两个锁相环,一个MPLL负责FCLK,HCLK,PCLK,一个UPLL负责USB的48MHz,通过三个倍频因子MDIV、PDIV和SDIV来 设置倍频。
1、主时钟源可以由外部时钟(EXTCLK)或者外部晶振(XTIPll)提供,时钟源由模式控制引脚OM3和OM2选择,在复位信号
的上升沿检测OM3和OM2引脚状态并锁定在OM[3:2]中。
2、我们可以在程序开头启动MPLL,在设置MPLL的几个寄存器后,需要等待一段时间(Lock Time),MPLL的输出才稳定。在这段
(Lock Time)时间内,FCLK停振,CPU停止工作。Lock Time的长短由寄存器LOCKTIME设定。Lock Time之后,MPLL输出平
稳。在上电没有设置MPLL时,系统时钟为晶振时钟。
( 0x4C000004)、UPLLCON(0x4C000008)。
2、时钟配置顺序如上:LOCKTIME => CLKDIVN => MPLLCON => UPLLCON。注意:UPLL的设置要先于MPLL,切超前7个时钟
设置。
3、时钟样例:
(1)、LOCKTIME:位[31:16]用于UPLL,位[15:0]用于MPLL。确省值为0xFFFFFFFF
(2)、CLKDIVN:DIVN _UPLL[3]:HDIVN [2:1]:PDIVN [0]用来设置FCLK:HCLK:PCLK的比例关系,默认为1:1:1。
CLKDIVN不同的设置及对应的时钟比例关系如下图:
图HDIVN 和PDIVN对应的比例,HCLK4_HALF和HCLK3_HALF在摄像头CAMDIVN寄存器中。
( 3)MPLLCON寄存器位[19:12]-MDIV(Main divider control);[9:4]-PDIV(Pre-divider control);[1:0]-SDIV(Post divider
control)。
锁相环输出时钟MPLL(FCLK) 通过如下计算公式得出:
MPLL(FCLK) = (2 * m * Fin)/(p * 2^s);其中:m = (MDIV + 8), p = (PDIV + 2), s = SDIV,Fin 输入的时钟频率。
如:MPLLCON设为(0x5c << 12)|(0x01 << 4)|(0x1),即0x5c010,可以计算出FCLK=400MHz,假设CLKDIVN设置
HDIV=1和PDIV=1;可知比例FCLK、HCLK、PCLK比率为1:2:4,所以HCLK=200MHz,PCLK=100MHz。
下图 为锁相环配置推荐表。
NOTE: The 48.00MHz and 96MHz output is used for UPLLCON register.
UPLLCON同理一样设置,计算公式如下:UPLL(UCLK) = (m * Fin) / (p * 2^s),m = (MDIV + 8), p = (PDIV + 2), s =SDIV。
Fin 输入的时钟频率。
(4)程序: