三、Linux内核模块编写2(多个c文件生成一个ko文件)

2024-03-01 05:30

本文主要是介绍三、Linux内核模块编写2(多个c文件生成一个ko文件),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  模块是一个目标文件,可以完成某种独立的功能,但是自身不是一个独立的进程,不能单独运行,可以动态的载入模块,使其成为内核代码的一部分,与内核其他代码的地位完全相同,当不需要某个模块功能时,还可以卸载模块。

(一) 多个c文件生成一个ko文件。

( 注: ko文件为kernel object文件,也称内核模块 )
程序包括:hello.c 、add.c 、Makefile。

a. 编写Makefile文件程序。

#多个c文件生成一个ko文件。
obj-m +=main.o                 #名字自定义,但是不要和.c文件的o文件名字一样!!
main-objs =hello.o add.o       # -objs前的名字要和定义的名字一致# KDIR 内核源码路径,根据自己需要设置
KDIR:=/home/qjl/work/lichee/linux-3.10all:
#ARCH: 指当前编译的驱动模块的架构
#CROSS_COMPILE:指明交叉编译器的前缀
#-C: 指定去$(KDIR)目录下执行Makefile
#M:告知Makefile,需要的编译文件在哪
#modules: 这个规则是用于编译驱动模块的@make ARCH=arm64 CROSS_COMPILE=aarch64-linux- -C $(KDIR) M=$(PWD) modules @rm -fr .tmp_versions *.o *.mod.o *.mod.c *.bak *.symvers *.markers *.unsigned *.order *~ .*.*.cmd .*.*.*.cmdclean:@make ARCH=arm64 CROSS_COMPILE=aarch64-linux- -C $(KDIR) M=$(PWD) modules clean@rm -rf *.ko	

b. 编写简单内核模块程序 ( hello.c )。

#include <linux/module.h>
#include <linux/kernel.h>extern int add(int ,int);
//实现入口、出口函数
/*__int只有驱动被编译进内核时才有效。作用:执行完本函数后丢弃该函数,并释放其占用的空间。(节约空间)原因:它只有模块被安装后才能触发。
*/static int __init a53_hello_init(void) //驱动模块被安装时触发的函数
{// 如果想把消息打印至前台,需要给printk输入等级如0 1 2 3。 如KERN_ERR为3.// 不赋予printk等级则 会将信息打印至后台。	//可使用 :dmesg -c  查看后台内.printk(KERN_ERR"hello world:%d\r\n",add(10,20));  return 0;  //此函数返回0时驱动才能正常安装,返回其他值则安装失败}/*__exit只有驱动被编译进内核时才有效。作用:不将本函数进行链接,因为模块不可能被卸载,所以此函数无意义
*/
static void __exit a53_hello_exit(void) //驱动模块被卸载时触发的函数
{printk(KERN_ERR"BYE BYE\r\n"); // 不使用KERN_ERR 会将信息打印至后台
}//声明驱动模块的入口、出口
module_init(a53_hello_init);
module_exit(a53_hello_exit);MODULE_LICENSE("GPL"); //本驱动程序遵循GPL开源协议,必写
MODULE_AUTHOR("QJL <1033275663@qq.com>");//作者信息
MODULE_DESCRIPTION("This is hello world driver");//驱动功能的描述
MODULE_VERSION("v1.0");//驱动的版本

c.编写add.c文件。这个c文件不是模块文件,只是普通的c文件。

int add(int a,int b)
{return a+b;
}

d. 使用make生成hello.ko驱动文件。

e.将驱动文件传给开发板,进行安装。(传输方式见:(https://blog.csdn.net/qq_48361010/article/details/131304809?spm=1001.2014.3001.5501))。

(二)模块的安装与卸载

a.原程序目录文件:
在这里插入图片描述

b.使用make编译后目录文件:
在这里插入图片描述

c.将ko文件传给开发板

d.开发板安装模块

insmod main.ko

在这里插入图片描述

e.开发板卸载模块

rmmod main

在这里插入图片描述
  

附加: 参数传入(使用不多,一般用于调试)
使用参考:

int n;
module_param(n, int, 0700); //0777为权限char *p;
module_param(p, charp, 0700); //0777为权限static int __init a53_hello_init(void) //驱动模块被安装时触发的函数
{// 如果想把消息打印至前台,需要给printk输入等级如0 1 2 3。 如KERN_ERR为3.// 不赋予printk等级则 会将信息打印至后台。	//可使用 :dmesg -c  查看后台内.printk(KERN_ERR"hello world\r\n");  printk(KERN_ERR"n = %d\r\n", n);printk(KERN_ERR"p = %s\r\n", p);return 0;  //此函数返回0时驱动才能正常安装,返回其他值则安装失败
}

执行安装模块命令时 输入参数,且要输入规范。变量名要一致!!
在这里插入图片描述

这篇关于三、Linux内核模块编写2(多个c文件生成一个ko文件)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/761345

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri