Keil C51重定向printf到串口

2018-06-10 11:20:34编辑:什么鱼 关键字:Keil  C51  重定向  printf  串口

概述

进行C/C++开发的时候我们都会需要打印调试信息,打印调试信息时我们习惯使用printf函数,但是在Keil C51环境下,由于我们的程序是下载到单片机里,使用printf函数时不能直接打印到串口上,这个时候就需要我们对printf函数输出重定向

重定向

重定向printf很简单,我们知道,printf函数是调用putchar实现字符数据传送的。我们只要重写putchar函数,就可以对printf进输出重定向。

代码清单

下面是自己在Keil 5环境下,使用单片机STC12测试printf重定向功能的代码清单

#include

#include


//UART1 初始化

void Uart1Init(void)    //115200bps@11.0592MHz

{

    PCON &= 0x7F;       //波特率不倍速

    SCON    = 0x50;     //8位数据,可变波特率

    AUXR |= 0x04;       //1T模式

    BRT     = 0xFD;     //设置独立波特率发生器重装值

    AUXR |=0X01;        //串口1选择独立发生器为波特率发生器

    AUXR |=0X10;        //启动独立波特率发生器

    ES = 1;                 //使能串口1中断

}


//UART1 发送串口数据

void UART1_SendData(char dat)

{

    ES=0;           //关串口中断

    SBUF=dat;           

    while(TI!=1);   //等待发送成功

    TI=0;           //清除发送中断标志

    ES=1;           //开串口中断

}


//UART1 发送字符串

void UART1_SendString(char *s)

{

    while(*s)//检测字符串结束符

    {

        UART1_SendData(*s++);//发送当前字符

    }

}


//重写putchar函数

char putchar(char c)

{

    UART1_SendData(c);

    return c;

}


void main(void)

{

    Uart1Init();

    UART1_SendString("Hello World!\r\n");

    printf("printf Test!\r\n");

    printf("Complie Time:%s\r\n", __TIME__);


    while(1)

    {

    }

}

打开串口把波特率调成115200bps,可以看到串口打印如下信息:

Hello World! 

printf Test! 

Complie Time:11:12:36

关键字:Keil  C51  重定向  printf  串口

来源: eefocus 引用地址:http://www.eeworld.com.cn/mcu/article_2018061039730.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:51单片机串口通信 采用中断方式
下一篇:51单片机定时器中断函数中变量初始化的问题

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

keil环境下stm32f030R8环境配置

的映射。     存取区一般不需要设置,除非用于IAP或APP需要调整区域空间;3、生成hex文件,即烧录文件。是在keil中编写程序并编译连接成可以下载到开发板的  .hex 文件,然后用jlink仿真器下载;2,是在uboot APP中编写编译代码,生成的是 .bin 文件,可以用uboot 下载。4、用于生成bin文件,如果不需要则可以略过这一步。C:\Keil_v5\ARM\ARMCC\bin\fromelf.exe  --bin -o  E:\bootloader_030test\OBJ\bootloader_030.bin E
发表于 2018-07-11 20:27:28

keil环境下stm32f030程序运行的说明

我们先来看看STM32 正常的程序运行流程:STM32 的内部闪存(FLASH)地址起始于0x08000000,一般情况下,程序文件就从此地址开始写入。此外STM32 是基于Cortex-M3 内核的微控制器,其内部通过一张“中断向量表”来响应中断,程序启动后,将首先从“中断向量表”取出复位中断向量执行复位中断程序完成启动,而这张“中断向量表”的起始地址是0x08000004,当中断来临,STM32 的内部硬件机制亦会自动将PC 指针定位到“中断向量表”处,并根据中断源取出对应的中断向量执行中断服务程序。环境配置:map文件中断向量表:SRAM堆栈分配:程序占用空间:FLASH所占用空间:Code +RO +RW = 1.41K;
发表于 2018-07-11 20:21:48

keil环境下stm32f030R8 APP程序中断向量的重映射

1、理论基础:        Stm32f030R8 有64KFlash + 8KSram      Stm32f0系列MCU中断矢量表的定位跟STM32其它系列相比有点差异,即M0系列没有像其它M3/M4/M0+系列所具备的中断矢量表重定位寄存器,其中断矢量表不能借助矢量重定位寄存器简单修改实现。所以Stm32f0 IAP的过程会跟其它系列的STM32芯片的IAP动作有所不同。我们知道,做IAP往往需要两部分代码,一部分是用来升级的IAP程序,一部分用来运行用户实际应用功能的应用程序APP代码。IAP程序及自身的中断向量表放在内部FLASH的
发表于 2018-07-10 21:57:40

STM32f030 boot iap升级时keil配置注意事项

最近使用了一款Cortex-M0内核的芯片STM32F030CC,发现它中断向量表的重映射方法与STM32F10x系列的有所区别,在这里记录与分享一下。由于需要通过IAP进行固件升级,所以芯片的FLASH里面要烧录两份代码:一个Boot loader, 一个用户应用程序。理所当然的,在用户应用程序中,必须得重新映射中断向量表。可是在ST提供的固件库里,我却没有发现类似于stm32f10x固件库中的voidNVIC_SetVectorTable(uint32_t NVIC_VectTab, uint32_t Offset)接口。     浏览了一下Cortex-M0的Programmingman
发表于 2018-07-10 21:33:26
STM32f030 boot iap升级时keil配置注意事项

keil C51使用串口时程序跑死的问题

在使用STC51单片机的串口时,有时候会进入一种很奇怪的情况,就是程序进入了一下子跑死了,初始化代码如下:void UsartConfiguration(unsigned int bps){ SCON = 0X50; //设置为工作方式1 10位异步收发器 TL2 = RCAP2L = bps; //set auto reload value TH2 = RCAP2H = bps>>8; T2CON = 0x34;//0011 0100  timer2 sart run ES = 1;//打开串口中断,注意打开开一定要写串口中断函数 EA = 1;//打开总中断}经过程序模拟DEBUG可以发现程序跑死在发送
发表于 2018-07-06 23:56:17

STM32 PWM的输出与Keil软件仿真

 Main函数int main(){        RCC_Config();        GPIO_Config();        TIM_Config();        while(1)        {                ;        }}接下来,我们讲解一下,在Keil里面看我
发表于 2018-06-29 21:09:23

小广播

何立民专栏

单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2018 EEWORLD.com.cn, Inc. All rights reserved