20135306黄韧模块实践报告

实验目的:

1、  理解模块原理

2、  编写模块代码

3、  编译模块

4、  加载模块

5、  测试模块

6、  卸载模块

实验步骤

1、实验原理

Linux模块是一些可以作为独立程序来编译的函数和数据类型的集合。之所以提供模块机制,是因为Linux本身是一个单内核。单内核由于所有内容都集成在一起,效率很高,但可扩展性和可维护性相对较差,模块机制可弥补这一缺陷。

Linux模块可以通过静态或动态的方法加载到内核空间,静态加载是指在内核启动过程中加载;动态加载是指在内核运行的过程中随时加载。

一个模块被加载到内核中时,就成为内核代码的一部分。模块加载入系统时,系统修改内核中的符号表,将新加载的模块提供的资源和符号添加到内核符号表中,以便模块间的通信。

2、编写模块代码

#  模块构造函数:

执行insmod或modprobe指令加载内核模块时会调用的初始化函数。函数原型必须是module_init(),括号内是函数指针

# 模块析构函数:

执行rmmod指令卸载模块时调用的函数。函数原型是module_exit()

# 模块许可声明:

函数原型是MODULE_LICENSE(),告诉内核该程序使用的许可证,不然在加载时它会提示该模块污染内核。一般会写GPL。

# 模块参数(可选)

#模块导出符号(可选)

#模块作者信息声明(可选)

头文件module.h,必须包含此文件;

头文件kernel.h,包含常用的内核函数;

头文件init.h包含宏_init和_exit,允许释放内核占用的内存。

写一个简单的代码,用来向内核输出一段文字。

(我直接采用了实践指导里面的代码)

代码很简单,里面包括了上文提到的构造、析构和许可证。

3、编译模块

接下来写Makefile。

Makefile里面有用到上学期学过的简写形式。

第一行的printname换成你自己写的.c文件名(module3.c)。

第三行的LINUX_KERNEL_PATH后面要写你自己的内核版本对应的内核源码包地址,我升级过内核,所以版本不太一样。

解释一下make命令:

make -C $(LINUX_KERNEL_PATH) 指明跳转到内核源码目录下读取那里的Makefile

M=$(CURRENT_PATH) 表明返回到当前目录继续执行当前的Makefile。

make之后的执行后

生成了好多文件:

4、加载模块

sudo insmod printname.ko

5、测试模块

dmesg看内核信息

6、卸载模块

sudo rmmod printname

这时用dmesg看内核信息,就会看到写在module_exit()中的输出。

9、结束语

按照实践指导按部就班的做,没有遇到很大的问题,就是在权限方面最后改成了root。在本次实践中,由于基础较差,在查找代码内容方面出现了问题,后期经过学习,对于此项工作已经了解,希望通过此后的学习能够更加熟练深入的理解linux内核。

时间: 2024-11-05 06:25:49

20135306黄韧模块实践报告的相关文章

20135336王维臻模块实践报告

实验目的 1.理解模块原理 2.编写模块代码 3. 编译模块 4.加载模块 5.测试模块 6.卸载模块 实验步骤 1.实验原理 Linux模块是一些可以作为独立程序来编译的函数和数据类型的集合.之所以提供模块机制,是因为Linux本身是一个单内核.单内核由于所有内容都集成在一起,效率很高,但可扩展性和可维护性相对较差,模块机制可弥补这一缺陷. Linux模块可以通过静态或动态的方法加载到内核空间,静态加载是指在内核启动过程中加载:动态加载是指在内核运行的过程中随时加载. 一个模块被加载到内核中时

20135306黄韧 第八章学习总结

第八章异常控制流 控制流:控制转移序列. 控制转移:从一条指令到下一条指令. 异常控制流:现代操作系统通过使控制流发生突变来对系统状态做出反应,这些突变称为异常控制流. 8.1 异常 异常的剖析,如下图所示: 异常处理 异常表:当处理器检测到有事件发生时,它会通过跳转表,进行一个间接过程调用(异常),到异常处理程序. 异常号:系统中可能的某种类型的异常都分配了一个唯一的非负整数的异常号.异常号是到异常表中的索引. 异常类似于过程调用,但有一些重要的不同之处:(1)过程调用时,在跳转到处理程序之前

20135306黄韧[2.72 2.77 3.70](http://i.cnblogs.com/EditPosts.aspx?opt=1)

2.72 A.size_t是无符号整数,因此左边都会先转换为无符号整数,它肯定是大于等于0的. B.判断条件改为 if(maxbytes > 0 && maxbytes >= sizeof(val)) 2.77 #include<stdio.h>int divide_power2(int x, int k){ int ans = x>>k; int w = sizeof(int)<<3; ans += (x>>(w-1)) &am

第五周信息安全系统设计基础学习总结 20135306 黄韧

第三章 程序的机器级表示 3.1  历史观点 Intel处理器系列俗称x86,开始时是第一代单芯片.16位微处理器之一,第一代是8086,也是汇编课程中学习的处理器型号.x86架构于1978年推出的Intel 8086中央处理器中首度出现,它是从Intel 8008处理器中发展而来的,而8008则是发展自Intel 4004的.8086在三年后为IBM PC所选用,之后x86便成为了个人计算机的标准平台,成为了历来最成功的CPU架构. 2.每个后继处理器的设计都是后向兼容的——较早版本上编译的代

关于java实践报告

关于java实践报告,总体来说并不是很难,对我而言最大的难度在于对集合的运用,这也说明了我对第七章甚至java的整体运用并不好,第七章因为不熟练的原因是因为代码量没有敲多少,很多东西并不理解,双列集合和单列集合的运用,一般而言,像这种银行系统肯定是用Map集合更好用,直接将用户账号设定为键值,将对象用户设置为value值,再对比账号密码时直接进行调用,不管是containsKey方法还是equals关键字比较都可以,使代码更灵活也更简单.而List集合虽然可以用,但用起来更加繁琐,且不说创建集合

GSM sniffer实践报告

GSM sniffer实践报告 一.声明这东西在国内挺敏感,国外已经玩了两三年了,国内现在才开始火起来,总之一句话,本报告只做研究用,勿做非法用途,违者自负!二.OsmocomBB简介OsmocomBB是GSM协议栈(Protocols stack)的开源实现,全称是Open source mobile communication Baseband.目的是要实现手机端从物理层(layer1)到layer3的三层实现.但是目前来看,真正的物理层(physical layer)并没有真正的开源实现,

苏黄的假期学习报告3

苏黄的假期学习报告3 复习进度 所有需要复习科目都已经过了一遍,但是时间所剩不多,因为本来寒假就短,我还因为病情住院.不爽! 春节安排 如果学校放假时间往后延一两个星期,我就可以和家人.同学在家乡过完一个完整的春节--从大年三十到元宵节.可惜学校就是想让我们这群年轻人体验一把春运抢不着返程票的滋味,真TMD的生气!我前几天就帮家里人收拾屋子,明天去买只活鸡宰了来祭祀.年三十肯定和家里人过,看不看春晚另外讲:初一就按小学.初中.高中.家这个路线去"行大运":初二回老家.之后就在吃汤圆.粽

第二章实验实践报告

实践报告 第一题 实践题目 问题描述 算法描述 算法时间及空间复杂度分析(要有分析过程) 心得体会(对本次实践收获及疑惑进行总结) 1.实验题目:二分查找 2.问题描述 输入n值(1<=n<=1000).n个非降序排列的整数以及要查找的数x,使用二分查找算法查找x,输出x所在的下标(0~n-1)及比较次数.若x不存在,输出-1和比较次数. 3.算法描述 二分查找算法关键是下标的mid.left.right的变化,开始是left=0和right=length-1,接着就要判断需要查找的值x和mi

第二章上机实践报告

实践报告任选一题进行分析.内容包括: 实践题目: 7-1 二分查找 (20 分) 输入n值(1<=n<=1000).n个非降序排列的整数以及要查找的数x,使用二分查找算法查找x,输出x所在的下标(0~n-1)及比较次数.若x不存在,输出-1和比较次数. 输入格式: 输入共三行: 第一行是n值: 第二行是n个整数: 第三行是x值. 输出格式: 输出x所在的下标(0~n-1)及比较次数.若x不存在,输出-1和比较次数. 问题描述:问题是让我们设计一个二分查找,在已经输入的数组里找到我们输入的数字,