MSP430F5438學習筆記 UART SMCLK 115200-8-N-1
MSP430中 UCBR0、UCBR1和UCBRF的設置值可以通過計算,也通過通過查表獲得。我個人傾向于查表法。具體可以參考以下兩張圖表。默認情況,ACLK為32768MHZ,而SMCLK為1048576。選擇ACLK時波特率最大為9600,大于9600的情況只能使用SMCLK,波特率的設置和SMCLK的時鐘頻率有關,我個人更傾向于設置SMCLK和MCLK為8MHz。
//時鐘默認情況
//FLL時鐘FLL選擇XT1
//輔助時鐘ACLK選擇XT132768Hz
//主系統(tǒng)時鐘MCLK選擇DCOCLKDIV8000000Hz
//子系統(tǒng)時鐘SMCLK選擇DCOCLKDIV8000000Hz
//UART時鐘選擇SMCLK
//低頻波特率產生115200-8-N-1
#include
#include
voidclock_config(void);
voidselect_xt1(void);
voiddco_config(void);
voiduart_config(void);
intmain(void)
{
clock_config();//初始化時鐘
uart_config();
_EINT();
P4DIR|=BIT0;//P4.0輸出
printf("HelloMSP430!rn");
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外設功能
UCSCTL6&=~(XT1OFF);//XT1打開
UCSCTL6|=XCAP_3;//內部電容
do
{
UCSCTL7&=~XT1LFOFFG;//清楚XT1錯誤標記
}while(UCSCTL7&XT1LFOFFG);//檢測XT1錯誤標記
}
voiddco_config(void)
{
__bis_SR_register(SCG0);//禁止FLL功能
UCSCTL0=0x0000;//SetlowestpossibleDCOx,MODx
UCSCTL1=DCORSEL_5;//DCO最大頻率為16MHz
UCSCTL2=FLLD_1+243;//設置DCO頻率為8MHz
//MCLK=SMCLK=Fdcoclkdiv=(N+1)X(Ffllrefclk/n)
//N為唯一需要計算的值
//FfllrefclkFLL參考時鐘,默認為XT1
//n取默認值,此時為1
//(243+1)*32768=8MHz
__bic_SR_register(SCG0);//使能FLL功能
//必要延時
__delay_cycles(250000);
//清楚錯誤標志位
do
{
UCSCTL7&=~(XT2OFFG+XT1LFOFFG+XT1HFOFFG+DCOFFG);
//清除所有振蕩器錯誤標志位
SFRIFG1&=~OFIFG;//清除振蕩器錯誤
}while(SFRIFG1&OFIFG);//等待清楚完成
}
voiduart_config(void)
{
P3SEL=0x30;//選擇P3.4和P3.5的復用功能
UCA0CTL1|=UCSWRST;//軟件復位
UCA0CTL1|=UCSSEL_2;//選擇SMCLK時鐘
UCA0BR0 = 69; //