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

下载本文档

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

文档简介

1、实验四-统计缺页次数实验四统计操作系统缺页次数实验目的学习虚拟内存的基本原理和Linux虚拟内存管理技术;深入理解、掌握Linux的按需调页过程;掌握内核模块的概念和操作方法,和向/proc文件系统中增加文件的方法;综合运用内存管理、系统调用、proc文件系统、内核编译的知识。1. 实验内容原理Linux的虚拟内存技术采用按需调页,当CP请求一个不在内存中的页面时,会发生缺页,缺页被定义为一种异常(缺页异常),会触发缺页中断处理流程。每种CPU结构都提供一个do_page_fault处理缺页中断。由于每发生一次缺页都要进入缺页中断服务函数do_page_fault一次,所以可以认为执行该函数的

2、次数就是系统发生缺页的次数。因此可以定义一个全局变量pfcount作为计数变量,在执行do_page_fault时,该变量值加1。本实验通过动态加载模块的方法,利用/proc文件系统作为中介来获取该值实验环境操作系统:Ubuntu12.04(内核版本为3.2.0-23-generic-pae)内核源码:linux-3.2.581. 实验指导下载一份内核源代码并解压Linux受GNU通用公共许可证(GPL)保护,其内核源代码是完全开放的。现在很多Linux的网站都提供内核代码的下载。推荐使用Linux的官方网站:。图1Linux的官方网站在terminal

3、下可以通过wget命令下载源代码:$cd/tmpwgethttp:/www.kernel.0rg/pub/linux/kernel/v3.x/linux-3.2.5.tar.xz切换到root身份,解压源代码到/usr/src目录下:# xz-dlinux-3.2.58.tar.xz2. tar水vflinux-3.2.58.tarC/usr/src修改内核源代码,添加统计变量1、切换到预编译内核目录#cd/usr/src/linux-3.2.582、修改处理内存访问异常的代码用vi编辑器打开fault.c,一般使用Intelx86体系结构,则修改arch/x86/目录下的文件#viarch/

4、x86/mm/fault.c#cdarch/x86/mm#sudogeditfault.cin:/usr/src/linux-3*2.74/include/linuxftcdlu:/usr/src/1tnux-3.2.1A/tncludeircdarch/xse/nn.arch/jfSC/nn:hosuchfileordirectoryt(j:/usr/src/ltnux-3*.74/include#cd/arch/x&fiymh*-/arch/x86/niFiiNeusuchfileordirectoryIin:/us/src/linux-3*2.74/include#cdarch:arch

5、:NosuchfileordtrecLary;u;/usrysrc/linux-3*2.74/include#cd/archI:/archiMosuchftLeordirectory.u:/usr/src/lLnux-2.2.74/tncludeJtcdzu:/usr/src/linux-3.2.74#cdarch/xHt/nli:/usr/src/linuKzu:/usr/src/linux-3.2.7/arch/xfitj/nn#Eudogedltfault.l*2.2.74/arrh/xS6/nn#|unsignedlongvolatticpfcount;dotrapllnkagevoi

6、d_kprobesubuntuoneIstructed_struct*vfij;structtask_struct*tsk;unsignedlongaddress;structm_structfault;Litte二errormdedo_pd0日_fAultrnetpt_regs*regsFurisignedlongerrorcixje)PFWRITE;unsignedtntflags=FAULT_FLAC_ALLOW_RCTRy|FflULT_FLAG_KILLABLE|(write?FAULI_FLAG_WR1TE:0);tsk-current;ee二在do_page_fault函数的上一

7、行定义统计缺页次数的全局变量pfcountunsignedlongvolatilepfcount;/将pfcount加入到do_page_fault中,用以统计缺页次数pfcount+;3、修改内存管理代码/用vi编辑器打开头文件mm.hIva_l*yout0胃EUL】tfdrfinerth_pagppagepfn_to_page(ppge_to_pfn(piignj)十(n)ftleordirectoryioe*l$blnm&r七Linux3.2.T4ubuntuSofLWdieCenterircludecasn/paq褚*hrtncludcncludtasi/proc#11;,hce*十c

8、ki-rt4-hoZ)njawfXSLCT11OTTSTTyTTETltUlTyiLCTLcLe!E_|Jgu*externvoid*htghnenory;externintpageclusterjexternunsignedtongvolatilepfcountj*ifdefCONFIG_SYSCTLexternIntsysctllegdcyvdIdyout;也L八_suchfilerdirectory;U:u:/usrPcd/src/Iinux3*274:/src/tiriJX-3.2.74:Ho:u:/usrffcd/srt:/src:Nosuch.ui/usr#Is%tflelndel

9、ib.d:/usr#cdsrc:ui/usr/srcMcd:u:/usr/src/llnux-3.2.74#cdinclude/linux:u:/uir/trc/llnux-32T4/UKlue/llnuxffsudogedtt|WJ/r$r$rjllnux”32八liux#viinclude/linux/mm.h/在mm.h中加入全局变量pfcount的声明,代码加在externintpage_cluster;语句之后externunsignedlongvolatilepfcount;4、导出pfcount全局变量,让整个内核(包括模块)都可以访问。方法是:#cdkernel#sudoged

10、itkallsyms.c在文件最后加入一行代码EXPORT_SYMBOL(pfcount);7U:/U5r/src/ltnui3,2,74#cdkernel:u:/usr/src/Iinux3,2.74/kernel#sudogedttIcallsyns,cTu:/us/sc,ltnux=3.Z.T4/kmneUytfendtf/*CONFIC_KGDB_KDB*/LibreOffceImpress.open=K3ead=seqreadfftle_operationsllsynsopen,kallsynsopeatlong*llseek=seqIseek(,release=&eq_rele3s

11、e_privatef1;stattctitinttkallsynstntt(votd)riproccreatefkails/nsw,0444,null,akallsynsoperations);return0;deviceiniteal1(kaXlsynsinit);EXPORTS/HBOL(pfCOUnt):3. 配置编译新内核用编译Linux内核预备实验中的方法完成新内核的配置、编译、替换,重启后验证是否完成替换。在编译内核前,一般来说都需要对内核进行相应的配置。配置是精确控制新内核功能的机会。配置过程也控制哪些需编译到内核的二进制映像中(在启动时被载入),哪些是需要时才装入的内核模块(m

12、odule)。首先进入内核源代码目录:#cd/usr/src/linux-3.2.58如果不是第一次编译的话,有必要将内核源代码树置于一种完整和一致的状态。因此,推荐执行命令makemrproper。它将清除目录下所有配置文件和先前生成核心时产生的.o文件:#makemrproper(如果是第一次可跳过此步)然后配置编译选项(此处使用原内核的配置文件,完整的配置命令看操作提示):#cp/boot/config-3.2.0-20-generic-pae.config该命令的作用是将原内核配置文件拷贝的当前目录下,并命名为.config。若需要进一步修改配置请参照操作提示。ctubuntu:/us

13、r/src/linjx-3.2*71#cp/boot/conftg-3.2*0-26generic-pae*con在编译前用#uname-r查看原来的版本4. rootuburtu:/ituname-r3.2*0-20generic-paeAuhnntm*fit|编译内核和模块编译内核,就用:#make编译内核需要较长的时间,具体与机器的硬件条件及内核的配置等因素有关(采用VMWare虚拟机,需要约60分钟)。完成后产生的内核文件bzImage的位置在/usr/src/linux/arch/i386/boot目录下,当然这里假设用户的CPU是Intelx86型的,并且你将内核源代码放在/usr

14、/src/linux目录下。如果选择了可加载模块,编译完内核后,要对选择的模块进行编译,可用:#makemodules安装新内核模块和新内核首先统的标准彳映命令将新内核模块安装到系#makemodules_installH161QFWftrrwarp/edgeport/dnwn.fwH16T0FWfbrwcjre/edgeport/downZ.fwIHEXfi.rmwdre/edgepart/d0wn3.binIHEX2FWfirnware/whiteheatlooderfwIHEX2FWfirrware/whtteheatfwIHEX2FUfIrrware/ke/spanpda/keyspa

15、npda.fw1HEJ(2FWftrrware/ke/spdn_pdd/xtrcom_pgs,fwIHEXfIrnwdie/cpLaZ/stvO672_vp4blnIHEXfitnwdrt?/ydfl/1200lq.u胃i-l-T/gi-kjfqlJmi-Lfr*-HIITLnfFc-b日.】jEJl*irwi】Ti-f通常,Linux在系统引导后从/boot目录下读取内核映像到内存中。因此如果想要使用自己编译的内核,就必须用makeinstall命令将启动文件(内核映像)安装到/boot目录下。6.编写读取pfcount值的模块代码系统重启后,执行如下操作:#cdsource/切换至Usou

16、rce#vipf.c码/新建用于构建模块的代#mkdirsource/在当前用户目录下创建source文件夹,用于存放编写的用户程序目录/*pf.c*/*modulesprogram*/#include#include#include#include#include#include#includestructproc_dir_entry*proc_pf;structproc_dir_entry*proc_pfcount;externunsignedlongpfcount;staticinlinestructproc_dir_entry*proc_pf_create(constchar*name

17、,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*peofvoid*data)(intlen=0;len=sprintf(buffer,%ldn,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目录下建立冰即Okefile中添加如下内容:obj-m:=pf.oifneq($(KERNELRELEASE),)obj-m:=pf.oelseKDIR:=/lib/modules/

温馨提示

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

评论

0/150

提交评论