linux内核 helloworld,Linux内核模块编程helloworld小程序问题解决方法

首先声明下,对Linux也是刚入门。没系统的学习过Linux。

首先附上能编译通过的hello world程序。

//#ifndef __KERNEL__

//#define __KERNEL__

//#endif //见别人的程序里出现过 注释掉也能通过。

#ifndef MODULE

#define MODULE

#endif

#include

MODULE_LICENSE("GPL");

int init_module(void){

printk("<0>Hello World!");

return 0;

}

void cleanup_module(void){

printk("<0>Goodbye World!");

}

编译程序可能会出现的问题:

若直接用命令gcc -c hello.c编译(声明下文件名为hello.c),则可能会出现以下提示:

hello.o: kernel-module version mismatch

hello.o was compiled for kernel version 2.4.20

while this kernel is version 2.4.20-8.

解决办法: 加-I选项即:gcc -I/usr/src/Linux-2.4.20-8/include/ -c hello.c -o hello.o

程序里还需要有这么一句 MODULE_LICENSE("GPL");否则出现以下警告信息,但模块已经加载

Warning: loading modt.o will taint the kernel: no license

See http://www.tux.org/lkml/#export-tainted for information about tainted

modules

Module modt loaded, with warnings

注意问题:加载模块命令参数和卸载模块命令参数有一点点不同哦

加载模块:insmod hello.o

卸载模块:rmmod hello 注意后面没有点偶哦(.o)

某些时候用insmod -f能够强制成功加载,需谨慎使用。

打印消息受级别的限制,消息级别可以通过printk设置,上面给出的代码设置级别为第0级,数字越小级别越高。

如果看不到用printk打印的信息,将级别设置为0级应该就可以了,也可以用dmesg命令查看。

i.e. 察看加载模块打印信息:首先执行命令insmod hello.o回车,然后再给一条命令dmesg即可。卸载模块类似。呵呵。0b1331709591d260c1c78e86d0c51c18.png

你可能感兴趣的:(linux内核,helloworld)