OpenEdv-开源电子网

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

要使用usart1和usart3打印输出参考了例程,但是卡死了

[复制链接]

3

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2017-4-2
在线时间
28 小时
发表于 2018-1-31 22:42:03 | 显示全部楼层 |阅读模式
5金钱
void u3_printf(char* fmt,...)  
{  
u16 i,j;
va_list ap;
va_start(ap,fmt);
vsprintf((char*)USART3_TX_BUF,fmt,ap);
va_end(ap);
i=strlen((const char*)USART3_TX_BUF);  
for(j=0;j<i;j++)      
{
   while(USART_GetFlagStatus(USART3,USART_FLAG_TC)==RESET);
  USART_SendData(USART3,USART3_TX_BUF[j]);
}
}

debug后一直停在 vsprintf((char*)USART3_TX_BUF,fmt,ap);求问有人有遇到这个情况的吗?
一直在论坛找贴还有百度,不知道是什么原因

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-1 01:13:42 | 显示全部楼层
我们不是有类似的例子么?你直接拷贝过来用就可以了啊。这段代码,是和硬件无关的(最后循环发送部分除外)
回复

使用道具 举报

3

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2017-4-2
在线时间
28 小时
 楼主| 发表于 2018-2-1 12:11:05 | 显示全部楼层
正点原子 发表于 2018-2-1 01:13
我们不是有类似的例子么?你直接拷贝过来用就可以了啊。这段代码,是和硬件无关的(最后循环发送部分除外)

是直接拷贝了战舰例程,但是打印不了,debug后单步调试运行到vsprintf((char*)USART3_TX_BUF,fmt,ap)就不在往下运行。
回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2018-2-1 13:22:01 | 显示全部楼层
void USART3_printf (char *fmt, ...)
{
                u8 i = 0;
                va_list arg_ptr;
                va_start(arg_ptr, fmt);
                vsnprintf(USART3_TX_BUF, USART3_MAX_SEND_LEN+1, fmt, arg_ptr);
                va_end(arg_ptr);
                while ((i < USART3_MAX_SEND_LEN) && USART3_TX_BUF[i])
                {
                                USART_SendData(USART3, (u8) USART3_TX_BUF[i++]);
                                while (USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);
                }
}
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-2 02:05:15 | 显示全部楼层
子忧默声 发表于 2018-2-1 12:11
是直接拷贝了战舰例程,但是打印不了,debug后单步调试运行到vsprintf((char*)USART3_TX_BUF,fmt,ap)就不 ...

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

使用道具 举报

17

主题

587

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4467
金钱
4467
注册时间
2013-6-27
在线时间
565 小时
发表于 2018-2-2 08:54:39 | 显示全部楼层
有添加相关头文件
#include <string.h>
#include <stdio.h>
#include <stdarg.h>
让我们的思维驾驭在电的速度之上!
回复

使用道具 举报

3

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2017-4-2
在线时间
28 小时
 楼主| 发表于 2018-2-2 11:20:10 | 显示全部楼层
正点原子 发表于 2018-2-2 02:05
不应该啊,你的buf小了?
USART3_TX_BUF多大?

开了600,我开到1000都是这样
回复

使用道具 举报

3

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2017-4-2
在线时间
28 小时
 楼主| 发表于 2018-2-2 11:21:09 | 显示全部楼层
DongInker 发表于 2018-2-2 08:54
有添加相关头文件
#include
#include

战舰例程有,我都加了
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-3 01:26:15 | 显示全部楼层
子忧默声 发表于 2018-2-2 11:21
战舰例程有,我都加了

不应该啊,这个很简单的东西。。。
你是不是哪里搞错了?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-3 01:26:23 | 显示全部楼层
你先把我们例程跑起来,试试看。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 07:19

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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