新闻中心

EEPW首页>嵌入式系统>设计应用> MSP430G2553单片机使用printf函数进行串口打印输出

MSP430G2553单片机使用printf函数进行串口打印输出

作者: 时间:2016-11-13 来源:网络 收藏
以前在使用keil编写51单片机程序的时候,经常使用printf函数打印输出一些关键的过程数据到电脑,方便监控程序的运行状况。最近使用IAR forMSP430调试MSP430G2553程序的时候,发现了一些小问题,MSP430G2553单片机并没有按照我的预期输出数据到电脑。
带着疑惑我查看了keil的帮助文件里面的printf函数说明,原来printf函数最终是调用putchar函数来实现打印输出字符的。
putchar,该函数将制定的表达式的值所对应的字符输出到标准输出终端上。表达式可以是字符型或整型,它每次只能输出一个字符。我们来看keil标准函数库里的putchar函数的函数体。
根据说明提示,我在D:KeilC51LIB文件夹里面找到了putchar.c文件
#include
#define XON 0x11
#define XOFF 0x13
/*
* putchar (full version): expands n into CR LF and handles
* XON/XOFF (Ctrl+S/Ctrl+Q) protocol
*/
char putchar (char c) {
if (c == n) {
if (RI) {
if (SBUF == XOFF) {
do {
RI = 0;
while (!RI);
}
while (SBUF != XON);
RI = 0;
}
}
while (!TI);
TI = 0;
SBUF = 0x0d; /* output CR */
}
if (RI) {
if (SBUF == XOFF) {
do {
RI = 0;
while (!RI);
}
while (SBUF != XON);
RI = 0;
}
}
while (!TI);
TI = 0;
return (SBUF = c);
}
#if 0 // comment out versions below
/*
* putchar (basic version): expands n into CR LF
*/
char putchar (char c) {
if (c == n) {
while (!TI);
TI = 0;
SBUF = 0x0d; /* output CR */
}
while (!TI);
TI = 0;
return (SBUF = c);
}
/*
* putchar (mini version): outputs charcter only
*/
char putchar (char c) {
while (!TI);
TI = 0;
return (SBUF = c);
}
#endif
由说明文件可以看出,我们可以改写这个底层的putchar函数来适应不同的硬件。keil里面的putchar函数是默认用串行口输出信息的,我们可以自由定义成另外的输出模块,比如自定义IO向 1602液晶输出信息。
keil的printf函数大致搞明白了,回头再研究下IAR for MSP430,可惜,我没有能够查看该软件标准函数库里的printf.c 和 putchar.c,不过我觉得程序没有通过串口向电脑打印输出信息,是因为底层的putchar函数没有定义为通过MSP430G2553的UART进行输出,那如果我自己重定向一个putchar函数,覆盖掉标准函数库里面的putchar,是不是就能够输出了呢。于是编写putchar函数如下:
/*********************************************************************
* 函数名 : putchar,函数重定向,自动覆盖标准库函数
* 函数功能 : 向串口终端发送一个字符
* 形参 : c为待发送的字符
* 返回值 : c
*********************************************************************/
int putchar(int c)
{
if(c == n)
{
while(UCA0STAT & UCBUSY);
UCA0TXBUF = r;
}
while(UCA0STAT & UCBUSY);
UCA0TXBUF = c;
return c;
}
编译后,输出完全正确。大功告成。
将测试程序向大家展示一下,希望能帮到大家。
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
uart.c
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#include < msp430g2553.h>
/**********************************************************************
* 函数名 : UartInit
* 函数功能 : 初始化msp430g2553的USCI寄存器,使其工作在UART模式
* 形参 : 无
* 返回值 : 无
* ********************************************************************/
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
}
/*********************************************************************
* 函数名 : putchar,函数重定向,自动覆盖标准库函数
* 函数功能 : 向串口终端发送一个字符
* 形参 : c为待发送的字符
* 返回值 : c
*********************************************************************/
int putchar(int c)
{
if(c == n)
{
while(UCA0STAT & UCBUSY);
UCA0TXBUF = r;
}
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 = %fn%sn",value,string);
while(1);
}
信息打印输出到电脑的超级终端,截图如下:



评论


技术专区

关闭