ARM中计算MPLL的方法

1. U32 mpll_val=0;

      mpll_val = (92<<12)|(1<<4)|(1);

      算得mpll_val的二进制:0101 1100 0000 0001 0001

       注意:(92<<12)中的92为十进制数,转换为二进制为0x5C。
2. ChangeMPllValue((mpll_val>>12)&0xff, (mpll_val>>4)&0x3f, mpll_val&3);

     代入1算得:ChangeMPllValue(0x5C,1,1);

3. 找到ChangeMPllValue子函数

      void ChangeMPllValue(int mdiv,int pdiv,int sdiv)
             {

                     rMPLLCON = (mdiv<<12) | (pdiv<<4) | sdiv;
              }

4. 调用子函数,得到rMPLLCON二进制为:0101 1100 0000 0001 0001

5. 根据S3C2440A官方datasheet:

     PLLCON          Bit                        Deion

        MDIV         [19:12]           Main divider control

        PDIV          [9:4]               Pre-divider control

         SDIV          [1;0]               Post divider control

      以及MPLL Control Register

            Mpll=(2*m*Fin)/(p*2s)

           m=(MDIV+8)   p=(PDIV+2)   s=SDIV

   因rMPLLCON二进制为:0101 1100 0000 0001 0001,所以

m=(MDIV+8)=([19:12]+8)=92+8=100

p=(PDIV+2)=([9:4]+2)=1+2=3

s=SDIV=[1:0]=1

   Mpll=(2*m*Fin)/(p*2s)=(2*100*12)/(3*2)=400M

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值