LDD3 带有参数的模块

#include <linux/init.h>
#include <linux/module.h>
#include <linux/moduleparam.h>


static char *who= "who";
static int time= 1;
module_param(time, int, S_IRUGO);
module_param(who, charp, S_IRUGO);

static int hello_init(void)
{
    int i=0;
    for (i=0; i<time; i++)
    printk(KERN_EMERG"HELLO,WORLD::::%d:%s\n",time,who);
    return 0;
}

static int hello_exit(void)
{
    printk(KERN_EMERG"GOOBYE,WORLD\n");
    return 0;
}

module_init(hello_init);
module_exit(hello_exit);
MODULE_LICENSE("Dual BSD/GPL");
EXPORT_SYMBOL(who);
//EXPORT_SYMBOL_GPL(who);

EXPORT_SYMBOL(time);
//EXPORT_SYMBOL_GPL(time);

测试结果:

[root@localhost module_with_arg]#
[root@localhost module_with_arg]# insmod book.ko who=ericjiang time=2
[root@localhost module_with_arg]#
Message from syslogd@ at Wed Sep 28 02:34:06 2011 ...
localhost kernel: HELLO,WORLD::::2:ericjiang
[root@localhost module_with_arg]# rmmod book.ko
[root@localhost module_with_arg]#
Message from syslogd@ at Wed Sep 28 02:42:06 2011 ...
localhost kernel: HELLO,WORLD::::2:ericjiang
Message from syslogd@ at Wed Sep 28 02:42:06 2011 ...
localhost kernel: GOOBYE,WORLD
[root@localhost module_with_arg]#

因为重复的消息只会显示一次,所以上面的现象是正常的。

源码为:

module_with_arg.tar.gz


你可能感兴趣的:(LDD3 带有参数的模块)