#define MODULE
#include<linux/module.h>
MODULE_LICENSE("GPL"); //这个如果不写,会出现Warning说没lincese
int init_module(void) //在 insmod hello.o时打印消息
{
printk("<0>Hello,world/n"); // <0>表示优先级,数字越小优先级越大
return 0;
}
void cleanup_module(void) //在 rmmod hello时打印消息
{
printk("<0>Goodbye cruel world/n");
}
gcc -c hello.c
insmod hello.o
注意:在此步中若出现提示说,内核版本不匹配的话( 这是因为内核源代码版本和编译器版本不一致造成的 ),可以修改,方法如下
可以采取修改编译器版本号与内核源代码版本号一致的办法来解决这个问题,即修改/usr/include/linux/version.h中 #define UTS_RELEASE "2.4.20"
出现如下画面:
Message from syslogd@wuyajie-hisense at Wed Jul 28 02:23:17 2010 ...
wuyajie-hisense kernel: Hello,world
按enter建回到终端
rmmod hello
出现如下画面:
Message from syslogd@wuyajie-hisense at Wed Jul 28 02:24:16 2010 ...
wuyajie-hisense kernel: Goodbye cruel world
linux内核是没有C语言的库函数的,因此不能用printf()函数。
模块能够调用printk是因为在insmod将模块装入内核后,模块就连接到了内核。因而可以访问内核的功用符号
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wyjie1987/archive/2010/08/09/5798644.aspx