LPC2478时钟模块详解

时间:2023-11-10 13:16:02

LPC2478时钟模块详解

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

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

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

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

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

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

LPC2478时钟模块详解

4.      PLL设置过程如下

LPC2478时钟模块详解

代码如下

#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