Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3404486
  • 博文数量: 754
  • 博客积分: 10132
  • 博客等级: 上将
  • 技术积分: 7780
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-14 23:36
文章分类

全部博文(754)

文章存档

2012年(3)

2011年(39)

2010年(66)

2009年(167)

2008年(479)

我的朋友

分类: LINUX

2008-10-19 22:37:29

存储器:
LOCKTIME MPLL,UPLL锁定时间寄存器
MPLLCON
UPLLCON
CLKCON   时钟使能设置
CLKSLOW  SlowMode模式设置
CLKDIVN  预分频

先设置MPLL,然后通过CLKDIV分频(FCLK,HCLK,PCLK)
void SetClockDivider(int hdivn, int pdivn)
{
     // hdivn,pdivn FCLK:HCLK:PCLK
     //     0,0         1:1:1
     //     0,1         1:1:2
     //     1,0         1:2:2
     //     1,1         1:2:4
    //如果为SlowMode(寄存器CLKSLOW的SLOW_BIT位),MPLL无效,所以返回没必要继续操作
    if(SlowMode)
     return;
    
 hdivn &= 1;
 pdivn &= 1;
 sCLKDIVN = (hdivn<<1)|pdivn;
 rCLKDIVN = sCLKDIVN;
    if(hdivn)
        MMU_SetAsyncBusMode();//参考s3c2410 DataSheet 231、545页
    else
        MMU_SetFastBusMode();
       
 SetHclkPclk();
}


MMU_SetAsyncBusMode
   mrc p15,0,r0,c1,c0,0
   orr r0,r0,#R1_nF:OR:R1_iA
   mcr p15,0,r0,c1,c0,0
   MOV_PC_LR


MMU_SetFastBusMode
   mrc p15,0,r0,c1,c0,0
   bic r0,r0,#R1_iA:OR:R1_nF
   mcr p15,0,r0,c1,c0,0
   MOV_PC_LR

//只是计算FCLK,HCLK,PCLK频率,并没有直接操作寄存器,系统频率由SetSysFclk()设置
static void SetHclkPclk()
{
 if(sCLKDIVN&2)
  SYS_HCLK = SYS_FCLK>>1;
 else
  SYS_HCLK = SYS_FCLK;
 
 if(sCLKDIVN&1)
  SYS_PCLK = SYS_HCLK>>1;
 else
  SYS_PCLK = SYS_HCLK;
}



U8 SetSysFclk(U32 val)
{
 U32 i, freq;
 U8 mdiv, pdiv, sdiv;
 
 if(SlowMode)
  return FALSE;
 
// PLL Control Register (MPLLCON and UPLLCON)
// Mpll = (m * Fin) / (p * 2的s次方)
// m = (MDIV + 8), p = (PDIV + 2), s = SDIV
// PLL Value Selection Guide
// 1. Fout = m * Fin / (p*2^s), Fvco = m * Fin / p where : m=MDIV+8, p=PDIV+2, s=SDIV
// 2. Fin/(25*p) < 28.449e6/m < Fin/(10*p)
// 3. 0.7 < 3.373/sqrt(m) < 1.8
// 4. 160e6 £ Fvco £ 400e6
// 5. 20e6 £ Fout £ 300e6 ( The max. Fout of the PLL itself is 300Mhz )
// 6. FCLK ³ 3X-tal or 3EXTCLK

 mdiv = (val>>12)&0xff;//mdiv=
 pdiv = (val>>4)&0x3f;//pdiv=
 sdiv = val&0x3;//sdiv=
 
 //p * 2的s次方
 i = (pdiv+2);
 while(sdiv--)
  i *= 2;
  
 freq = ((mdiv+8)*EXT_XTAL_FREQ)/i;
 if(freq>=(3*EXT_XTAL_FREQ)) {
  rMPLLCON = val;
  SYS_FCLK = freq;
  SetHclkPclk();
  if(os_timer_run) {
   os_timer_rld = SYS_PCLK/(8*4*Timer4Freq)-1;
   chg_os_timer = 1;
  }
  if(bios_timer_run) {
   bios_timer_rld = SYS_PCLK/(8*4*BIOS_TIMER_FREQ)-1;
   chg_bios_timer = 1;
  }
  return TRUE;
 }
 return FALSE;
}
阅读(2407) | 评论(2) | 转发(0) |
0

上一篇:希腊符号

下一篇:ARM 协处理器

给主人留下些什么吧!~~

chinaunix网友2009-11-05 10:15:23

可以.....

chinaunix网友2009-11-05 10:14:53

45