3223|0

6802

帖子

0

TA的资源

五彩晶圆(高级)

楼主
 

贴一个F28335的时钟设置 [复制链接]

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 limp mode
  •   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 the PLL 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 power settle
  •   // 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;
  •   }
  •   }

[color=rgb(51, 102, 153) !important]复制代码


 
点赞 关注

回复
举报
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表