请教TMS320F2812的几个问题

[复制链接]
 楼主| zzu65 发表于 2008-8-15 11:31 | 显示全部楼层 |阅读模式
1、高低速外设时钟是什么意思?<br />TMS320F2812的高速外设时钟寄存器HISPCP和低速外设时钟寄存器LOSPCP分别控制高低速外设时钟<br />通过寄存器中的位2~0可以配置高低速外设时钟相对于SYSCLKOUT的倍频系数<br />高(低)速外设时钟&nbsp;=&nbsp;SYSCLKOUT/(n&nbsp;x&nbsp;2),其中,n&nbsp;=&nbsp;1~7<br />我的疑问是,那些是高速外设,那些是低速外设,他们的时钟公式是一样的,所以低速外设的时钟完全可以配置为高于高速外设时钟,那么这应该是一个相对的概念<br />在2812的内部结构图里,高速外设的框框里有EVA/B,ADC,在低速外设里有SCI,SPI,McBSp,但是在例程中用EVA的时候没有设置过这个时钟,用AD的时候设置过,2812的外设不止这些,那么其他的是属于高速还是低速,什么时候需要设置这个时钟?<br /><br />2、如何设置PIE配置寄存器PIECTRL?<br />在例程中使能PIE中断的时候有这么一条语句:<br />PieCtrlRegs.PIECRTL.bit.ENPIE&nbsp;=&nbsp;1;&nbsp;&nbsp;&nbsp;//&nbsp;Enable&nbsp;the&nbsp;PIE&nbsp;block<br />该位置1所有向量取自PIE向量表,该位置0,PIE无效,向量取自引导ROM的CPU向量表或XINTF7区外部接口。<br />例程中好多次用到PIE中断的时候也没有碰到这条语句,在McBSP的例程中这么设置了,不知道什么意思,有和没有什么区别,什么时候需要用?<br /><br />3、锁相环倍频<br />2812可以通过PLL控制寄存器来选择锁相环的工作模式和倍频系数,一共可以设置10种倍频系数,CLKIN&nbsp;=&nbsp;&nbsp;(OSCCLK&nbsp;&nbsp;X&nbsp;n)/2,其中,n&nbsp;=&nbsp;1~10,如果晶振为30MHz,那么CLKIN&nbsp;=&nbsp;15,30,45,60,75,90,105,120,135,150MHz,大家再看例程中给出的设置倍频系数的程序,以下宏定义只能选择一种,分别对应倍频系数为:10~1<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;&nbsp;6.667L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;150MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;&nbsp;7.143L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;140MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;&nbsp;8.333L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;120MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;10.000L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;100MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;13.330L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;75MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;20.000L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;50MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;33.333L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;30MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;41.667L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;24MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;50.000L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;20MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />#define&nbsp;CPU_RATE&nbsp;&nbsp;100.000L&nbsp;&nbsp;&nbsp;//&nbsp;for&nbsp;a&nbsp;&nbsp;10MHz&nbsp;CPU&nbsp;clock&nbsp;speed&nbsp;(SYSCLKOUT)<br />怎么和上面公式计算的不一样,我的实际晶振为30M,有一个例程的系统时钟不能过高,我设置倍频系数改为5,宏定义#define&nbsp;CPU_RATE&nbsp;&nbsp;&nbsp;20.000L,即选晶振为50M,程序运行正常,频率太高就不能正常运行,说明是有50M这个频率的,但是上面的公式计算中没有啊,难道计算有误?不知道还有其他地方需要设置吗?<br /><br />请高手指教,非常感谢!
mr.king 发表于 2008-8-15 18:58 | 显示全部楼层

1,上电有默认值,如果你需要测量外脉冲时间

参数,你必须知道自己的内部时钟,选高的分辨能测量更精细,但要兼顾长度不会测量过程溢出(溢出一次还是有标志可查的),低速时钟能测量更长时间.2/3没仔细了解,用DEMO工程中参数
keyuandan 发表于 2008-8-18 19:13 | 显示全部楼层

可以到www.haiii.com去进行及时交流

这个站点其实是让我们工程师都到上面注册,并填写自己的兴趣点(关键词),然后,再下载一个客户端,当别人问和自己的兴趣点相同的时候,就会发一个聊天请求,开始聊天,就像qq一样。<br /><br />你试着输入“fpga”,或者“视频”,或者“dsp”,或者“TI”等,找找看,总之,就是你输入问题的关键字,只要有人把这个关键字填写到自己的兴趣点关键字里面了,大家就能建立聊天了。呵呵,比bbs更快!
liulang34 发表于 2008-8-25 19:18 | 显示全部楼层

求助

我是个初学者,太多不明白,而且这里网络受限,好多网站打不开,我想请问下楼主,能不能发给我一些2812的例子,最好全点(包括完整头文件和工程中包含的.bjt,.asm,.cmd及.c)因为也找了些例程,发现不是找这个就是少那个,而且又不能合用。<br />我邮箱:sunue_zzy@163.com,这里先谢谢楼主好心了,希望大家共同进步
spiderman9 发表于 2008-9-22 23:19 | 显示全部楼层

RE

楼主要仔细多看看书啊:)<br />DSP外挂一个有缘或无缘的晶振,然后内部靠外部这个晶振做**,PLL倍频后分高速低速时钟,然后你用哪个DSP外设就开哪个时钟,没有时钟,外设不工作!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

25

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部

3

主题

25

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部