OpenEdv-开源电子网

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

驱动printk和用户程序printf一起打印的混乱现象

[复制链接]

21

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2016-6-8
在线时间
79 小时
发表于 2021-3-20 02:31:27 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 我叫做大熙熙 于 2021-3-20 02:36 编辑

偶然发现的,驱动程序中用printk打印,应用程序中加了printf打印,应用程序在调用驱动程序时,应用程序的打印没有在终端显示。举个例子:
  1. 应用程序:
  2. int main(int argc, char *argv[])
  3. {
  4.         int fd = open(fileName, O_RDWR);
  5.         int ret = read(fd, readBuf, 50);
  6.         if(ret < 0)
  7.         {
  8.                 printf("[APP]:file '%s' read failed", fileName);
  9.         }
  10.         else
  11.         {
  12.                 printf("[APP]:read data:%s\r\n", readBuf);
  13.         }
  14.         return 0;
  15. }
复制代码
  1. 驱动程序
  2. static int chrdevbase_open(struct inode *inode, struct file *filp)
  3. {
  4.      printk("[KER]: chrdevbase open!\r\n");
  5.      return 0;
  6. }

  7. static ssize_t chrdevbase_read(struct file *filp, char __user *buf, size_t cnt, loff_t *offt)
  8. {
  9.     int retvalue = 0;
  10.         
  11.     /* 向用户空间发送数据 */
  12.     memcpy(readbuf, kerneldata, sizeof(kerneldata));
  13.     retvalue = copy_to_user(buf, readbuf, cnt);
  14.     if(retvalue == 0){
  15.         printk("[KER]: ok\r\n");
  16.     }else{
  17.         printk("[KER]: failed\r\n");
  18.     }
  19.    return 0;
  20. }
复制代码
最后应用程序尝试去读的时候,发现打印是
[KER]: chrdevbase open!
[KER]: ok
然后就没了,应用程序的打印没打出来,去掉驱动printk的打印的话,应用程序printf的打印是正常的。网上查询的在printf后面加fflush(stdout)这句是刷新缓存区实测没用。
所以想问一下,内核和应用程序都想正常打印的话要怎么做呢?

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2021-3-21 01:33:34 | 显示全部楼层
回复

使用道具 举报

33

主题

1628

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
6549
金钱
6549
注册时间
2015-8-25
在线时间
1024 小时
发表于 2021-3-22 14:08:30 | 显示全部楼层
printf中加\r\n
He who fights with monsters should look to it that he himself does not become a monster, when you gaze long into the abyss, the abyss also gazes into you.
过于执着就会陷入其中,迷失自己,困住自己。
回复

使用道具 举报

21

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2016-6-8
在线时间
79 小时
 楼主| 发表于 2021-3-22 14:34:38 | 显示全部楼层

试过了的,就有时候应用层的打印还是会被丢掉,我现在调试的话就是尽量都在一边打印。
回复

使用道具 举报

15

主题

184

帖子

0

精华

高级会员

Rank: 4

积分
647
金钱
647
注册时间
2014-4-29
在线时间
299 小时
发表于 2021-3-23 09:43:21 | 显示全部楼层
可以用setbuf或者setvbuf函数把stdout输出设置成无缓冲模式
回复

使用道具 举报

21

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2016-6-8
在线时间
79 小时
 楼主| 发表于 2021-3-23 20:26:23 | 显示全部楼层
xianshasaman 发表于 2021-3-23 09:43
可以用setbuf或者setvbuf函数把stdout输出设置成无缓冲模式

之前也试过了,没有用...
回复

使用道具 举报

1

主题

40

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
449
金钱
449
注册时间
2013-5-22
在线时间
80 小时
发表于 2021-6-21 15:31:37 | 显示全部楼层
你好,请问这个问题解决了吗,我这边调试也发现这个问题,应用程序的printf会被内核的printk覆盖
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-24 12:00

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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