首先,printf重定义后可以直接使用printf函数从串口发送数据
在usart.c中添加代码:
#ifdef __GNUC__
/* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
set to 'Yes') calls __io_putchar() */
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
/**
* @brief Retargets the C library printf function to the USART.
* @param None
* @retval None
*/
PUTCHAR_PROTOTYPE
{
/* Place your implementation of fputc here */
/* e.g. write a character to the EVAL_COM1 and Loop until the end of transmission */
HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 0xFFFF);
return ch;
}
便可以在main中直接使用printf函数了
int main(void)
{
HAL_Init();
MX_GPIO_Init();
MX_USART1_UART_Init();
while (1)
{
printf("\n\r 我是杨海鑫\n\r");
HAL_Delay(1000);
}
}
关键字:STM32 USART 串口调节 printf重定义
引用地址:
STM32USART串口调节与printf重定义
推荐阅读最新更新时间:2024-03-16 16:22
STM32 双DAC DMA TIM6输出正弦波例子
STM32F103有双DAC通道,利用DMA实现2个波形输出 #include stm32f10x.h //DAC1,2初始化 void dac_init(void) { RCC- APB2ENR |= RCC_APB2ENR_IOPAEN; //开启端口A时钟 RCC- APB1ENR |= RCC_APB1ENR_DACEN; //开启DAC时钟 GPIOA- CRL &= 0xff00ffff; //PA4,PA5模拟输入 DAC- CR = DAC_CR_TEN1 | DAC_CR_TEN2; //开启触发使能才能设置触发模式 //开启DAC,关闭输出缓存,TI
[单片机]
STM32 RTC实时时钟(二)
上次实验完成了对实时时钟的基本功能——计时的实验,这次在计时的基础上对RTC的可编程闹钟的功能进行测试。 RTC 单元提供两个可编程闹钟,即闹钟 A 和闹钟 B。 可通过将 RTC_CR 寄存器中的 ALRAE 和 ALRBE 位置 1 来使能可编程闹钟功能。如果日历亚秒、秒、分钟、小时、日期或日分别与闹钟寄存器RTC_ALRMASSR/RTC_ALRMAR 和RTC_ALRMBSSR/RTC_ALRMBR 中编程的值相匹配,则 ALRAF 和 ALRBF 标志会被置为1。可通过 RTC_ALRMAR 和 RTC_ALRMBR 寄存器的 MSKx 位以及 RTC_ALRMASSR 和RTC_ALRMBSSR 寄
[单片机]
【STM32】STM32启动方式
在少量芯片程序下载时,用JLINK或SWD的下载方式比较繁琐,串口下载配合正点原子的FLYMCU比较快捷,STM32的串口下载时候需要注意MCU的启动方式。 在复位时,会按照boot的状态判断进入哪种模式,boot脚不用保持长状态。 在根据STM407参考手册来看,STM32拥有三种启动方式,分别为: 模式1:boot0拉低,使用用户闪存区,这是最正常启动的模式,即,在正常启动时,boot0应该下拉为低电平; 模式2:从系统存储器启动,在系统ROM区有固定的bootloader代码,用于ISP(串口)下载,引导外部代码到falsh,在重新复位后,置boot0为0即可以得到刚才的下载的代码。 模式3:从SRAM
[单片机]
STM32 使用TIM2_CH1(PA15) 输出10K PWM信号
PA15- TIM2 Remap CH1 1.apb_init() RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE); 2.gpio_init() #define PWM_GPIO_IDX 8 //PA15 #define PWM_GRP GPIOA #define PWM_PIN GPIO_Pin_15
[单片机]
STM32 ST-LINK Utility无法下载的处理方法
现象:提示family: Unknown device Read out protection is activated. Could not disable Read Out Protection! 分析:由于STM内部提供了数据保护,有读出保护和写保护。禁止读出保护起作用,那么下载器就读不出内容了。是为了防止盗版的功能。做产品应该使用。 解决办法:只能把写保护、读保护取消,并擦出整个芯片。 首先,连接板子与PC,进入Dos命令行,进入C:\Program Files\STMicroelectronics\STM32 ST-LINK Utility\ST-LINK Utility目录下,执行S
[单片机]
STM32 GPIO的8种工作模式及相关配置寄存器
GPIO八种工作模式 四种输入: GPIO_Mode_IPU(上拉输入) GPIO_Mode_IPD(下拉输入) 原理: 经过上拉开关和下拉开关的连接,再经过触发器转化为0,1的数字信号,存储到数据寄存器中,然后我们就可以通过配置寄存器CRL,CRH控制这两个开关。 用法: 若GPIO引脚配置为上拉输入模式,在默认状态下(GPIO引脚无输入),取得的GPIO引脚数据为1,既高电平. 而下拉输入模式则是相反的,在默认状态下其引脚数据为0,低电平. GPIO_Mode_IN_FLOATING(浮空输入) 原理: 不接上拉和下拉开关,直接经由触发器输入. 用法: 若配置成这个模式可以用电表测量其引脚电压是1点几伏(不确定的值).由于输
[单片机]
STM32 堆栈大小详解 以及变量存储位置
栈增长和大端/小端问题是和CPU相关的两个问题. 1,首先来看:栈(STACK)的问题. 函数的局部变量,都是存放在 栈 里面,栈的英文是:STACK.STACK的大小,我们可以在stm32的启动文件里面设置,以 战舰 stm32 开发板 为例,在startup_stm32f10x_hd.s里面,开头就有: Stack_Size EQU 0x00000800 表示栈大小是0X800,也就是2048字节.这样,CPU处理任务的时候,函数局部变量做多可占用的大小就是:2048字节,注意:是所有在处理的函数,包括函数嵌套,递归,等等,都是从这个 栈 里面,来分配的. 所以,如果一个函数的局部变量过多,比如在函数里面定义一个u8
[单片机]
基于STM32智能马蹄锁设计
1. 前言 设计一款基于单片机的家用马蹄锁,主要用在自行车、共享单车上。 主要要求: 1、手机蓝牙直连控制开关:手机直接连接智能马蹄锁可以控制其开锁关锁的功能。 2、即连即开: 手机端与智能马蹄锁第一次连接成功后可以选择即连即开模式,在之后距离智能马蹄锁一定范围内,智能马蹄锁会自动打开。 3、即走即关:手机端与智能马蹄锁第一次连接成功后可以选择即连即走即关,在之后离开智能马蹄锁一定范围,智能马蹄锁会自动关团。 4、实体触控按键控制开锁手动关锁。当用户无法使用蓝牙功能时,可以使用侧面实体触控按键进行密码解锁。 5、GPRS防盗预警当自行车在智能马蹄锁住的的情况下三轴加速度传感器检测到车辆被长时间移动时会向用户
[单片机]