ARM11 OK6410学习总结----时钟设置(C语言)

#define APLL_LOCK (*((volatile unsigned long *)0x7E00F000))
#define MPLL_LOCK (*((volatile unsigned long *)0x7E00F004))
#define EPLL_LOCK (*((volatile unsigned long *)0x7E00F008))

#define OTHERS    (*((volatile unsigned long *)0x7e00f900))

#define CLK_DIV0  (*((volatile unsigned long *)0x7E00F020))

#define ARM_RATIO    0   /* ARMCLK = DOUTAPLL / (ARM_RATIO + 1)    */
#define HCLKX2_RATIO 4   /* HCLKX2 = HCLKX2IN / (HCLKX2_RATIO + 1) = 100MHz */
#define HCLK_RATIO   0   /* HCLK = HCLKX2 / (HCLK_RATIO + 1)   = 100MHz       */
#define PCLK_RATIO   1   /* PCLK   = HCLKX2 / (PCLK_RATIO + 1) = 50MHz    */
#define MPLL_RATIO   0   /* DOUTMPLL = MOUTMPLL / (MPLL_RATIO + 1)     */


#define APLL_CON  (*((volatile unsigned long *)0x7E00F00C))
#define APLL_CON_VAL  ((1<<31) | (250 << 16) | (3 << 8) | (1))

#define MPLL_CON  (*((volatile unsigned long *)0x7E00F010))
#define MPLL_CON_VAL  ((1<<31) | (250 << 16) | (3 << 8) | (1))

#define CLK_SRC  (*((volatile unsigned long *)0x7E00F01C))

void clock_init(void)
{
    /*将每一个 LOCK_TIME 设置为 0xffff*/
    APLL_LOCK = 0xffff;
    MPLL_LOCK = 0xffff;
    EPLL_LOCK = 0xffff;

    /* set async mode 当CPU时钟 != HCLK时,要设为异步模式 */
    OTHERS &= ~0xc0;   //将 OTHERS 的第六和第七位清零,以设置成异步模式。
    while ((OTHERS & 0xf00) != 0);
    /*CLK_DIV是为外设进行分频的寄存器,共三个.CLK_DIV0、CLK_DIV1、CLK_DIV2。对于设置内核时钟和AHB、APB的总线时钟来说,我们只需要了解CLK_DIV0的几个位域即可。*/
    CLK_DIV0 = (ARM_RATIO) | (MPLL_RATIO << 4) | (HCLK_RATIO << 8) | (HCLKX2_RATIO << 9) | (PCLK_RATIO << 12);
    
    APLL_CON = APLL_CON_VAL;  /* 500MHz */
    MPLL_CON = MPLL_CON_VAL;  /* 500MHz */

    CLK_SRC = 0x03;//打开时钟源开关,让进过LOCK_TIME后变得稳定后的时钟源输出。
}



注意:OTHERS寄存器中的syncmode和syncmuxsel这两个位应该是协同工作的,一起置1或清0。syncmode要置1,就先向syncmuxsel位写1;syncmode清0后,随即再把syncmuxsel位也清0。


可以结合以下的博客学习:

http://blog.csdn.net/newthinker_wei/article/details/8121506

http://blog.csdn.net/newthinker_wei/article/details/8126035

http://blog.csdn.net/newthinker_wei/article/details/8126354

你可能感兴趣的:(ARM,6410)