linux 驱动 Printk 在终端没有输出

写LINUX 驱动的时候 在初始化和退出的时候加了printk 但是在终端没有输出  
图片
这个有输出
图片
图片
这个没有
图片

原因是要加上一个输出等级
图片

0~3的等级可以再终端输出

有一个人写的很好借来用一下

printk无输出

Q:

int init_module()
{
printk("Hello\n");
}

编译成功后,也用insmod命令成功地载入。但并没有任何输出..

A:

1.同时在另一个窗口,用命令tail -f /var/log/messages察看日志文件,会看到log

2.dmesg命令。
它的输出是在内核log中,不是控制台

-----------------------------------------------------

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你好!要编写一个简单的Linux驱动程序来打印"Hello World",可以按照以下步骤进行操作: 1. 创建一个文件夹来存放驱动程序的源代码。可以使用以下命令创建: ``` mkdir helloworld_driver cd helloworld_driver ``` 2. 创建一个名为`helloworld.c`的C语言源代码文件,并使用文本编辑器打开它: ``` touch helloworld.c nano helloworld.c ``` 3. 在打开的文件中,输入以下驱动程序的基本结构: ```c #include <linux/module.h> #include <linux/kernel.h> static int __init hello_init(void) { printk(KERN_INFO "Hello World!\n"); return 0; } static void __exit hello_exit(void) { printk(KERN_INFO "Goodbye World!\n"); } module_init(hello_init); module_exit(hello_exit); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Your Name"); MODULE_DESCRIPTION("A simple hello world driver"); ``` 上述代码包含了两个函数:`hello_init()`和`hello_exit()`。`hello_init()`函数在加载驱动程序调用,用于打印"Hello World"。`hello_exit()`函数在卸载驱动程序调用,用于打印"Goodbye World"。 4. 保存并关闭文件。 5. 创建一个名为`Makefile`的文件,并使用文本编辑器打开它: ``` touch Makefile nano Makefile ``` 6. 在打开的文件中,输入以下内容: ``` obj-m += helloworld.o all: make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules clean: make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean ``` 7. 保存并关闭文件。 8. 打开终端,进入到存放驱动程序源代码的文件夹。 9. 使用以下命令编译和构建驱动程序: ``` make ``` 10. 如果一切顺利,没有错误发生,将会生成一个名为`helloworld.ko`的驱动程序模块文件。 11. 使用以下命令加载驱动程序: ``` sudo insmod helloworld.ko ``` 这将会在终端打印"Hello World"。 12. 使用以下命令卸载驱动程序: ``` sudo rmmod helloworld ``` 这将会在终端打印"Goodbye World"。 这就是一个简单的Linux驱动程序的"helloworld"编写过程。请注意,编写和加载驱动程序可能需要管理员权限。如果有任何问题,请随向我提问!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值