s3c6410时钟初始化

本文详细介绍了S3C6410处理器的时钟初始化过程,包括3个内部PLL的设置、时钟模式切换、时钟分频器配置、输出频率计算及时钟源选择,提供了相应的汇编代码示例。
摘要由CSDN通过智能技术生成

    今天自己写bootloader做时钟初始化时遇到的问题,特记录下来。为了方便理解,我大部分都有截图, 在此我先说明下,图均来自数据手册。也希望看了本篇文章的同志多多参看数据手册才能理解的更加透彻,才能真正的锻炼自己的能力。下面程序部分我也拆分成了5个部分分别解释,最后也给出了整个程序。本文如果有什么错误的地方,欢迎各位批评指正,不甚感激。

    6410有3个内部PLL(Phase Locked Loop:为锁相回路或锁相环,用来统一整合时脉讯号,使内存能正确的存取资料。PLL用于振荡器中的反馈技术。 许多电子设备要正常工作,通常需要外部的输入信号与内部的振荡信号同步,利 用锁相环路就可以实现这个目的。)分别是:APLL、MPLL、EPLL。他们被下面7个寄存器控制:

        

1、 其中前3个寄存器见下图:

        

所以对应的初始化代码为:

    //set the clock time

    ldr r0, =0x7e00f000 //APLL_CLOCK
    ldr r1, =0xffff
    str r1, [r0]

    str r1, [r0, #0x4]  //MPLL_CLOCK

    str r1, [r0, #0x8]  //EPLL_CLOCK

 

2、 接着设置时钟为异步模式,通过others寄存器设置,图和代码如下:

        
这是others被设置的对应的位,这里截取得其中用到的部分。
        
   //set Async mode

    ldr r0, =0x7e00f900 //OTHERS

    ldr r1, [r0]

    bic r1, #0xc0

    str r1, [r0]

    //wait for Async mode

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值