智能车制作
标题:
pll
[打印本页]
作者:
wxl900306
时间:
2012-4-3 20:59
标题:
pll
SYNR=0x00 | 0x01; // VCOFRQ[7:6];SYNDIV[5:0]
void SetBusCLK_16M(void)
{
CLKSEL=0X00; // disengage PLL to system
PLLCTL_PLLON=1; // turn on PLL
SYNR=0x00 | 0x01; // VCOFRQ[7:6];SYNDIV[5:0]
// fVCO= 2*fOSC*(SYNDIV + 1)/(REFDIV + 1)
// fPLL= fVCO/(2 × POSTDIV)
// fBUS= fPLL/2
// VCOCLK Frequency Ranges VCOFRQ[7:6]
// 32MHz <= fVCO <= 48MHz 00
// 48MHz < fVCO <= 80MHz 01
// Reserved 10
// 80MHz < fVCO <= 120MHz 11
REFDV=0x80 | 0x01; // REFFRQ[7:6];REFDIV[5:0]
// fREF=fOSC/(REFDIV + 1)
// REFCLK Frequency Ranges REFFRQ[7:6]
// 1MHz <= fREF <= 2MHz 00
// 2MHz < fREF <= 6MHz 01
// 6MHz < fREF <= 12MHz 10
// fREF > 12MHz 11
// pllclock=2*osc*(1+SYNR)/(1+REFDV)=32MHz;
POSTDIV=0x00; // 4:0, fPLL= fVCO/(2xPOSTDIV)
// If POSTDIV = $00 then fPLL is identical to fVCO (divide by one).
_asm(nop); // BUS CLOCK=16M
_asm(nop);
while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;
CLKSEL_PLLSEL =1; //engage PLL to system;
}
谁能告诉我SYNR=0X00|0X01是什么意思吗?主要也就是后面注释里的意思 // VCOFRQ[7:6];SYNDIV[5:0]
为什么是7:6和5:0
新手求指教
作者:
醉清风
时间:
2012-4-3 21:32
SYNR(CRG时钟合成寄存器):确定PLL的 倍频因子 并选择VCO频率范围。
作者:
wxl900306
时间:
2012-4-3 21:38
大哥 这些我都知道啊,我不理解的是这句话VCOFRQ[7:6];SYNDIV[5:0]
作者:
醉清风
时间:
2012-4-4 08:16
--
欢迎光临 智能车制作 (http://111.231.132.190/)
Powered by Discuz! X3.2