K60时钟分析
1.飞思卡尔K60时钟系统


- unsigned char pll_init(unsigned char clk_option, unsigned char crystal_val)
- {
- unsigned char pll_freq;
- if (clk_option > 3) {return 0;} //return 0 if one of the available options is not selected
- if (crystal_val > 15) {return 1;} // return 1 if one of the available crystal options is not available
- //This assumes that the MCG is in default FEI mode out of reset.
- // First move to FBE mode
- #if (defined(K60_CLK) || defined(ASB817))
- MCG_C2 = 0;
- #else
- // Enable external oscillator, RANGE=2, HGO=1, EREFS=1, LP=0, IRCS=0
- MCG_C2 = MCG_C2_RANGE(2) | MCG_C2_HGO_MASK | MCG_C2_EREFS_MASK;
- #endif
- // after initialization of oscillator release latched state of oscillator and GPIO
- SIM_SCGC4 |= SIM_SCGC4_LLWU_MASK;
- LLWU_CS |= LLWU_CS_ACKISO_MASK;
- // Select external oscilator and Reference Divider and clear IREFS to start ext osc
- // CLKS=2, FRDIV=3, IREFS=0, IRCLKEN=0, IREFSTEN=0
- MCG_C1 = MCG_C1_CLKS(2) | MCG_C1_FRDIV(3);
- /* if we aren't using an osc input we don't need to wait for the osc to init */
- #if (!defined(K60_CLK) && !defined(ASB817))
- while (!(MCG_S & MCG_S_OSCINIT_MASK)){}; // wait for oscillator to initialize
- #endif
- while (MCG_S & MCG_S_IREFST_MASK){}; // wait for Reference clock Status bit to clear
- while (((MCG_S & MCG_S_CLKST_MASK) >> MCG_S_CLKST_SHIFT) != 0x2){}; // Wait for clock status bits to show clock source is ext ref clk
- // Now in FBE
- #if (defined(K60_CLK))
- //MCG_C5 = MCG_C5_PRDIV(0x18);
- MCG_C5 = MCG_C5_PRDIV(0x18); //基频2M 外部时钟源是50M时, 50/25=2M
- #else
- // Configure PLL Ref Divider, PLLCLKEN=0, PLLSTEN=0, PRDIV=5
- // The crystal frequency is used to select the PRDIV value. Only even frequency crystals are supported
- // that will produce a 2MHz reference clock to the PLL.
- MCG_C5 = MCG_C5_PRDIV(crystal_val); // Set PLL ref divider to match the crystal used
- #endif
- // Ensure MCG_C6 is at the reset default of 0. LOLIE disabled, PLL disabled, clk monitor disabled, PLL VCO divider is clear
- MCG_C6 = 0x0;
- // Select the PLL VCO divider and system clock dividers depending on clocking option
- switch (clk_option) {
- case 0:
- // Set system options dividers
- //MCG=PLL, core = MCG, bus = MCG, FlexBus = MCG, Flash clock= MCG/2
- set_sys_dividers(0,0,0,1);
- // Set the VCO divider and enable the PLL for 50MHz, LOLIE=0, PLLS=1, CME=0, VDIV=1
- MCG_C6 = MCG_C6_PLLS_MASK | MCG_C6_VDIV(1); //VDIV = 1 (x25)
- pll_freq = 50;
- break;
- case 1:
- // Set system options dividers
- //MCG=PLL, core = MCG, bus = MCG/2, FlexBus = MCG/2, Flash clock= MCG/4
- set_sys_dividers(0,1,1,3);
- // Set the VCO divider and enable the PLL for 100MHz, LOLIE=0, PLLS=1, CME=0, VDIV=26
- MCG_C6 = MCG_C6_PLLS_MASK | MCG_C6_VDIV(26); //VDIV = 26 (x50)
- pll_freq = 100;
- break;
- case 2:
- // Set system options dividers
- //MCG=PLL, core = MCG, bus = MCG/2, FlexBus = MCG/2, Flash clock= MCG/4
- set_sys_dividers(0,1,1,3);
- // Set the VCO divider and enable the PLL for 96MHz, LOLIE=0, PLLS=1, CME=0, VDIV=24
- MCG_C6 = MCG_C6_PLLS_MASK | MCG_C6_VDIV(24); //VDIV = 24 (x48)
- pll_freq = 96;
- break;
- case 3:
- // Set system options dividers
- //MCG=PLL, core = MCG, bus = MCG, FlexBus = MCG, Flash clock= MCG/2
- set_sys_dividers(0,0,0,1);
- // Set the VCO divider and enable the PLL for 48MHz, LOLIE=0, PLLS=1, CME=0, VDIV=0
- MCG_C6 = MCG_C6_PLLS_MASK; //VDIV = 0 (x24)
- pll_freq = 48;
- break;
- }
- while (!(MCG_S & MCG_S_PLLST_MASK)){}; // wait for PLL status bit to set
- while (!(MCG_S & MCG_S_LOCK_MASK)){}; // Wait for LOCK bit to set
- // Now running PBE Mode
- // Transition into PEE by setting CLKS to 0
- // CLKS=0, FRDIV=3, IREFS=0, IRCLKEN=0, IREFSTEN=0
- MCG_C1 &= ~MCG_C1_CLKS_MASK;
- // Wait for clock status bits to update
- while (((MCG_S & MCG_S_CLKST_MASK) >> MCG_S_CLKST_SHIFT) != 0x3){};
- // Now running PEE Mode
- return pll_freq;
- } //pll_init
K60时钟分析的更多相关文章
- 飞思卡尔K60时钟分析
推荐:NXP官方软件config tool,图形化界面可导出代码 K60芯片的时钟系统由振荡器(OSC).实时振荡器(RTC OSC).多功能时钟发生器(MCG).系统集成模块(SIM)和电源管理器( ...
- MINIX3 内核时钟分析
MINIX3 内核时钟分析 4.1 内核时钟概要 先想想为什么 OS 需要时钟?时钟是异步的一个非常重要的标志,设想一下,如 果我们的应用程序需要在多少秒后将触发某个程序或者进程,我们该怎么做到? ...
- stm32时钟分析
转载自http://blog.chinaunix.net/uid-21658993-id-3129667.html 在STM32中,有五个时钟源,为HSI.HSE.LSI.LSE.PLL. 其实是 ...
- KVM 时钟分析
1. 关于GToffset: KVM的guset时钟为gc0_COUNT 其中:mfc0 gc0_count = c0_COUNT+GToffset vcpu_run 以及 vcpu_reenter的 ...
- MINIX3 导读分析
一个操作系统的分析是属于一个非常庞大的工程,操作系统就像是一个人造的 人,每一个模块想完全发挥功效,很有可能需要很多模块的支持才能够实现.所 以在分析 MINIX3 时,我认为同时看多个模块对于理解 ...
- Minix2.0操作系统kernel文件分析
详细分析 MINIX消息机制的核心: mpx386.s start.c proc.c 保护模式分析: src/kernel/exception.c src/kernel/protect.c src/ ...
- LCD RGB 控制技术讲解 — 时钟篇(上)
时序图 下面是LCD RGB 控制的典型时序图 天啊,一下就上这玩意,怎么看??? 其实要解释上面的时序图,我们还需要了解一些LCD的显示过程.所以现在只是有个印象,稍后我们详细讲解. LCD显示流 ...
- LCD RGB 控制技术讲解 — 时钟篇(上)【转】
1. 时序图 下面是LCD RGB 控制的典型时序图 天啊,一下就上这玩意,怎么看??? 其实要解释上面的时序图,我们还需要了解一些LCD的显示过程.所以现在只是有个印象,稍后我们详细讲解. 2. L ...
- minix2.0内核组织结构与公用头文件说明
Minix2.0操作系统的源代码由两个目录组成:include/目录和src/目录 include/目录包含了操作系统所有的头文件(即.h文件) src/目录下包含了操作系统所有的源文件(.c或.s文 ...
随机推荐
- OpenCV:图像的裁剪
import cv2 import matplotlib.pyplot as plt def show(image): plt.imshow(image) plt.axis('off') plt.sh ...
- ListenAndServe源码剖析
使用goland追踪阅读ListenAndServe源码,剖析服务器启动流程 ListenAndServe阅读 func ListenAndServe(addr string, handler Han ...
- Python 3 线程模型,进程模型记录
最近需要使用 python3 多线程处理大型数据,顺道探究了一下,python3 的线程模型的情况,下面进行简要记录: 多线程运行的优点: 使用线程可以把程序中占用时间较长的任务放到后台去处理: 用户 ...
- 【python3基础】python3 神坑笔记
目录 os 篇 os.listdir(path) 运算符篇 is vs. == 实例 1:判断两个整数相等 实例 2:argparse 传参 实例 3:np.where 命令行参数篇 Referenc ...
- Vue动态加载图片图片不显示
图片是放在assets文件夹下的 使用require进行解决 图片不显示的原因 在webpack,将图片放在assets中,会将图片图片来当做模块来用,因为是动态加载的,所以url-loader将无法 ...
- AcWing 901. 滑雪
地址 https://www.acwing.com/problem/content/description/903/ 题目描述给定一个R行C列的矩阵,表示一个矩形网格滑雪场. 矩阵中第 i 行第 j ...
- 题解:A
A (a.pas/c/cpp) [题目描述] 对于给定的一个正整数n, 判断n是否能分成若干个正整数之和 (可以重复) , 其中每个正整数都能表示成两个质数乘积. [输入描述] 第一行一个正整数 q, ...
- Node.js使用Nodemailer发送邮件
除了Python,在node中收发电子邮件也非常简单,因为强大的社区有各种各样的包可以供我么直接使用.Nodemailer包就可以帮助我们快速实现发送邮件的功能. Nodemailer简介 Nodem ...
- kvm与xen虚拟化的比较(转)
Linux虚拟化技术的用户目前有两种免费的开源管理程序可以选择:Xen和KVM. 作为较早出现的虚拟化技术,Xen是“第一类”运行在裸机上的虚拟化管理程序(Hypervisor),也是当前相当一部分商 ...
- 01-Git单人本地仓库操作
Git源代码管理 Git(多人协同开发同一个项目),作用就是源代码管理,为什么需要源代码管理呢,方便多人协同开发,并且方便版本控制. Git管理源代码特点: 1.Git是分布式管理.服务器和客户端都有 ...