S2C2440 时钟的设置方式

发布时间:2023-09-05  

1. S2C2440 的时钟是通过MPLL锁相环环来进行倍频的 其中公式为

 

 

在S2C2440里面有三种时钟 1: FLCK 这个是内核的时钟最大可以到400Mhz

                                            2.    HLCK 高速时钟 这个是提供给内部资源的时钟最大为136Mhz

                                            3. Pclk 这个是外设的时钟 最大是68Mhz

 

注意: 所有的时钟都是有FLCK分频得来

 

 下面我们要做的是如何在内核时钟最大的时候400Mhz 的时候 分频给Hclk 100Mhz 和外设时钟68Mhz

 

 

 上图的寄存器是为ARM提供上电延时的时钟延时 一般都是取默认值

 

 

 

上图的寄存器是从FCLK分频: 其中HDIVN我们选择 10  PDIVN 我们选择HLCK/2 即1   100MZH/2

 

 

这段代码需要加载到汇编语言中

 

随后就是倍频寄存器 图如下

 

 

我们利用已经给好的数组算出就好。

下面是代码

.text

.global _start


_start:


    /* 关闭看门狗 */

    ldr r0, =0x53000000

    ldr r1, =0

    str r1, [r0]


    /* 设置MPLL, FCLK : HCLK : PCLK = 400m : 100m : 50m */

    /* LOCKTIME(0x4C000000) = 0xFFFFFFFF */

    ldr r0, =0x4C000000

    ldr r1, =0xFFFFFFFF

    str r1, [r0]


    /* CLKDIVN(0x4C000014) = 0X5, tFCLK:tHCLK:tPCLK = 1:4:8  */

    ldr r0, =0x4C000014

    ldr r1, =0x5

    str r1, [r0]


    /* 设置CPU工作于异步模式 */

    mrc p15,0,r0,c1,c0,0

    orr r0,r0,#0xc0000000   //R1_nF:OR:R1_iA

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


    /* 设置MPLLCON(0x4C000004) = (92<<12)|(1<<4)|(1<<0) 

     *  m = MDIV+8 = 92+8=100

     *  p = PDIV+2 = 1+2 = 3

     *  s = SDIV = 1

     *  FCLK = 2*m*Fin/(p*2^s) = 2*100*12/(3*2^1)=400M

     */

    ldr r0, =0x4C000004

    ldr r1, =(92<<12)|(1<<4)|(1<<0)

    str r1, [r0]


    /* 一旦设置PLL, 就会锁定lock time直到PLL输出稳定

     * 然后CPU工作于新的频率FCLK

     */

    

    


    /* 设置内存: sp 栈 */

    /* 分辨是nor/nand启动

     * 写0到0地址, 再读出来

     * 如果得到0, 表示0地址上的内容被修改了, 它对应ram, 这就是nand启动

     * 否则就是nor启动

     */

    mov r1, #0

    ldr r0, [r1] /* 读出原来的值备份 */

    str r1, [r1] /* 0->[0] */ 

    ldr r2, [r1] /* r2=[0] */

    cmp r1, r2   /* r1==r2? 如果相等表示是NAND启动 */

    ldr sp, =0x40000000+4096 /* 先假设是nor启动 */

    moveq sp, #4096  /* nand启动 */

    streq r0, [r1]   /* 恢复原来的值 */

    


    bl main


halt:

    b halt


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    .主体结构模块 本设计分为核心控制、显示控制和时间调整三大模块,主体结构如图1 所示。 图1 主体结构模块 2.LED灯模块 该钟表中LED 灯的摆放位置如图2 所示: 图2(红色LED 灯表示小时......
    AT89S51单片机对6位LED数码管实现显示时计方式的设计;这是我们设计的单片机电子钟/计时器学习板,它采用6位LED数码管显示时、分、秒,以24小时计时方式。可以通过按键实现时分调整、秒表/时钟......
    设计完成之后,最终能够实现如下多种功能: 1、夜灯功能:七彩闪烁小夜灯,跟随音乐的节奏闪烁; 2、LED显示:外置显示屏,电量显示,音乐显示; 3、时钟显示:自动适配时区,24小时时钟显示; 4、语音交互:用语......
    音频处理器的架构_音频处理器的延时怎么调整;  音频处理器的架构   音频处理器又称为数字处理器,是对数字信号的处理,其内部的结构普遍是由输入部分和输出部分组成。它内部的功能更加齐全一些,有些......
    ;当K1按下3次时,按K2对小时进行调整,当按下4次K1时,校时完毕,时钟按设定的时间进行正常走时。 当按1次K3进入闹钟设置界面,时钟继续进行走时,按K2对秒进行设置;当按2次K3,按K2......
    下设置按键设置日。设置完日期再按下设置键退出设置。 通过按下闹钟按键进入闹钟显示模式,闹钟指示灯亮。显示默认闹钟时间16.30。需要修改闹钟时间的话按下设置键,时间闪烁表示设置时钟,再按......
    出XXlllXXX,U3的⑨脚输出高电平,这样,输出数据就被锁存在U4的00~04中了。 二、软件设计 程序主要包括:定时中断服务程序、时钟显示程序、键盘扫描处理程序、八路时控程序,主程序流程见图2......
    步进电机驱动器怎么调_步进驱动器正反转怎么控制的;  步进电机驱动器怎么调   步进电机驱动器的调整包括两个方面:电气参数的设置和运动参数的调整。电气参数的设置包括电流、细分数、步进角等,而运动参数的调整......
    伺服控制器怎么调_伺服控制器和伺服驱动器的区别;  伺服控制器怎么调   伺服控制器的调试需要根据具体应用场景和控制器型号进行具体设置和调整。一般来说,伺服控制器的调试包括以下几个方面:   电气参数调整......
    怎么调节使用普源示波器;普源示波器的调节和使用方法 作为电子工程师,在测试电路中都会用到示波器,普源精电示波器作为国产示波器是针对最广泛的主流数字示波器市场的设计、调试、测试......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>