datasheet

STM32 printf函数打印到串口

2018-06-10来源: eefocus 关键字:STM32  printf函数  打印到串口

学习STM32过程中,经常打交道的莫过于串口,你可以将任何信息,当然重要的是调试信息打印到串口中输出,总是用一个字节发送函数或者字符串发送函数总是有些不放便,之前编程中熟悉的莫过于printf了,下面就给出了用printf打印到串口的方案,当然方案不止一个,仅供参考。


1、 添加printf的头文件 #include


int fputc(int ch, FILE *f)

{

USART_SendData(USART1, (uint8_t) ch);


while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);

return ch;

}


3、修改一下选中Use MicroLIB ,在 Target/Code Generation选中Use MicroLIB 

这样就可以像以前那样使用printf了。 

不过现在的USART已经在程序中加了这个重定向; 

编译会出错:..\OBJ\164串口转并口.axf: Error: L6200E: Symbol fputc multiply defined (by usart.o and main.o)。


/************************************************

 刘凯教你学STM32F103

 第21讲

 软件仿真,库函数实现USART数据发送

 2016年4月24日 10:12:39

 程序实现3 printf实现

**************************************************/

#include "sys.h"

#include "delay.h"

#include "stdio.h"



void RCC_Configuration(void);

void GPIO_Configuration(void);

void USART_Configuration(u32 Baudrate);

int fputc(int ch, FILE *f)//重定向,让printf输出到串口

{

    USART_SendData(USART1,ch);


    while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);

    return ch;

}


int main(void)

{

    u8 i,data;



    RCC_Configuration();

    GPIO_Configuration();

    USART_Configuration(9600);

    data = 'A';

    for(i=0;i<30;i++)

    {

        USART_SendData(USART1, data);

        data++;

        while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);

    }

    printf("yuanbao");

}


void RCC_Configuration(void)

{

        /*---------------使用外部RC晶振----------*/

        RCC_DeInit();           //设置时钟为缺省值

        RCC_HSEConfig(RCC_HSE_ON);  //使能外部高速晶振

        while(RCC_GetFlagStatus(RCC_FLAG_HSERDY) == RESET);//等待HSE准备就绪


        FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);   //使能指令预取

        FLASH_SetLatency(FLASH_Latency_2);                      //等待2个周期


        RCC_HCLKConfig(RCC_SYSCLK_Div1);    //HCLK = SYSCLK

        RCC_PCLK2Config(RCC_HCLK_Div1);     //PCLK2 = HCLK

        RCC_PCLK1Config(RCC_HCLK_Div2);     //PCLK1 = HCLK/2

        RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9); //PLLCLK = 72MHZ

        RCC_PLLCmd(ENABLE);                                 //Enable PLLCLK

        while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); //Wait PLL is ready


       RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);         //SYSCLK = PLLCLK

       while(RCC_GetSYSCLKSource()!= 0x08);                   //Wait PLLCLK as system clock 



        //---------打开相应外设时钟--------------------

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);    //使能APB2外设的GPIOA的时钟 

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);    

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);     


void GPIO_Configuration(void)

{

    GPIO_InitTypeDef    GPIO_InitStructure;     //声明一个结构体变量

    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;   //

    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    //管脚频率为50MHZ

    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 


    GPIO_Init(GPIOA,&GPIO_InitStructure);                //初始化GPIOA寄存器


    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;  //选择

    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;    

    GPIO_Init(GPIOA,&GPIO_InitStructure);                //初始化GPIOA寄存器      


void USART_Configuration(u32 Baudrate)

{

    USART_InitTypeDef USART_InitStructure; 

    USART_InitStructure.USART_BaudRate = Baudrate;      

    USART_InitStructure.USART_WordLength = USART_WordLength_8b; 

    USART_InitStructure.USART_StopBits = USART_StopBits_1; 

    USART_InitStructure.USART_Parity = USART_Parity_No; 

    USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; 

    USART_InitStructure.USART_Mode = USART_Mode_Tx | USART_Mode_Rx; 

    USART_Init(USART1, &USART_InitStructure);


    USART_Cmd(USART1,ENABLE);

}


关键字:STM32  printf函数  打印到串口

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

上一篇:STM32 串口通信 printf方法
下一篇:基于STM32的虚拟多线程

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

推荐阅读

STM32双堆栈及其在uC/OS-II中的使用

,进入中断程序后就开始使用MSP,如果还有一个高优先级的中断难么就继续的使用MSP,在程序推出最后一级中断的时候就用用户堆栈恢复寄存器。下面以uCOS-II为例进行说明:首先建立一个堆栈  OS_STK   AppTaskStartStk[1024]  //32位STM32是向下生长的满栈,初始化堆栈后(在没有使用PSP以前,一直使用的是MSP)。                 |    
发表于 2018-12-03
STM32双堆栈及其在uC/OS-II中的使用

关于STM32中的assert_param()

在STM32的固件库和提供的例程中,到处都可以见到assert_param()的使用。如果打开任何一个例程中的stm32f10x_conf.h文件,就可以看到实际上assert_param是一个宏定义;在固件库中,它的作用就是检测传递给函数的参数是否是有效的参数。所谓有效的参数是指满足规定范围的参数,比如某个参数的取值范围只能是小于3的正整数,如果给出的参数大于3,则这个assert_param()可以在运行的程序调用到这个函数时报告错误,使程序员可以及时发现错误,而不必等到程序运行结果的错误而大费周折。这是一种常见的软件技术,可以在调试阶段帮助程序员快速地排除那些明显的错误。它确实在程序的运行上牺牲了效率(但只是在调试阶段
发表于 2018-12-03

stm32启动文件相关说明

说的直白点就是以下区别,在选择启动文件的时候有选择性区别!startup_stm32f10x_cl.s互联型的STM32F105xx,STM32F107xxstartup_stm32f10x_hd.s 大容量的STM32F101xx,STM32F102xx,STM32F103xxstartup_stm32f10x_hd_vl.s 大容量的STM32F100xxstartup_stm32f10x_ld.s 小容量的STM32F101xx,STM32F102xx,STM32F103xxstartup_stm32f10x_ld_vl.s 小容量
发表于 2018-12-03
stm32启动文件相关说明

STM32定时器相关介绍(主要是有UEV更新事件介绍)

单片机的定时器的确很强大,参考说明书中就占了一百多页,占参考手册1/4 有多了。STM32的定时器分了好几个类别,各个类别针对功能作用都不大相同。分有: 一、高级定时器       二、通用定时器       三、基本定时器       四、看门狗定时器       五、SysTick定时器      其中看门狗定时器和SysTick定时器本篇笔记阐述,这里主要记下对平时使用
发表于 2018-12-03

stm32时钟相关

我在原创的基础又从另一位博主处引用了一些内容。  时钟系统是处理器的核心,所以在学习STM32所有外设之前,认真学习时钟系统是必要的,有助于深入理解STM32。     下面是从网上找的一个STM32时钟框图,比《STM32中文参考手册》里面的是中途看起来清晰一些:         重要的时钟:   PLLCLK,SYSCLK,HCKL,PCLK1,PCLK2 之间的关系要弄清楚;       1、HSI:高速内部时钟信号
发表于 2018-12-03
stm32时钟相关

STM32之中断管理

关于STM32的中断,相信大家玩过单片机的朋友就知道,中断是MCU的一大优点,使MUC工作能够分清事情的”轻重缓急“ ,从而达到处理事情井井有条; 今天就讲解下STM32-Cortex-M3内核的中断管理机制,其他处理器的也类似;M3中F103系列的有60个可屏蔽的中断和16个内核级别的中断;     大家知道,操作一款MCU 其实实质就是操作的寄存器,而寄存器有机的结合起来就实现了特定的功能;中断系统也不例外,下面来认识一下中断系统中的几个重要的寄存器;    1. ISER[8](Interrupt Set-Enable Registers),就是中断使能寄存器组
发表于 2018-12-03

小广播

何立民专栏

单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2018 EEWORLD.com.cn, Inc. All rights reserved
pt type="text/javascript" src="//v3.jiathis.com/code/jia.js?uid=2113614" charset="utf-8">