zoukankan      html  css  js  c++  java
  • LPC2478时钟模块详解


    时钟框图如上图,系统时钟来源分别是内部4M的RC振荡器和外置晶振,RTC模块在某些情况下也可以作为主时钟,经过系统时钟选择sde时钟需要经过PLL倍频(或者不倍频),处理过的PLL输出USB时钟分频器和CPU时钟分频器,成为FCCLK 和FUSBCLK,FCCLK供给系统内核,以太网模块,以及各式AHB外设,APB外设的时钟来自于PLLCLK,经过外设时钟发生器,分频出各个时钟供给外设使用,同时,时钟模块也能切断外设模块的时钟

    另外,看门狗定时器有多重时钟可以选择,系统实时时钟也有多个模式的时钟源可以选择

    使用时钟模块时,主要有以下注意事项

    1.      切换时钟源的时候PLL必须被断开,否则无法切换成功

    2.      PLL输入时钟最大50M,产生的时钟最小275M

    3.      PLL配置寄存器的写入需要解锁,写入PLL数据之后必须要解锁写入的数据才能生效,如下


    4.      PLL设置过程如下

     

             代码如下

     

    #include "clock.h"
    
    u32 SystemCoreClock;
    
    void ClockSet(u8 clockSel)
    {
    	if((PLLSTAT&(1<<25)))//如果PLL连接
    	{
    		PLLCON &= ~(1<<1);//断开PLL连接
    		PLLFEED  = 0xAA;//发送馈送序列
    		PLLFEED  = 0x55;
    		while((PLLSTAT&(1<<25)));//等待PLL断开连接
    	}
    	PLLCON &= ~(1<<0);//禁用PLL
    	PLLFEED  = 0xAA;//发送馈送序列
    	PLLFEED  = 0x55;
    	while((PLLSTAT&(1<<24)));//等待PLL禁止
    	if(clockSel == CLOCK_HSE)	//选择外部时钟
    	{
    		SCS &= ~(1<<4);//主振荡器频率选择1-20M
    		SCS |= (1<<5);//主振荡器使能
    		while((SCS&(1<<6)) == 0);//等待主振荡器准备好
    		
    		CLKSRCSEL = 0x01;//选择主时钟源为PLL时钟
    		SystemCoreClock = 100000000;
    		
    	}
    	else if(clockSel == CLOCK_HSI)//选择内部时钟
    	{
    		CLKSRCSEL = 0x00;//选择内部RC振荡器为系统时钟源
    		SystemCoreClock = 100000000;
    	}
    	PLLCFG = 0x00050063;    // 选择PLL倍频     N 6 M 100 12M 2*100*4/2 = 400M
    	PLLFEED  = 0xAA;//发送馈送序列
    	PLLFEED  = 0x55;
    	
    	PLLCON   |= 0x01;             /* 使能PLL                */
    	PLLFEED  = 0xAA;
    	PLLFEED  = 0x55;
    	while (!(PLLSTAT & (1<<24)));/* 等待PLL0使能  */
    //	while (!(PLLSTAT & (1<<26)));/* 等待PLL0锁定  */
    	
    	//修改cpu分频数值
    	CCLKCFG = 0x03;//四分频 400/4 = 100M
    	
    	PLLCON   |= (1<<1);             /* 连接PLL                */
    	PLLFEED  = 0xAA;
    	PLLFEED  = 0x55;
    	while (!(PLLSTAT & (1<<25)));/* 等待PLL连接  */
    	
    	//此时,PLL时钟就OK了,接下来需要设置外设的分频数
    	PCLKSEL0 = 0x00000040;//外设时钟均为25M
    	PCLKSEL1 = 0x00000000;
    	
    	PCONP = 0x00000000;//禁用全部外设时钟
    }
    
    

    #ifndef __CLOCK_H_
    #define __CLOCK_H_
    
    #include "lpc24xx.h"
    #include "common.h"
    
    #define CLOCK_HSE	1
    #define CLOCK_HSI	2
    
    void ClockSet(u8 clockSel);
    
    
    extern u32 SystemCoreClock;
    
    #endif
    
    
    
    
    
    

  • 相关阅读:
    js 作用域
    js 实现二级联动
    JavaScript 基础(四)
    JavaScript 基础(三)
    数据库事务的基本概念
    二进制安装 kubernetes 1.12(五)
    二进制安装 kubernetes 1.12(四)
    二进制安装 kubernetes 1.12(三)
    二进制安装 kubernetes 1.12(二)
    Centos 7.x 安装 Docker-ce
  • 原文地址:https://www.cnblogs.com/dengxiaojun/p/4279403.html
Copyright © 2011-2022 走看看