实验四统计缺页次数_第1页
实验四统计缺页次数_第2页
实验四统计缺页次数_第3页
实验四统计缺页次数_第4页
实验四统计缺页次数_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实验四-统计缺页次数实验四统计操作系统缺页次数实验目的学习虚拟内存的基本原理和Linux虚拟内存管理技术;进一步理解、掌握Linux的按需调页过程;掌握内核模块的概念和操作办法,和向/proc文献系统中增加文献的办法;综合运用内存管理、系统调用、proc文献系统、内核编译的知识。实验内容1.原理Linux的虚拟内存技术采用按需调页,当CPU请求一种不在内存中的页面时,会发生缺页,缺页被定义为一种异常(缺页异常),会触发缺页中断解决流程。每种CPU构造都提供一种do_page_fault解决缺页中断。由于每发生一次缺页都要进入缺页中断服务函数do_page_fault一次,因此能够认为执行该函数的次数就是系统发生缺页的次数。因此能够定义一种全局变量pfcount作为计数变量,在执行do_page_fault时,该变量值加1。本实验通过动态加载模块的办法,运用/proc文献系统作为中介来获取该值。2.实验环境操作系统:Ubuntu12.04(内核版本为3.2.0-23-generic-pae)内核源码:linux-3.2.58实验指导下载一份内核源代码并解压Linux受GNU通用公共许可证(GPL)保护,其内核源代码是完全开放的。现在诸多Linux的网站都提供内核代码的下载。推荐使用Linux的官方网站:。图1Linux的官方网站在terminal下能够通过wget命令下载源代码:$cd/tmp$wget切换到root身份,解压源代码到/usr/src目录下:#xz–dlinux-3.2.58.tar.xz#tar–xvflinux-3.2.58.tar–C/usr/src2.修改内核源代码,添加统计变量1、切换到预编译内核目录#cd/usr/src/linux-3.2.582、修改解决内存访问异常的代码//用vi编辑器打开fault.c,普通使用Intelx86体系构造,则修改arch/x86/目录下的文献#viarch/x86/mm/fault.c#cdarch/x86/mm#sudogeditfault.c//在do_page_fault函数的上一行定义统计缺页次数的全局变量pfcountunsignedlongvolatilepfcount;//将pfcount加入到do_page_fault中,用以统计缺页次数pfcount++;3、修改内存管理代码//用vi编辑器打开头文献mm.h#viinclude/linux/mm.h//在mm.h中加入全局变量pfcount的声明,代码加在externintpage_cluster;语句之后externunsignedlongvolatilepfcount;4、导出pfcount全局变量,让整个内核(涉及模块)都能够访问。办法是:#cdkernel#sudogeditkallsyms.c//在文献最后加入一行代码EXPORT_SYMBOL(pfcount);配备编译新内核用编译Linux内核预备实验中的办法完毕新内核的配备、编译、替代,重启后验证与否完毕替代。在编译内核前,普通来说都需要对内核进行对应的配备。配备是精确控制新内核功效的机会。配备过程也控制哪些需编译到内核的二进制映像中(在启动时被载入),哪些是需要时才装入的内核模块(module)。首先进入内核源代码目录:#cd/usr/src/linux-3.2.58如果不是第一次编译的话,有必要将内核源代码树置于一种完整和一致的状态。因此,推荐执行命令makemrproper。它将去除目录下全部配备文献和先前生成核心时产生的.o文献:#makemrproper(如果是第一次可跳过此步)然后配备编译选项(此处使用原内核的配备文献,完整的配备命令看操作提示):#cp/boot/config-3.2.0-20-generic-pae.config该命令的作用是将原内核配备文献拷贝的现在目录下,并命名为.config。若需要进一步修改配备请参考操作提示。在编译前用#uname-r查看原来的版本4.编译内核和模块编译内核,就用:#make编译内核需要较长的时间,具体与机器的硬件条件及内核的配备等因素有关(采用VMWare虚拟机,需要约60分钟)。完毕后产生的内核文献bzImage的位置在/usr/src/linux/arch/i386/boot目录下,固然这里假设顾客的CPU是Intelx86型的,并且你将内核源代码放在/usr/src/linux目录下。如果选择了可加载模块,编译完内核后,要对选择的模块进行编译,可用:#makemodules安装新内核模块和新内核首先,用下面的命令将新内核模块安装到系统的原则模块目录中:#makemodules_install此处有改动选择了取消然后,用下面的命令将新内核安装到系统中:#makeinstall普通,Linux在系统引导后从/boot目录下读取内核映像到内存中。因此如果想要使用自己编译的内核,就必须用makeinstall命令将启动文献(内核映像)安装到/boot目录下。6.编写读取pfcount值的模块代码系统重启后,执行以下操作:#mkdirsource//在现在顾客目录下创立source文献夹,用于寄存编写的顾客程序#cdsource//切换到source目录#vipf.c//新建用于构建模块的代码/*pf.c*//*modulesprogram*/#include<linux/init.h>#include<linux/module.h>#include<linux/kernel.h>#include<linux/mm.h>#include<linux/proc_fs.h>#include<linux/string.h>#include<asm/uaccess.h>structproc_dir_entry*proc_pf;structproc_dir_entry*proc_pfcount;externunsignedlongpfcount;staticinlinestructproc_dir_entry*proc_pf_create(constchar*name,mode_tmode,read_proc_t*get_info){returncreate_proc_read_entry(name,mode,proc_pf,get_info,NULL);}intget_pfcount(char*buffer,char**start,off_toffset,intlength,int*peof,void*data){intlen=0;len=sprintf(buffer,"%ld\n",pfcount);returnlen;}staticintpf_init(void){proc_pf=proc_mkdir("pf",0);proc_pf_create("pfcount",0,get_pfcount);return0;}staticvoidpf_exit(void){remove_proc_entry("pfcount",proc_pf);remove_proc_entry("pf",0);}module_init(pf_init);module_exit(pf_exit);MODULE_LICENSE("GPL");7编译、构建内核模块#viMakefile//在source目录下建立Makefile文献在Makefile中添加以下内容:obj-m:=pf.oifneq($(KERNELRELEASE),) obj-m:=pf.oelse KDIR:=/lib/modules/$(shelluname-r)/build PWD:=$(shellpwd)default: $(MAKE)-C$(KDIR)M=$(PWD)modulesclean: $(MAKE)-C$(KDIR)M=$(PWD)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论