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数据之后必须要解锁写入的数据才能生效,如下
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
LPC2478时钟模块详解的更多相关文章
- Python中操作mysql的pymysql模块详解
Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...
- python之OS模块详解
python之OS模块详解 ^_^,步入第二个模块世界----->OS 常见函数列表 os.sep:取代操作系统特定的路径分隔符 os.name:指示你正在使用的工作平台.比如对于Windows ...
- python之sys模块详解
python之sys模块详解 sys模块功能多,我们这里介绍一些比较实用的功能,相信你会喜欢的,和我一起走进python的模块吧! sys模块的常见函数列表 sys.argv: 实现从程序外部向程序传 ...
- python中threading模块详解(一)
python中threading模块详解(一) 来源 http://blog.chinaunix.net/uid-27571599-id-3484048.html threading提供了一个比thr ...
- python time 模块详解
Python中time模块详解 发表于2011年5月5日 12:58 a.m. 位于分类我爱Python 在平常的代码中,我们常常需要与时间打交道.在Python中,与时间处理有关的模块就包括: ...
- python time模块详解
python time模块详解 转自:http://blog.csdn.net/kiki113/article/details/4033017 python 的内嵌time模板翻译及说明 一.简介 ...
- 小白的Python之路 day5 time,datatime模块详解
一.模块的分类 可以分成三大类: 1.标准库 2.开源模块 3.自定义模块 二.标准库模块详解 1.time与datetime 在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时 ...
- 小白的Python之路 day5 random模块和string模块详解
random模块详解 一.概述 首先我们看到这个单词是随机的意思,他在python中的主要用于一些随机数,或者需要写一些随机数的代码,下面我们就来整理他的一些用法 二.常用方法 1. random.r ...
- Python中time模块详解
Python中time模块详解 在平常的代码中,我们常常需要与时间打交道.在Python中,与时间处理有关的模块就包括:time,datetime以及calendar.这篇文章,主要讲解time模块. ...
随机推荐
- Spark集群搭建中的问题
参照<Spark实战高手之路>学习的,书籍电子版在51CTO网站 资料链接 Hadoop下载[链接](http://archive.apache.org/dist/hadoop/core/ ...
- 学习笔记——状态模式State
状态模式,主要是用于存在大量case判断的操作执行,同时这些case依赖于对象的状态,那么就可以将大量的case判断封装为独立的类. Context: -state,当前状态对象. ChangeSta ...
- HDU 3552 I can do it!
脑洞题.http://blog.csdn.net/dgq8211/article/details/7748078 #include<cstdio> #include<cstring& ...
- PAT1004
A family hierarchy is usually presented by a pedigree tree. 一个家族的层次结构经常用一个血缘树来呈现. Your job is to cou ...
- 免费vpn:SoftEther VPN
Google it. 注意下载2.0版的,不要下载最新版的.
- 解开神秘面纱之“AngualrJS 中指令相关的嵌入作用域和模板作用域”
原文:https://www.airpair.com/angularjs/posts/transclusion-template-scope-in-angular-directives#r1 原标题: ...
- 2016大连网络赛 Weak Pair
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Prob ...
- js变量数组
<html><head lang="en"> <meta charset="UTF-8"> <title>< ...
- 文件夹添加 IIS 应用程序池用户权限
http://serverfault.com/questions/81165/how-to-assign-permissions-to-applicationpoolidentity-account ...
- Chapter 1 First Sight——2
"Bella," my mom said to me — the last of a thousand times — before I got on the plane. &qu ...