MSP430F5438學(xué)習(xí)筆記 DCO倍頻至8MHZ
1.平臺說明 MS430F5438
//時鐘默認(rèn)情況
//FLL時鐘FLL選擇XT1
//輔助時鐘ACLK選擇XT132768Hz
//主系統(tǒng)時鐘MCLK選擇DCOCLKDIV1048576Hz
//子系統(tǒng)時鐘SMCLK選擇DCOCLKDIV1048576Hz
#include
voidclock_config(void);
voidselect_xt1(void);
voiddco_config(void);
intmain(void)
{
clock_config();//初始化時鐘
P4DIR|=BIT0;//P4.0輸出
while(1)
{
P4OUT^=BIT0;
__delay_cycles(1000000);
}
}
voidclock_config(void)
{
WDTCTL=WDTPW+WDTHOLD;//停止看門狗
select_xt1();//選擇XT1
dco_config();//ACLK=XT1=32.768K
//MCLK=SMCLK=8000K
}
voidselect_xt1(void)
{
//啟動XT1
P7SEL|=0x03;//P7.0P7.1外設(shè)功能
UCSCTL6&=~(XT1OFF);//XT1打開
UCSCTL6|=XCAP_3;//內(nèi)部電容
do
{
UCSCTL7&=~XT1LFOFFG;//清楚XT1錯誤標(biāo)記
}while(UCSCTL7&XT1LFOFFG);//檢測XT1錯誤標(biāo)記
}
voiddco_config(void)
{
__bis_SR_register(SCG0);//禁止FLL功能
UCSCTL0=0x0000;//SetlowestpossibleDCOx,MODx
UCSCTL1=DCORSEL_5;//DCO最大頻率為16MHz
UCSCTL2=FLLD_1+243;//設(shè)置DCO頻率為8MHz
//MCLK=SMCLK=Fdcoclkdiv=(N+1)X(Ffllrefclk/n)
//N為唯一需要計算的值
//FfllrefclkFLL參考時鐘,默認(rèn)為XT1
//n取默認(rèn)值,此時為1
//(243+1)*32768=8MHz
__bic_SR_register(SCG0);//使能FLL功能
//必要延時
__delay_cycles(250000);
//清楚錯誤標(biāo)志位
do
{
UCSCTL7&=~(XT2OFFG+XT1LFOFFG+XT1HFOFFG+DCOFFG);
//清除所有振蕩器錯誤標(biāo)志位
SFRIFG1&=~OFIFG;//清除振蕩器錯誤
}while(SFRIFG1&OFIFG);//等待清楚完成
}