目录

一、环境配置

 1、开发板环境

2、uboot环境

①设置bootargs

②设置bootcmd

二、加载驱动与卸载驱动

 1、加载命令选择

2、创建目录环境以及驱动文件复制

3、加载驱动 

提示①“modprobe: can't open 'modules.dep': No such file or directory”

 提示②module license 'unspecified'

4、卸载驱动

提示②module license 'unspecified'的解决

三、测试驱动入口函数和出口函数

1、printk 

2、测试 


一、环境配置

 1、开发板环境

开发板通过从SD卡启动,SD卡里面烧写了uboot,开发板能ping通ubantu

uboot通过tftp从ubuntu里面获取zimage和dtb,rootfs也是通过nfs挂载

2、uboot环境

①设置bootargs

setenv bootargs='console=ttymxc0,115200 rw root=/dev/nfs nfsroot=192.168.1.222:/home/ubantu22/nfs/rootfs ip=192.168.1.221:192.168.1.222:192.168.1.1:255.255.255.0::eth0:off'

“console”为设置串口和波特率,“rw”是可读可写权限,"root"告诉内核要通过网络取得根文件系统

“nfsroot”后面ip为uabntu的ip,路径为根文件系统路径

“ip”第一个是开发板ip,第二个是ubantu的ip第三个是网关,第四个是子网掩码

“eth0”设置使用的网口

记得使用saveenv命令进行保存

②设置bootcmd

setenv bootcmd='tftp 80800000 zImage;tftp 83000000 imx6ull-my-emmc.dtb;bootz 80800000 - 83000000;'

通过tftp下载zImage到80800000和.dtb设备树下载到83000000

用bootz启动

记得使用saveenv命令进行保存

二、加载驱动与卸载驱动

 1、加载命令选择

驱动编译完成以后扩展名为.ko,有两种命令可以加载驱动模块: insmod和 modprobe

 insmod是最简单的模块加载命令,此命令用于加载指定的.ko 模块,但是insmod 命令不能解决模块的依赖关系,比如 drv.ko 依赖 first.ko 这个模块,就必须先使用insmod 命令加载 first.ko 这个模块,然后再加载 drv.ko 这个模块,所以不建议使用这个

modprobe 会分析模块的依赖关系,然后会将所有的依赖模块都加载到内核中,因此modprobe 命令相比 insmod 要智能一些。 modprobe 命令主要智能在提供了模块的依赖性分析、错误检查、错误报告等功能,推荐使用 modprobe 命令来加载驱动

要注意的是,modprobe 命令默认会去/lib/modules/<kernel-version>目录中查找模块,比如这里使用的 Linux kernel 的版本号为 4.1.15,因此 modprobe 命令默认会到/lib/modules/4.1.15 这个目录中查找相应的驱动模块,一般自己制作的根文件系统中是不会有这个目录,所以需要自己手动创建

2、创建目录环境以及驱动文件复制

cd lib

mkdir modules

cd modules

mkdir 4.1.15

cd 4.1.15

Linux完整卸载GPU驱动 linux卸载驱动模块_linux

 这就进入到/lib/modules/4.1.15的目录下了,在ubantu里面把驱动放到这个目录下,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_02

 在开发板上面查看一下.ko文件,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_ubuntu_03

3、加载驱动 

利用modprobr加载驱动,如下图

 

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_04

 这里错误提示“modprobe: can't open 'modules.dep': No such file or directory”

提示①“modprobe: can't open 'modules.dep': No such file or directory”

modprobe 提示无法打开“modules.dep”这个文件,因此驱动挂载失败了。对于一个新的模块使用modprobe加载的时候需要先调用一下depmod命令,直接输入 depmod 命令即可自动生成modules.dep,不用手动创建。有些根文件系统可能没有 depmod 这个命令,如果没有这个命令就只能重新配置busybox,使能此命令,然后重新编译 busybox。输入“depmod”命令以后会自动生成 modules.alias、modules.symbols 和 modules.dep 这三个文件,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_Linux完整卸载GPU驱动_05

 下面重新加载驱动,使用modprobe如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_ubuntu_06

 提示②module license 'unspecified'

这里有提示“chrdevbase: module license 'unspecified' taints kernel.Disabling lock debugging due to kernel taint”,意为未指定许可证,这里暂时不管,学完卸载驱动后进行解决

下面用“lsmod”查看一下当前的驱动模块都有那些,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_07

可以看到已经有chrdevbase的驱动了

4、卸载驱动

利用“remod”卸载驱动,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_Linux完整卸载GPU驱动_08

chrdevbase 驱动已经被卸载了

下面先解决刚刚加载驱动后出现的提示

提示②module license 'unspecified'的解决

重新加载驱动,如下图

Linux完整卸载GPU驱动 linux卸载驱动模块_Linux完整卸载GPU驱动_09

这次重新加载就没有错误提示了,而且也成功加载,可能是只提示一次,但还是要解决

出现提示“chrdevbase: module license 'unspecified' taints kernel主要是因为驱动没有 license信息

下面在编译驱动的c文件里面添加 license信息和作者信息(可不加),代码如下

MODULE_LICENSE("GPL");                        /* license许可信息,采用 GPL 协议*/
MODULE_AUTHOR("ba che kai qi lai");        /*作者*/

Linux完整卸载GPU驱动 linux卸载驱动模块_linux_10

 重新编译,再拷贝到开发板根文件系统的/lib/modules/4.1.15的目录下

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_11

Linux完整卸载GPU驱动 linux卸载驱动模块_Linux完整卸载GPU驱动_12

 先把已经加载的chrdevbase驱动卸载

Linux完整卸载GPU驱动 linux卸载驱动模块_Linux完整卸载GPU驱动_13

 重启开发板来测试是否还会有提示,重新加载驱动

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_14

可以看到不再出现“module license 'unspecified' ”的提示了

三、测试驱动入口函数和出口函数

1、printk 

先了解一下关于printf和printk,在内核里面没有printf这个函数的

printf运行在用户态,而printk运行在内核态,printk使用有等级之分,具体可以自行了解

想要在内核里面向控制台输出或显示一些内容就需要用printk这个函数

在驱动入口函数里面输入下面代码

#include<linux/kernel.h>
#include<linux/init.h>

printk("chrdevbase_init\r\n");

printk("chrdevbase_exit\r\n");

Linux完整卸载GPU驱动 linux卸载驱动模块_arm_15

 添加完成重新编译和复制到开发板根文件系统的/lib/modules/4.1.15的目录下

Linux完整卸载GPU驱动 linux卸载驱动模块_linux_16

2、测试 

 再来测试加载驱动和卸载驱动

Linux完整卸载GPU驱动 linux卸载驱动模块_arm开发_17

这里都已经打印提示信息,说明驱动出口和入口函数都已经执行了