OpenEdv-开源电子网

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

rmmod命令卸载模块不打印字符串,再次insmod装载才显示刚才卸载时出现的字符串

[复制链接]

5

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
101
金钱
101
注册时间
2020-11-5
在线时间
20 小时
发表于 2021-10-12 19:27:30 | 显示全部楼层 |阅读模式
10金钱
本帖最后由 张要飞 于 2021-10-12 19:35 编辑

insmod正常打印信息,但是rmmod时无法打印字符串,dmesg中也没有相关打印信息,再次insmod才会显示上次退出打印的字符串,请求帮助!!@正点原子



[root@/home/zyf]# insmod hello.ko      #第一次安装模块
has running hello module!               



[root@/home/zyf]# rmmod hello         #第一次卸载模块,没有打印字符串
[root@/home/zyf]# insmod hello.ko     #再次装载才出现刚才卸载模块时的打印的字符
exit hello module                                 
has running hello module!




  1. static int __init insmod_print_hello(void)
  2. {
  3.         printk(KERN_EMERG "has running hello module!\n\n\n");
  4.         return 0;
  5. }
  6. module_init(insmod_print_hello);

  7. static void __exit rmmod_hello(void)
  8. {
  9.         printk(KERN_EMERG "exit hello module");
  10. }

  11. module_exit(rmmod_hello);


  12. MODULE_LICENSE("GPL v2");
  13. MODULE_DESCRIPTION("a simple Hello Module");
复制代码

企业微信截图_163403771284.png
企业微信截图_163403771284.png

最佳答案

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

解决了各位。Linux的标准输入输出都是经过缓存后才显示在终端上的,有两种情况会立即将缓存内容输出到终端:1、当行缓存存满了就会输出打印到终端上;2、在标准输入输出中换行符'\n'可以认为是行刷新标志,遇到\n就将缓存中的内存输出到终端。 所以在printk中加入一个换行符就可以了:printk(KERN_EMERG "exit hello module\n")
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

5

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
101
金钱
101
注册时间
2020-11-5
在线时间
20 小时
 楼主| 发表于 2021-10-12 19:27:31 | 显示全部楼层
本帖最后由 张要飞 于 2021-10-12 19:43 编辑

解决了各位。Linux的标准输入输出都是经过缓存后才显示在终端上的,有两种情况会立即将缓存内容输出到终端:1、当行缓存存满了就会输出打印到终端上;2、在标准输入输出中换行符'\n'可以认为是行刷新标志,遇到\n就将缓存中的内存输出到终端。

所以在printk中加入一个换行符就可以了:printk(KERN_EMERG "exit hello module\n")

回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-22 15:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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