單片機(jī)使用printf函數(shù)進(jìn)行串口打印輸出
由說(shuō)明文件可以看出,我們可以改寫這個(gè)底層的putchar函數(shù)來(lái)適應(yīng)不同的硬件。keil里面的putchar函數(shù)是默認(rèn)用串行口輸出信息的,我們可以自由定義成另外的輸出模塊,比如自定義IO向1602液晶輸出信息。
keil的printf函數(shù)大致搞明白了,回頭再研究下IAR for MSP430,可惜,我沒有能夠查看該軟件標(biāo)準(zhǔn)函數(shù)庫(kù)里的printf.c 和 putchar.c,不過(guò)我覺得程序沒有通過(guò)串口向電腦打印輸出信息,是因?yàn)榈讓拥膒utchar函數(shù)沒有定義為通過(guò)MSP430G2553的UART進(jìn)行輸出,那如果我自己重定向一個(gè)putchar函數(shù),覆蓋掉標(biāo)準(zhǔn)函數(shù)庫(kù)里面的putchar,是不是就能夠輸出了呢。于是編寫putchar函數(shù)如下:
int putchar(int c)
{
if(c == )
{
while(UCA0STAT & UCBUSY);
UCA0TXBUF = ;
}
while(UCA0STAT & UCBUSY);
UCA0TXBUF = c;
return c;
}
編譯后,輸出完全正確。大功告成。
將測(cè)試程序向大家展示一下,希望能幫到大家。
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
uart.c
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#include
void UartInit()
{
BCSCTL1 = CALBC1_1MHZ; // Set DCO
DCOCTL = CALDCO_1MHZ;
BCSCTL2 &= ~(DIVS_3);
P1SEL = BIT1 + BIT2 ; // P1.1 = RXD, P1.2=TXD
P1SEL2 = BIT1 + BIT2; // P1.1 = RXD, P1.2=TXD
UCA0CTL1
= UCSSEL_2; // SMCLK
UCA0BR0 = 104; // 1MHz 9600
UCA0BR1 = 0; // 1MHz 9600
UCA0MCTL = UCBRS0; // Modulation UCBRSx = 1
UCA0CTL1 &= ~UCSWRST; // **Initialize USCI state machine**
UC0IE
= UCA0RXIE; // Enable RX int
}
int putchar(int c)
{
if(c == )
{
while(UCA0STAT & UCBUSY);
UCA0TXBUF = ;
}
while(UCA0STAT & UCBUSY);
UCA0TXBUF = c;
return c;
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
main.c
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#include
#include "uart.h"
#include "stdio.h"
void main()
{
float value = 123.123456789;
char *string="http://www.hao123.com";
WDTCTL = WDTPW + WDTHOLD;
UartInit();
printf("value = %f%s",value,string);
while(1);
}
評(píng)論