TMS320F28335的时钟介绍
来源:互联网 发布:windows能装mac系统吗 编辑:程序博客网 时间:2024/05/21 05:21
TMS320F28335的时钟介绍
TMS320F28335上有一个基于PLL电路的片上时钟模块,为CPU及外设提供时钟有两种方式:一种是用外部的时钟源,将其连接到X1引脚上或者XCLKIN引脚上,X2接地;另一种是使用振荡器产生时钟,用30MHz的晶体和两个20PF的电容组成的电路分别连接到X1和X2引脚上,XCLKIN引脚接地。我们常用第二种来产生时钟。此时钟将通过一个内部PLL锁相环电路,进行倍频。由于F28335的最大工作频率是150M,所以倍频值最大是5。其中倍频值由PLLCR的低四位和PLLSTS的第7、8位来决定。其详细的倍频值可以参照TMS320F28335的Datasheet。下面是F28335的时钟设置:
void InitPll(Uint16 val, Uint16 divsel)
{
// Make sure the PLL is not running in limpmode
if(SysCtrlRegs.PLLSTS.bit.MCLKSTS != 0)
{
// Missing external clock has been detected
// Replace this line with a call to an appropriate
// SystemShutdown(); function.
asm(" ESTOP0");
}
//DIVSEL MUST be 0 before PLLCR can be changed from
//0x0000. It is set to 0 by an external reset XRSn
//This puts us in 1/4
if(SysCtrlRegs.PLLSTS.bit.DIVSEL != 0)
{
EALLOW;
SysCtrlRegs.PLLSTS.bit.DIVSEL = 0;
EDIS;
}
//Change the PLLCR
if(SysCtrlRegs.PLLCR.bit.DIV != val)
{
EALLOW;
// Before setting PLLCR turn off missing clock detect logic
SysCtrlRegs.PLLSTS.bit.MCLKOFF = 1;
SysCtrlRegs.PLLCR.bit.DIV = val;
EDIS;
// Optional: Wait for PLL to lock.
// During this time the CPU will switch to OSCCLK/2 until
// the PLL is stable. Once thePLL is stable the CPU will
// switch to the new PLL value.
//
// This time-to-lock is monitored by a PLL lock counter.
//
// Code is not required to sit and wait for the PLL to lock.
// However, if the code does anything that is timing critical,
// and requires the correct clock be locked, then it is best to
// wait until this switching has completed.
// Wait for the PLL lock bit to be set.
// The watchdog should be disabled before this loop, or fed within
// the loop via ServiceDog().
//Uncomment to disable the watchdog
DisableDog();
while(SysCtrlRegs.PLLSTS.bit.PLLLOCKS != 1)
{
// Uncomment to service the watchdog
// ServiceDog();
}
EALLOW;
SysCtrlRegs.PLLSTS.bit.MCLKOFF = 0;
EDIS;
}
// If switching to 1/2
if((divsel == 1)||(divsel == 2))
{
EALLOW;
SysCtrlRegs.PLLSTS.bit.DIVSEL = divsel;
EDIS;
}
// If switching to 1/1
// * First go to 1/2 and let the powersettle
// The time required will depend on the system, this is only an example
// * Then switch to 1/1
if(divsel == 3)
{
EALLOW;
SysCtrlRegs.PLLSTS.bit.DIVSEL = 2;
DELAY_US(50L);
SysCtrlRegs.PLLSTS.bit.DIVSEL = 3;
EDIS;
}
}
如果我们希望DSP工作在某一个频率下,我们就可以对Uint16 val, Uint16 divsel两个参数进行设定。
- TMS320F28335的时钟介绍
- TMS320F28335的时钟介绍
- TMS320F28335之系统时钟
- TMS320F28335 时钟分析2
- TMS320F28335 时钟分析3
- TMS320F28335 时钟分析3
- 关于TMS320F28335的eCAN模块时钟的配置
- TMS320F28335时钟(1) -----PLL倍频器的初始化详解
- TMS320F28335时钟(3) -----总结
- TMS320F28335项目开发记录1_CCS的使用介绍
- LPC3250的时钟介绍
- TMS320F28335的GPIO
- TMS320F28335的GPIO
- TMS320F28335的存储空间
- TMS320F28335的CCS配置
- TMS320F28335时钟(2) -----外设时钟初始化详解
- TMS320F28335
- TMS320F28335
- vs2008 wdk 驱动开发环境配置 之wdm
- java程序设计语言将参数传递方法的方式
- TMS320F28335的GPIO
- 突然···
- UNIX多用户系统下信号量操作详解
- TMS320F28335的时钟介绍
- Unix环境进程间通信
- 指向类成员的指针
- .net获取地址栏中的url
- 部署Silverlight应用程序的常见问题_Blog
- 20110621
- 地牢围攻2 宽屏补丁 使用说明
- TMS320F28335外部中断总结
- html转chm的方法