OpenEdv-开源电子网

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

用printf函数遇到的问题

[复制链接]

21

主题

78

帖子

0

精华

初级会员

Rank: 2

积分
188
金钱
188
注册时间
2015-10-26
在线时间
32 小时
发表于 2016-3-23 20:23:20 | 显示全部楼层 |阅读模式
5金钱
    在调试是遇到printf函数是,程序直接卡死了,跳到了B处。有谁知道这是怎么回事吗?

A)U1H9A){J%F(S3EI%KNY1D.png
AL~7~)D87GN5E(CRC5%Q]@L.png
我本自由身,谁敢高高在上
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-3-23 21:44:56 | 显示全部楼层
你是不是串口没有初始化?
回复

使用道具 举报

1

主题

78

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
211
金钱
211
注册时间
2015-12-10
在线时间
49 小时
发表于 2016-3-23 22:05:45 | 显示全部楼层
俺也发现printf有些怪。UCOSII下,加上红外遥控输入后(我用TIM3的CH4,PB1),就不能输出浮点数了,也是程序跑飞,连sprintf也不行了,但整数和字串没问题。去掉红外就没问题了,真是见了鬼了。
逆水行舟不进则退
回复

使用道具 举报

4

主题

66

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
279
金钱
279
注册时间
2015-10-5
在线时间
27 小时
发表于 2016-3-24 13:07:05 | 显示全部楼层
使用printf是要进行重定向的,要加上这两段
/* Private function prototypes -----------------------------------------------*/
#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 USART */
  USART_SendData(USART2, (uint8_t) ch);

  /* Loop until the end of transmission */
  while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET)
  {}

  return ch;
}
上面的两个USART2要进行相应的修改就可以了
然后卡在B处有可能是你开了相应的中断而没有清中断的标志位,卡在中断服务函数里面了,再仔细查查是什么回事吧
回复

使用道具 举报

21

主题

78

帖子

0

精华

初级会员

Rank: 2

积分
188
金钱
188
注册时间
2015-10-26
在线时间
32 小时
 楼主| 发表于 2016-3-25 20:01:52 | 显示全部楼层
正点原子 发表于 2016-3-23 21:44
你是不是串口没有初始化?

初始化了,,,要使用printf不是在usart.c里加


//加入以下代码,支持printf函数,而不需要选择use MicroLIB          
#if 1
#pragma import(__use_no_semihosting)            
//标准库需要的支持函数                 
struct __FILE
{
        int handle;
        /* Whatever you require here. If the only file you are using is */
        /* standard output using printf() for debugging, no file handling */
        /* is required. */
};
/* FILE is typedef’ d in stdio.h. */
FILE __stdout;      
//定义_sys_exit()以避免使用半主机模式   
_sys_exit(int x)
{
        x = x;
}
//重定向fputc函数
//printf的输出,指向fputc,由fputc输出到串口
//这里使用串口1(USART1)输出printf信息
int fputc(int ch, FILE *f)
{      
        while((MYUSART3->SR&0X40) ==0) ;//等待上一次串口数据发送完成  
        MYUSART3->DR = (unsigned char) ch;              //写DR,串口1将发送数据
        return ch;
}
#endif

就行了吗??
我本自由身,谁敢高高在上
回复

使用道具 举报

21

主题

78

帖子

0

精华

初级会员

Rank: 2

积分
188
金钱
188
注册时间
2015-10-26
在线时间
32 小时
 楼主| 发表于 2016-3-25 20:03:33 | 显示全部楼层
461450651 发表于 2016-3-24 13:07
使用printf是要进行重定向的,要加上这两段
/* Private function prototypes ---------------------------- ...

我已经加了重定向了,中断我也只开了一个接受非空中断啊
我本自由身,谁敢高高在上
回复

使用道具 举报

4

主题

66

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
279
金钱
279
注册时间
2015-10-5
在线时间
27 小时
发表于 2016-3-27 10:34:44 | 显示全部楼层
小败 发表于 2016-3-25 20:03
我已经加了重定向了,中断我也只开了一个接受非空中断啊

//这里使用串口1(USART1)输出printf信息
int fputc(int ch, FILE *f)
{      
        while((MYUSART3->SR&0X40) ==0) ;//等待上一次串口数据发送完成  
        MYUSART3->DR = (unsigned char) ch;              //写DR,串口1将发送数据
        return ch;
}
看清楚咯,你下面的是USART3,你上面的文字说明是用USART1
回复

使用道具 举报

21

主题

78

帖子

0

精华

初级会员

Rank: 2

积分
188
金钱
188
注册时间
2015-10-26
在线时间
32 小时
 楼主| 发表于 2016-3-28 19:28:01 | 显示全部楼层
461450651 发表于 2016-3-27 10:34
//这里使用串口1(USART1)输出printf信息
int fputc(int ch, FILE *f)
{      

那是复制过来的,我用的就是USART3
我本自由身,谁敢高高在上
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

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

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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