曾经在运用keil编写51单片机程序的时分,常常运用printf函数打印输出一些要害的进程数据到电脑,便利监控程序的运行状况。最近运用IAR for MSP430 调试MSP430G2553程序的时分,发现了一些小问题,MSP430G2553单片机并没有依照我的预期输出数据到电脑。
带着疑问我检查了keil的帮助文件里边的printf函数阐明,本来printf函数最终是调用putchar函数来完成打印输出字符的。

putchar,该函数将拟定的表达式的值所对应的字符输出到规范输出终端上。表达式可所以字符型或整型,它每次只能输出一个字符。咱们来看keil规范函数库里的putchar函数的函数体。
依据阐明提示,我在D:\Keil\C51\LIB文件夹里边找到了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 = %f\n%s\n”,value,string);
while(1);
}
信息打印输出到电脑的超级终端,截图如下:
