#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);
#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]#
因为重复的消息只会显示一次,所以上面的现象是正常的。
源码为: