OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3742|回复: 7

精英版 串口2 printf()打印 问题

[复制链接]

17

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
132
金钱
132
注册时间
2016-6-1
在线时间
33 小时
发表于 2017-3-23 22:19:19 | 显示全部楼层 |阅读模式
5金钱
我用精英版  按照串口1来配置的串口2函数,RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); 这句也改成了  RCC_APB1PeriphClockCmd(RCC_APB2Periph_USART2, ENABLE);



int fputc(int ch, FILE *f)
{      
        while((USART2->SR&0X40)==0);//Ñ-»··¢Ëí,Ö±μ½·¢Ëííê±Ï   
    USART2->DR = (u8) ch;      
        return ch;
}


这里也按照原子视屏上改成了2,但用不了printf()打印到串口上,求解????

要是能分享例程那更是万分感谢

最佳答案

查看完整内容[请看2#楼]

Mini板的GSM/蓝牙例程,就是串口2的,另外,多用心。少浪问。 参考代码: [mw_shl_code=c,true]#include "delay.h" #include "usart2.h" #include "stdarg.h" #include "stdio.h" #include "string.h" ////////////////////////////////////////////////////////////////////////////////// //本程序只供学习使用,未经作者许可,不得用于其它任何用途 //ALIENTEK STM32开发板 //串口2驱动代码 //正点原子@ALIENTE ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-3-23 22:19:20 | 显示全部楼层
Mini板的GSM/蓝牙例程,就是串口2的,另外,多用心。少浪问。
参考代码:
[mw_shl_code=c,true]#include "delay.h"
#include "usart2.h"
#include "stdarg.h"       
#include "stdio.h"       
#include "string.h"       
//////////////////////////////////////////////////////////////////////////////////       
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//ALIENTEK STM32开发板
//串口2驱动代码       
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2014/3/29
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 广州市星翼电子科技有限公司 2009-2019
//All rights reserved       
//////////////////////////////////////////////////////////////////////////////////

//串口发送缓存区
__align(8) u8 USART2_TX_BUF[USART2_MAX_SEND_LEN]; //发送缓冲,最大USART2_MAX_SEND_LEN字节
#ifdef USART2_RX_EN //如果使能了接收
//串口接收缓存区
u8 USART2_RX_BUF[USART2_MAX_RECV_LEN]; //接收缓冲,最大USART2_MAX_RECV_LEN个字节.


//通过判断接收连续2个字符之间的时间差不大于10ms来决定是不是一次连续的数据.
//如果2个字符接收间隔超过10ms,则认为不是1次连续数据.也就是超过10ms没有接收到
//任何数据,则表示此次接收完毕.
//接收到的数据状态
//[15]:0,没有接收到数据;1,接收到了一批数据.
//[14:0]:接收到的数据长度
u16 USART2_RX_STA=0;
void USART2_IRQHandler(void)
{
u8 res;       
if(USART2->SR&(1<<5))//接收到数据
{       
res=USART2->DR;
if(USART2_RX_STA<USART2_MAX_RECV_LEN)        //还可以接收数据
{
TIM4->CNT=0; //计数器清空
if(USART2_RX_STA==0)TIM4_Set(1);        //使能定时器4的中断
USART2_RX_BUF[USART2_RX_STA++]=res;        //记录接收到的值       
}else
{
USART2_RX_STA|=1<<15;        //强制标记接收完成
}
}
}
//初始化IO 串口2
//pclk1CLK1时钟频率(Mhz)
//bound:波特率       
void USART2_Init(u32 pclk1,u32 bound)
{
RCC->APB2ENR|=1<<2; //使能PORTA口时钟
GPIOA->CRL&=0XFFFF00FF;        //IO状态设置
GPIOA->CRL|=0X00008B00;        //IO状态设置       
RCC->APB1ENR|=1<<17; //使能串口时钟
RCC->APB1RSTR|=1<<17; //复位串口2
RCC->APB1RSTR&=~(1<<17);//停止复位       
//波特率设置
USART2->BRR=(pclk1*1000000)/(bound);// 波特率设置       
USART2->CR1|=0X200C; //1位停止,无校验位.
USART2->CR3=1<<7; //使能串口2的DMA发送
UART_DMA_Config(DMA1_Channel7,(u32)&USART2->DR,(u32)USART2_TX_BUF);//DMA1通道7,外设为串口2,存储器为USART2_TX_BUF
#ifdef USART2_RX_EN        //如果使能了接收
//使能接收中断
USART2->CR1|=1<<8; //PE中断使能
USART2->CR1|=1<<5; //接收缓冲区非空中断使能       
MY_NVIC_Init(2,3,USART2_IRQn,2);//组2,最低优先级
TIM4_Init(99,7199);        //10ms中断
USART2_RX_STA=0;        //清零
TIM4_Set(0);        //关闭定时器4
#endif       
}
//串口2,printf 函数
//确保一次发送数据不超过USART2_MAX_SEND_LEN字节
void u2_printf(char* fmt,...)
{
va_list ap;
va_start(ap,fmt);
vsprintf((char*)USART2_TX_BUF,fmt,ap);
va_end(ap);
while(DMA1_Channel7->CNDTR!=0);        //等待通道7传输完成
UART_DMA_Enable(DMA1_Channel7,strlen((const char*)USART2_TX_BUF)); //通过dma发送出去
}
//定时器4中断服务程序       
void TIM4_IRQHandler(void)
{
if(TIM4->SR&0X01)//是更新中断
{       
USART2_RX_STA|=1<<15;        //标记接收完成
TIM4->SR&=~(1<<0);        //清除中断标志位       
TIM4_Set(0);        //关闭TIM4
}       
}
//设置TIM4的开关
//sta:0,关闭;1,开启;
void TIM4_Set(u8 sta)
{
if(sta)
{
TIM4->CNT=0; //计数器清空
TIM4->CR1|=1<<0; //使能定时器4
}else TIM4->CR1&=~(1<<0);//关闭定时器4       
}
//通用定时器中断初始化
//这里始终选择为APB1的2倍,而APB1为36M
//arr:自动重装值。
//psc:时钟预分频数       
void TIM4_Init(u16 arr,u16 psc)
{
RCC->APB1ENR|=1<<2;        //TIM4时钟使能
TIM4->ARR=arr; //设定计数器自动重装值
TIM4->SC=psc; //预分频器
TIM4->DIER|=1<<0; //允许更新中断       
TIM4->CR1|=0x01; //使能定时器4       
MY_NVIC_Init(1,3,TIM4_IRQn,2);//抢占2,子优先级3,组2        在2中优先级最低       
}
#endif       
///////////////////////////////////////USART2 DMA发送配置部分//////////////////////////////////       
//DMA1的各通道配置
//这里的传输形式是固定的,这点要根据不同的情况来修改
//从存储器->外设模式/8位数据宽度/存储器增量模式
//DMA_CHxMA通道CHx
//cpar:外设地址
//cmar:存储器地址
void UART_DMA_Config(DMA_Channel_TypeDef*DMA_CHx,u32 cpar,u32 cmar)
{
RCC->AHBENR|=1<<0;        //开启DMA1时钟
delay_us(5);
DMA_CHx->CPAR=cpar; //DMA1 外设地址
DMA_CHx->CMAR=cmar; //DMA1,存储器地址       
DMA_CHx->CCR=0X00000000;        //复位
DMA_CHx->CCR|=1<<4; //从存储器读
DMA_CHx->CCR|=0<<5; //普通模式
DMA_CHx->CCR|=0<<6; //外设地址非增量模式
DMA_CHx->CCR|=1<<7; //存储器增量模式
DMA_CHx->CCR|=0<<8; //外设数据宽度为8位
DMA_CHx->CCR|=0<<10; //存储器数据宽度8位
DMA_CHx->CCR|=1<<12; //中等优先级
DMA_CHx->CCR|=0<<14; //非存储器到存储器模式       
}
//开启一次DMA传输
void UART_DMA_Enable(DMA_Channel_TypeDef*DMA_CHx,u16 len)
{
DMA_CHx->CCR&=~(1<<0); //关闭DMA传输
DMA_CHx->CNDTR=len; //DMA1,传输数据量
DMA_CHx->CCR|=1<<0; //开启DMA传输
}       
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////




















[/mw_shl_code]

我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

3

主题

261

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2075
金钱
2075
注册时间
2014-2-20
在线时间
284 小时
发表于 2017-3-24 08:53:54 | 显示全部楼层
串口2对应的引脚有没有改?
回复

使用道具 举报

17

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
132
金钱
132
注册时间
2016-6-1
在线时间
33 小时
 楼主| 发表于 2017-3-24 09:49:37 | 显示全部楼层
Da Wen 发表于 2017-3-24 08:53
串口2对应的引脚有没有改?

改了,用的是PA2 PA3,推挽和浮空
回复

使用道具 举报

6

主题

24

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
250
金钱
250
注册时间
2017-2-20
在线时间
65 小时
发表于 2017-3-24 09:58:02 | 显示全部楼层
刚好最近在用串口调试,也用到了串口2作为printf输出,我把我改动过的usart.c和usart.h的程序附上,基于STM32F407。测试过可用。我觉得楼主打印失败的原因可能是因为有部分函数没有改全,也可以再检查一遍试试。



usart.zip

3.37 KB, 下载次数: 167

回复

使用道具 举报

3

主题

261

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2075
金钱
2075
注册时间
2014-2-20
在线时间
284 小时
发表于 2017-3-24 11:51:25 | 显示全部楼层
龙战云野 发表于 2017-3-24 09:49
改了,用的是PA2 PA3,推挽和浮空

那得看你的程序了
回复

使用道具 举报

17

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
132
金钱
132
注册时间
2016-6-1
在线时间
33 小时
 楼主| 发表于 2017-3-27 13:47:23 | 显示全部楼层
殇湮hml 发表于 2017-3-24 09:58
刚好最近在用串口调试,也用到了串口2作为printf输出,我把我改动过的usart.c和usart.h的程序附上,基于STM ...

嗯嗯,后面改好
回复

使用道具 举报

17

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
132
金钱
132
注册时间
2016-6-1
在线时间
33 小时
 楼主| 发表于 2017-3-27 13:47:42 | 显示全部楼层
正点原子 发表于 2017-3-23 22:19
Mini板的GSM/蓝牙例程,就是串口2的,另外,多用心。少浪问。
参考代码:
[mw_shl_code=c,true]#include  ...

嗯嗯,谢了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-8-22 22:08

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表