3. 嵌入式linux驱动-驱动加载的两种方式
文章目录1. 动态加载2. 静态加载3. 两种方式的优缺点 linux驱动的加载有动态加载和静态加载两种方式。1. 动态加载 驱动的动态加载指的是利用了linux的module特性,可以在系统启动后通过insmod或modprobe命令挂载.ko内核目标文件,对模块进行加载,成功后可通过mknod指令进行挂载节点,在不需要的时候可通过rmmod命令来卸载模块。 操作方法: 在驱动文件...
linux驱动的加载有动态加载和静态加载两种方式。
1. 动态加载
驱动的动态加载指的是利用了linux的module特性,可以在系统启动后通过insmod或modprobe命令挂载.ko内核目标文件,对模块进行加载,成功后可通过mknod指令进行挂载节点,在不需要的时候可通过rmmod命令来卸载模块。
操作方法: 在驱动文件mydrv.c和makefile目录下执行make编译出mydrv.ko文件,然后复制到目标板,执行insmod命令加载驱动,然后就可以在应用层调用了,不使用可以使用rmmod命令卸载驱动模块。
2. 静态加载
驱动的静态加载指的是直接把驱动程序编译进内核,在系统启动后可直接调用,不需要任何加载卸载命令。
操作方法:
- 将驱动文件驱mydrv.c复制到目标板内核源码树drivers/char(假设是字符型驱动)下。
- 在char目录的Kconfig文件中添加新源代码对应项目的编译配置选项
Config MYDRV ------对应驱动
bool “support for mydrv” ------选项
default y -----定义开始为yes
- 在char目录的Makefile文件中添加编译脚本
obj-$(CONFIG_MYDRV) += mydrv.o
编译内核后,驱动就被静态加载到内核了。
3. 两种方式的优缺点
动态加载的模块本身没有被编译进内核映像,控制内核的大小;同时,模块一旦被加载,它就和内核中的其他部分完全一样,使用灵活。可在每次调用时都需要通过命令进行加载与卸载,操作麻烦。
静态加载驱动模块直接编译进内核映像,伴随系统的启动自动加载,使用方便,不需要任何加载卸载命令。但是把模块编译进内核使得生成的内核很大,如果我们要在现有的内核中新增加或删除功能,将不得不重新编译内核,效率较低。
嵌入式linux驱动开发时,可以使用动态加载方式,这样调试方便,开发完成后可以是静态加载方式,这样使用方便。
更多推荐
所有评论(0)