########## Makefile ##########
obj-m := modname.o
編譯完會有modname.ko
當前目錄下必須有modname.[c/s/S]文件
obj-m的值有多少個*.o就會有多少個*.ko
++++++++++++++++++++++++++++++
多文件:
obj-m := modname.o
modname-objs := 1.o 2.o ...
編譯完的modname.o由modname-objs的所有*.o產生
***不會編譯當前目錄下的modname.[c/s/S]文件
########## 模塊命令 ##########
insmod modname.ko or modprobe modname 用modprobe命令需要把模塊安裝到文件系統
lsmod [modname] or cat /proc/modules
rmmod module_name or modprobe -r modname
modinfo modname.ko
########## 模塊基本結構 ##########
include <linux/init.h>
include <linux/module.h>
static int __init test_init(void)
{
printk("hello test init!!!\n");
return 0;
}
static void __exit test_exit(void)
{
printk("hello test exit!!!\n");
}
module_init(test_init);
module_exit(test_exit);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("...");
MODULE_DESCRIPTION("...");
########## 模塊參數 ##########
type var_name;
module_param(var_name, type, perm); insmod modname.ko var_name=value
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
int num = SIZE;
type var_name[SIZE];
module_param_array(var_name, type, &num, perm); insmod modname.ko var_name=val0, val1, val2, ..., valSIZE
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
var_name: 變量(必須是全局)
type:
byte
short
ushort
int
uint
long
ulong
charp
bool
invbool
perm: 指定/sys/module/$(modname)/parameters/$(param_name)文件的權限(該文件的內容為var_name的值) --->> kernel/include/linux/stat.h:50
0 --->(沒有相對應的文件)
S_IRWXUGO
S_IALLUGO
S_IRUGO
S_IWUGO
S_IXUGO
&num: 參數長度指針(必須是全局)
########## 符號導出 ##########
EXPORT_SYMBOL(symbol_name);
內核---->內核 or 模塊A---->模塊A 不需要導出符號
模塊---->內核 or 模塊A---->模塊B 只能使用對方已導出的符號
內核---->模塊 不管模塊符號是否導出都不能使用
########## printk ##########
級別: include/linux/printk.h:9
cat /proc/sys/kernel/printk
echo a [b] > /proc/sys/kernel/printk
a: 級別小於a的消息將會打印到控制台
b: 默認級別