资源描述:
《s3c2410系统时钟和定时器》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、S3C2410系统时钟和定时器S3C2410系统时钟和定时器(2011-05-2608:59)主机环境:UBUNTU10.04LTS+arm-linux-gcc2.95.3开发板环境:EdukitIII实验箱+s3c2410子板问题描述:首先初始化S3C2410系统时钟,然后通过定时器中断来控制LED的点亮、熄灭情况【1.系统时钟硬件原理】EdukitIII实验箱上一共有两个时钟,都是通过外接晶振实现,一个是实时时钟RTC,主要为系统计时使用,其晶振X101频率为32.768kHz;另一个是系统时钟,为硬件设备提供时钟信号使用,其晶振X102为12MHz,系统时钟都是在X102的基础上通过
2、时钟寄存器的控制来生成不同的时钟信号,为不同的硬件设备提供工作时钟信号。S3C2410的时钟控制逻辑可以外接晶振,然后通过内部的电路产生时钟源,也可以直接使用外部提供的时钟源,通过引脚设置来选择。时钟逻辑为整个系统提供3种时钟:FCLK用于CPU核;HCLK用于AHB总线上的设备,如存储控制器、中断控制器、LCD控制器、DMA、USB主机模块等;PCLK用于APB总线上的设备,如WATCHDOG、IIS、I2C、PWM定时器、MMC接口、ADC、UART、GPIO、RTC、SPI等。开发板上的外接时钟(晶振X102为12MHz)通过相位锁相环(PLL)电路来提高频率,S3C2410有两个P
3、LL,一个MPLL,用于设置FCLK、HCLK、PCLK;另一个为UPLL,用于USB设备。上电时,PLL没有启动,FCLK等于外部输入时钟Fin,若要提高系统频率,通过软件来启用PLL(设置相关寄存器),图1为PLL上电后的启动过程图1上电后MPLL的启动过程图中的OSC即是外接晶振X102,频率为12MHz,上电后需要等待一段时间(LockTime),MPLL才能输出稳定,LockTime的值由寄存器LOCITIME设置。LockTime之前,FCLK=Fin,LockTime之后,MPLL输出正常,CPU工作在新的FCLK之下。启动S3C2410的MPLL,要设置3个相关寄存器:1.
4、LOCITIME寄存器,用于设置LockTime的长度,地址和各位含义如图2所示图2LOCKTIME地址和各位含义LOCKTIME[0:11]用于设置MPLL的LockTime,LOCKTIME[12:23]用于设置UPLL的LockTime,使用默认值0x00FFFFFF即可。2.MPLLCON寄存器(MainPLLControl):用于设置FCLK与Fin的倍数,地址和各位含义如图3所示图3MPLLCON地址和各位含义MPLLCON[0:1]称为SDIV,MPLLCON[4:9]称为PDIV,MPLLCON[12:19]称为MDIV,FCLK的计算公式如下:S3C2410:MPLL(F
5、CLK)=(m*Fin)/(p*2^s)S3C2410:MPLL(FCLK)=(2*m*Fin)/(p*2^s)其中:m=MDIV+8,p=PDIV+2,s=SDIV对于本开发板,Fin=12MHz(晶振X102的频率)本例要产生的FCLK为200MHz,因此MDIV=0x5C=92;PDIV=0x04=4;SDIV=0x00=0,所以m=100,p=6,s=0,把Fin=12MHz代入S3C2410的MPLL(FCLK)计算公式,可以得到FCLK=200MHz,因此该寄存器的值可以设置为((0x5c12)
6、(0x044)
7、(0x00))。图4是一些常用的PLL值,设置MPLLCON寄存器
8、时可以参考该表。图4:MPLLCON常用设置值3.CLKDIVN寄存器,用于设置FCLK、HCLK、PCLK的比例,地址和各位含义如图5所示图5CLKDIVN地址和各位含义HDIVN1=CLKDIVN[2]=0,表示保留,HDIVN1=CLKDIVN[2]=1,表示FCLK:HCLK:PCLK=1:4:4,此时HDIVN和PDIVN均要设置为0。HDIVN=CLKDIVN[1]=0,表示HCLK=FCLK,HDIVN=CLKDIVN[1]=1,表示HCLK=FCLK/2;PDIVV=CLKDIVN[0]=0,表示PCLK=HCLK,PDIVV=CLKDIVN[0]=1,表示PCLK=FCL
9、K/2。对于本例程,要求FCLK:HCLK:PCLK=1:2:4,所以CLKDIVN[0:2]=0b110=0x3。如果HDIVN=1,那么CPU要从fastbusmode转换为asynchronousbusmode,可以通过如下指令完成:mrcp15,0,r1,c1,c0,0/*读出控制寄存器*/orrr1,r1,0xc0000000/*设置为"asynchronousbusmode"*/mcrp15,0,r1