西电软院操作系统课程设计报告.docx

上传人:b****2 文档编号:18466331 上传时间:2023-08-18 格式:DOCX 页数:16 大小:603.46KB
下载 相关 举报
西电软院操作系统课程设计报告.docx_第1页
第1页 / 共16页
西电软院操作系统课程设计报告.docx_第2页
第2页 / 共16页
西电软院操作系统课程设计报告.docx_第3页
第3页 / 共16页
西电软院操作系统课程设计报告.docx_第4页
第4页 / 共16页
西电软院操作系统课程设计报告.docx_第5页
第5页 / 共16页
西电软院操作系统课程设计报告.docx_第6页
第6页 / 共16页
西电软院操作系统课程设计报告.docx_第7页
第7页 / 共16页
西电软院操作系统课程设计报告.docx_第8页
第8页 / 共16页
西电软院操作系统课程设计报告.docx_第9页
第9页 / 共16页
西电软院操作系统课程设计报告.docx_第10页
第10页 / 共16页
西电软院操作系统课程设计报告.docx_第11页
第11页 / 共16页
西电软院操作系统课程设计报告.docx_第12页
第12页 / 共16页
西电软院操作系统课程设计报告.docx_第13页
第13页 / 共16页
西电软院操作系统课程设计报告.docx_第14页
第14页 / 共16页
西电软院操作系统课程设计报告.docx_第15页
第15页 / 共16页
西电软院操作系统课程设计报告.docx_第16页
第16页 / 共16页
亲,该文档总共16页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

西电软院操作系统课程设计报告.docx

《西电软院操作系统课程设计报告.docx》由会员分享,可在线阅读,更多相关《西电软院操作系统课程设计报告.docx(16页珍藏版)》请在冰点文库上搜索。

西电软院操作系统课程设计报告.docx

西电软院操作系统课程设计报告

操作系统课程设计

实验报告册

 

班级:

学号:

姓名:

教师:

褚华

 

实验说明

重要提示

实验1系统调用

实验2内核模块

实验3文件系统

实验4设备管理

实验说明

1.实验做为学习的重要促进手段,是为了深化对理论的理解,锻炼实践动手能力。

2.实验同时也作为考核的手段。

3.实验内容会在课程进行中下达,并且会分次地、部分地被抽查。

4.课程结束时,要求把所有的实验整理成一个完整的电子文档并上交,做为最后成绩的评定依据。

5.如果有兴趣的合适的题目,也可自己选题目。

格式说明

1.本文档文件名命名为“学号-姓名”,如“13071000_小王”。

2.留白部分不足的自己调整长度,也可加页(增加内容应在表格内)。

3.每次的实验报告都要在这个文件中(按照实验次序依次)增加,而不是每次一个新的word文件。

4.本文档保存为doc格式(请勿用Word2007的docx格式)。

重要提示:

1.实验正文建议使用小四号或五号宋体。

2.若附加图形,则请直接嵌入到实验手册相应位置。

3.各实验的源程序,请按实验分目录存放,如第一个实验的源程序存放在目录lab1下,第二个实验的源程序存放在目录lab2下等等,依次类推。

可互相讨论,但严禁抄袭网络或同学的实验结果。

 

实验编号

1

题目

系统调用

实验目的

为Linux内核增加一个系统调用,并编写用户进程的程序来测试

要求该系统调用能够完成以下功能:

1.该系统调用有1个int型参数,返回值为int。

2.若参数为偶数,则输出自己学号后四位

3.若参数为奇数,则输出自己学号的后五位

实验内容

1.系统调用的实现

2.增加系统调用

3.Linux内核的构建

报告内容要求

(1)实现方法和思路

(2)测试及结果

报告正文

要给linux增加系统调用,可以用修改内核源码并重新编译的方法实现

一:

基本过程是

1.在系统调用表文件中给要增加的一个系统调用的名字

2.在系统调用号文件中给要新增的系统调用分配一个系统调用号

3.增加系统调用声明

4.添加系统调用的实现

5.重新编译内核

6.编写测试驱动函数,测试系统调用是否添加成功

 

一:

在系统调用表文件中增加系统调用的名字

二:

在系统调用号文件中给要新增的系统调用分配一个系统调用号

 

三:

增加系统调用声明

 

四:

添加系统调用的实现

要为linux内核增加系统调用,首先必须要实现系统的内核调用

也就是提供功能的一个函数

根据题目要求,当给改系统调用传递int参数为奇数时输出自己学号的后五位,当系统调用接受的参数为偶数时,输出自己学号的后四位

所以,系统调用的实现如下

可以看到系统调用的实现同基本的C语言没多大差别,只是能使用的库不一样

在linux内核中的代码不能使用标准C库,只能使用内核提供的库

所以能调用的函数会有不同

最后实现代码如下

当参数num为偶数时输出2257也就是学号的后四位

当参数为奇数时输出12257也就是学号的后四位

可以看到输出函数式printk而不是printf,因为在内核中不能使用标准C函数

五:

编译内核

六:

测试系统调用

测试驱动函数如下

测试输出如下

由于在系统调用实现时忘记在末尾加换行符了。

所以输出的两个是在一行的

也就是2257和12257,但是可以看到系统调用时实现了的。

 

实验编号

2

题目

内核模块

实验目的

1.学习linux内核模块的编写及加载的方法

2.理解linux内核模块的机制

实验内容

1.编写linux内核模块并测试

2.编写可以带参数的linux内核模块并测试

3.使用内核模块的方法为linux增加系统调用

1、用内核模块的方法完成实验1的内

报告内容要求

(1)实现方法和思路

(2)测试及结果

报告正文

实验内容:

编写一个内核模块;

编译该模块;

加载、卸载该模块;

实验步骤:

新建模块目录

用编辑器(vi)编辑源文件

分析:

模块入口函数为hello_init(),由module_init()宏指定,在模块被加载的时候被调用向系统注册。

入口函数的返回值:

0表示成功,非0表示失败。

模块的退出函数为hello_exit(),由module_exit()宏指定,在模块被卸载时被调用向系统注销,主要来完成资源的清理工作。

它被调用完毕后,就模块就被内核清除了。

一个模块最少需要有入口和退出函数。

 

2.4内核后,引入识别代码是否在GPL许可下发布的机制。

在使用非公开的源代码产品时会得到警告。

通过宏MODULE_LICENSE(“GPL”),设置模块遵守GPL证书,取消警告信息。

宏MODULE_DESCRIPTION()用来描述模块的用途。

宏MODULE_AUTHOR()用来声明模块的作者。

宏MODULE_SUPPORTED_DEVICE()声明模块支持的设备。

这些宏都在头文件linux/module.h定义,使用这些宏只是用来提供识别信息。

用编辑器编辑Makefile

编译模块

加载删除模块

dmesg输出信息

带参数的模块

传入参数

输出结果

内容二:

用内核模块的方式为系统添加一个系统调用

为Linux内核增加一个系统调用,并编写用户进程的程序来测试。

要求该系统调用够完成以下功能:

1.该系统调用有1个int型参数,返回值为int。

2.若参数为偶数,则输出自己学号后四位

3.若参数为奇数,则输出自己学号的后五位

基本思路就是通过修改系统调用参数表所在的内存地址

并加入系统调用即可

实验编号

3

题目

文件系统

实验目的

1.了解/proc文件系统

2.掌握修改/proc文件系统的方法

3.利用/proc与内核交互

创建以及使用/proc文件

实验内容

1.利用/proc与内核交互

2、利用内核模块方法创建/proc文件

报告内容要求

(1)实现方法和思路

(2)测试及结果

报告正文

实验一:

本实验只使用标准C函数进行修改/proc文件

也就是说直接readwrite/proc里的文件

从而达到与内核交互的目的

代码如下

输出结果

可以看到实现了功能完成了hostname文件的修改

 

内容二:

通过内核的/proc编程接口进行/proc文件的操作

本试验通过构造可加载内核模块,通过内核的/proc编程接口进行/proc文件的操作

需要用到的基本函数有

structproc_dir_entry*create_proc_entry(constchar*name,mode_tmode,structproc_dir_entry*parent)这个函数创建一个/proc文件

structproc_dir_entry*create_proc_read_entry(constchar*name,mode_tmode,structproc_dir_entry*base,read_proc_t*read_proc,void*data)这个函数创建一个/proc的只读文件

structproc_dir_entry*proc_mkdir(constchar*name,structproc_dir_entry*parent)这个函数创建一个/proc目录

删除节点(文件或者目录)remove_proc_entry()

voidremove_proc_entry(constchar*name,structproc_dir_entry*parent)

该函数将删除一个proc节点(按文件名删除)

以上函数只能创建一个文件,要想使创建的文件发挥作用,还有两个域的值需要填写,它们是read_proc和write_proc。

该两个函数都是回调函数,当对文件进行读写时,系统会自动调用相应的回调函数。

可以使用write_proc函数向/proc中写入一项。

这个函数的原型如下

int(*write_proc)(structfile*file,constchar*buffer,unsignedlongcount,void*data)

file参数实际上是一个打开文件结构(我们可以忽略这个参数)。

buffer参数是传递给您的字符串数据。

缓冲区地址实际上是一个用户空间的缓冲区,因此我们不能直接读取它。

count参数定义了在buff中有多少数据要被写入。

data参数是一个指向私有数据的指针

可以使用read_proc函数从一个/proc项中读取数据(从内核空间到用户空间)。

这个函数的原型如下:

int(*read_proc)(char*page,char**start,off_toff,intcount,int*eof,void*data)

page参数是这些数据写入到的位置,其中count定义了可以写入的最大字符数。

在返回多页数据(通常一页是4KB)时,我们需要使用start和off参数。

当所有数据全部写入之后,就需要设置eof(文件结束参数)。

与write类似,data表示的也是私有数据。

此处提供的page缓冲区在内核空间中。

实验代码如下

可以看到代码创建一个/proc13121257的目录

并且创建两个文件以及一个link文件

结果如下

若对文件进行读写操作则如下显示

实验编号

4

题目

设备管理

实验目的

1.了解linux设备文件

2.了解linux设备驱动程序的编写

实验内容

1.实现一个linux字符设备驱动文件

报告内容要求

(1)实现方法和思路

(2)测试及结果

报告正文

1.首先了解linux设备驱动文件的基本数据结构

内核设备驱动程序表结构(infs/devices.c)

structdevice_struct{

constchar*name;//devicename

structfile_operations*fops;

};

字符设备驱动程序的基本操作和数据结构

2.字符设备驱动程序:

设备表:

全局数组chrdevs[255],主设备号是它的下标

登记:

register_chrdev()/unregister_chrdev()

缺省操作集合:

file_ops:

def_chr_fops,仅定义了open方法;

inode_ops:

chrdev_inode_operations,仅定义了其中的file_operation=&def_chr_fops.

三:

关键代码

实现了驱动程序的初始化以及退出清理函数

在初始化中用register_chrdev函数进行注册

在退出中用unregister_chrdev函数进行清理

2.关键的字符设备驱动程序的数据结构

其中rwbuf_open实现打开设备文件操作

Rwbuf_close实现关闭设备文件操作

Rwbuf_write实现写设备文件

Rwbuf_read实现读设备文件

Rwbuf_ioctl实现一些操作

在测试函数中

实现读写操作以及clean操作

首先创建一个设备文件节点

可以看出可以对设备文件像普通文件一样进行读写操作

运行结果如下

实验完成

 

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 法律文书 > 判决书

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2