原文:https://www.freesion.com/article/83831518068/
一、环境
Ubuntu14.04 +vmware tools
二、步骤
先写个.c文件,驱动文件一般没有printf,有自己的一套,先写一个helloword.c
- /*
- * helloworld.c
- *
- * 宇文凌风
- *
- */
- #include "linux/init.h"
- #include "linux/module.h"
- static int helloworld_init(void)
- {
- printk(KERN_ALERT "Hello World linux_driver_module,entry helloworld.ko\n");
- return 0;
- }
- static void helloworld_exit(void)
- {
- printk(KERN_ALERT "exit the linux_driver_module helloworld.ko\n");
- }
- module_init(helloworld_init);
- module_exit(helloworld_exit);
- MODULE_LICENSE("GPL");
- MODULE_AUTHOR("ywlf");
- /*
- //MODULE_LICENSE("GPL"); // "GPL" 是指明了 这是GNU General Public License的任意版本
- // “GPL v2” 是指明 这仅声明为GPL的第二版本
- // "GPL and addtional"
- // "Dual BSD/GPL"
- // "Dual MPL/GPL"
- // "Proprietary" 私有的
- // 除非你的模块显式地声明一个开源版本,否则内核会默认你这是一个私有的模块(Proprietary)。
- //MODULE_AUTHOR // 声明作者
- //MODULE_DESCRIPTION // 对这个模块作一个简单的描述,这个描述是"human-readable"的
- //MODULE_VERSION // 这个模块的版本
- //MODULE_ALIAS // 这个模块的别名
- //MODULE_DEVICE_TABLE // 告诉用户空间这个模块支持什么样的设备
- */
紧接着Makefile写起来
- KVERS = $(shell uname -r)
- MODENAME = helloworld
- obj-m += $(MODENAME).o #这个地方务必写成+=,不可写成: ,否则会出现cc -c -o helloworld.o #helloworld.c
- #helloworld.c:9:24: fatal error: linux/init.h: 没有那个文件或目录
- # include "linux/init.h"这样的错误
- build:kernel_modules
- kernel_modules:
- make -C /lib/modules/$(KVERS)/build M=$(CURDIR) modules
- rm *.order && rm *.symvers && rm *.mod.c && rm *.mod.o && rm *.o
- clean:
- make -C /lib/modules/$(KVERS)/build M=$(CURDIR) clean
- rm *.order && rm *.symvers && rm *.ko && rm *.mod.c && rm *.mod.o && rm *.o
也可以这样写:
- KVERS = $(shell uname -r)
- MODENAME = helloworld
- obj-m += $(MODENAME).o
- #build:kernel_modules
- #kernel_modules:
- all:
- make -C /lib/modules/$(KVERS)/build M=$(CURDIR) modules
- rm *.order && rm *.symvers && rm *.mod.c && rm *.mod.o && rm *.o
- clean:
- make -C /lib/modules/$(KVERS)/build M=$(CURDIR) clean
- rm *.order && rm *.symvers && rm *.ko && rm *.mod.c && rm *.mod.o && rm *.o
三、运行
这里什么原理呢?
初步的想法就是:
make -C dir:在读取makefile 之前改变到指定的目录dir;
“M=”选项的作用是,当用户需要以某个内核为基础编译一个外部模块的话,需要在make modules 命令中加入“M=dir”,程序会自动到你所指定的dir目录中查找模块源码,将其编译,生成KO文件。
四、运行驱动
查看ko模块的信息 modinfo helloworld.ko
加载驱动
insmod helloworld.ko
sudo insmod helloworld.ko
如果先在另一终端中运行: sudo cat /proc/kmsg 就可以看到有 hello world 打印。
卸载驱动也是:sudo rmmod helloworld
对驱动的初步映像就是,依赖于内核的模块编译,最后依赖于内核加载,初步学习,借鉴了很多,切记不可直接拷贝,Makefile我直接从网上拷贝,大佬们写的没毛病,只不过编码不一致,编译了好久不过,最后重新自己敲了一遍,又借鉴了已有的另一个大佬的编好的东西才搞定
标签:GPL,MODULE,UBUNTU,modules,helloworld,笔记,&&,rm,驱动 From: https://www.cnblogs.com/bruce1992/p/17323196.html