嵌入式Linux最简单驱动模块编译与剖析
2017-01-11 21:09
267 查看
# 最简单的内核模块:
#include<linux/module.h>
#include<linux/kernel.h>
static int my_driver_init(void)
{
printk("hello\n");
return 0;
}
static my_driver_exit(void)
{
printk("byebye\n");
}
module_init(my_driver_init);
module_exit(my_driver)_exit);
MODULE_AUTHOR("hanshanjie");
MODULE_LICENSE("GPL");
其中,module_init()表名模块的入口,该函数在模块加载时候被调用,即insmod,modprobe时候被调用。该函数指定的函数,试分析一个驱动最先关注的,类似于main函数。
Makefile编写:
CROSS_COMPILE ?=
CC = $(CROSS_COMPILE)gcc
obj-m := hello.o
KERNELDIR =
PWD := $(shell pwd)
deafult: $(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE= modules
clean: $(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE= clean
rm -f *.ko *.mod *.symvers *~*.order
实际编译时候:
make -C /home/parallels/work31017/kernel_source/3.10.17-r0/ M=/home/parallels/work31017/helloko/ ARCH=arm CROSS_COMPILE=/opt/poky/1.5.3/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-
modules
过程:
make: Entering directory `/home/parallels/work31017/kernel_source/3.10.17-r0'
CC [M] /home/parallels/work31017/helloko/hello.o
Building modules, stage 2.
MODPOST 1 modules
CC /home/parallels/work31017/helloko/hello.mod.o
LD [M] /home/parallels/work31017/helloko/hello.ko
make: Leaving directory `/home/parallels/work31017/kernel_source/3.10.17-r0'生成:
hello.ko hello.mod.c hello.mod.o hello.o Makefile modules.order Module.symver
安装驱动:insmod
显示hello
卸载驱动 rmmod
显示byebye
#include<linux/module.h>
#include<linux/kernel.h>
static int my_driver_init(void)
{
printk("hello\n");
return 0;
}
static my_driver_exit(void)
{
printk("byebye\n");
}
module_init(my_driver_init);
module_exit(my_driver)_exit);
MODULE_AUTHOR("hanshanjie");
MODULE_LICENSE("GPL");
其中,module_init()表名模块的入口,该函数在模块加载时候被调用,即insmod,modprobe时候被调用。该函数指定的函数,试分析一个驱动最先关注的,类似于main函数。
Makefile编写:
CROSS_COMPILE ?=
CC = $(CROSS_COMPILE)gcc
obj-m := hello.o
KERNELDIR =
PWD := $(shell pwd)
deafult: $(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE= modules
clean: $(MAKE) -C $(KERNELDIR) M=$(PWD) ARCH=arm CROSS_COMPILE= clean
rm -f *.ko *.mod *.symvers *~*.order
实际编译时候:
make -C /home/parallels/work31017/kernel_source/3.10.17-r0/ M=/home/parallels/work31017/helloko/ ARCH=arm CROSS_COMPILE=/opt/poky/1.5.3/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-
modules
过程:
make: Entering directory `/home/parallels/work31017/kernel_source/3.10.17-r0'
CC [M] /home/parallels/work31017/helloko/hello.o
Building modules, stage 2.
MODPOST 1 modules
CC /home/parallels/work31017/helloko/hello.mod.o
LD [M] /home/parallels/work31017/helloko/hello.ko
make: Leaving directory `/home/parallels/work31017/kernel_source/3.10.17-r0'生成:
hello.ko hello.mod.c hello.mod.o hello.o Makefile modules.order Module.symver
安装驱动:insmod
显示hello
卸载驱动 rmmod
显示byebye
相关文章推荐
- Linux开源模块移植概述暨交叉编译跨平台移植总结--摘自《嵌入式Linux驱动模板精讲与项目实践》
- Linux开源模块迁移概述暨交叉编译跨平台移植总结--从《嵌入式Linux驱动模板简洁和工程实践》
- 不用修改核心快速编译驱动模块
- 如何把自己的驱动编译进内核或模块
- 驱动编译进内核或编译模块的区别
- 设备驱动之一 - 最简单的可运行的scull模块
- 如何将驱动或模块编译进内核
- Code maturity level options 代码成熟度选项 [*]Prompt for development and/or incomplete code/drivers 显示尚在开发中或尚未完成的代码与驱动.除非你是测试人员或者开发者,否则请勿选择 我是开发者,所以选[*] Loadable module support 可加载模块支持 [*]Enable loadable module support 内核编译配置选项简介 (2.4.20-8
- 一个最简单的Linux 2.6内核驱动模块
- 如何把自己的驱动编译进内核或模块
- Linux 2.6 内核驱动模块的编译和加载
- 如何把自己的驱动编译进内核或模块(Kconfig和Makefile)
- 编译和安装linux内核2.6.x,一个简单的内核驱动测试
- 内核源码书编译及简单驱动验证
- Linux驱动入门——几个简单的Linux 模块
- Fedora下编译Hello模块驱动
- 编写、编译、安装、移除一个内核模块的基本过程,不能再简单了的
- 转:linux启动时对编译进内核驱动模块的加载
- 关于linux模块驱动简单的Makefile
- 网上找到linux 简单模块编译脚本