《统计操作系统缺页次数》由会员分享,可在线阅读,更多相关《统计操作系统缺页次数(11页珍藏版)》请在人人文库网上搜索。

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

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

3、p:/www.kernel.org。在terminal下可以通过wget命令下载源代码:$ cd /tmp$ wget http:/www.kernel.org/pub/linux/kernel/v3.x/linux-3.2.58.tar.xz切换到root身份,解压源代码到/usr/src目录下:# xz d linux-3.2.58.tar.xz# tar xvf linux-3.2.58.tar C /usr/src2.修改内核源代码,添加统计变量1、切换到预编译内核目录#cd /usr/src/linux-3.2.582、修改处理内存访问异常的代码/用vi编辑器打开fault.c,一般。

4、使用Intel x86体系结构,则修改arch/x86/目录下的文件#vi arch/x86/mm/fault.c/在do_page_fault函数的上一行定义统计缺页次数的全局变量pfcountUnsigned long volatile pfcount;/将pfcount加入到do_page_fault中,用以统计缺页次数pfcount+;3、修改内存管理代码/用vi编辑器打开头文件mm.h#vi include/linux/mm.h/在mm.h中加入全局变量pfcount的声明,代码加在extern int page_cluster;语句之后extern unsigned long vo。

5、latile pfcount;4、导出pfcount全局变量,让整个内核(包括模块)都可以访问。方法是:#vi kernel/kallsyms.c/在文件最后加入一行代码EXPORT_SYMBOL(pfcount);3. 配置编译新内核在编译内核前,一般来说都需要对内核进行相应的配置。配置是精确控制新内核功能的机会。配置过程也控制哪些需编译到内核的二进制映像中(在启动时被载入),哪些是需要时才装入的内核模块(module)。首先进入内核源代码目录:# cd /usr/src/linux-3.2.58如果不是第一次编译的话,有必要将内核源代码树置于一种完整和一致的状态(如果是第一次可跳过此步)。。

6、因此,推荐执行命令make mrproper。它将清除目录下所有配置文件和先前生成核心时产生的.o文件:#make mrproper然后配置编译选项(此处使用原内核的配置文件,完整的配置命令看操作提示):# cp /boot/config-3.2.0-23-generic-pae .config该命令的作用是将原内核配置文件拷贝的当前目录下,并命名为.config。若需要进一步修改配置请参照操作提示。用编译Linux内核预备实验中的方法完成新内核的配置、编译、替换,重启后验证是否完成替换。#uname r /如果为3.2.58(与你采用的新内核版本一至)说明替换完成4.编写读取pfcount值。

7、的模块代码系统重启后,执行如下操作:cd /home/sa#mkdir source /在当前用户目录下创建source文件夹,用于存放编写的用户程序#cd source /切换到source目录#vi pf.c /新建用于构建模块的代码-/*pf.c*/ /*modules program*/#include #include #include #include #include #include #include struct proc_dir_entry *proc_pf; struct proc_dir_entry *proc_pfcount;extern unsigned long 。

8、volatile pfcount;static inline struct proc_dir_entry *proc_pf_create(const char* name, mode_t mode, read_proc_t * get_info)return create_proc_read_entry(name,mode,proc_pf,get_info,NULL);int get_pfcount(char *buffer, char *start, off_t offset, int length, int *peof, void *data)int len = 0;len = sprin。

9、tf(buffer, %ld n, pfcount);return len;static int pf_init(void)proc_pf = proc_mkdir(pf, 0);proc_pf_create(pfcount, 0, get_pfcount);return 0;static void pf_exit(void)remove_proc_entry(pfcount,proc_pf);remove_proc_entry(pf,0);module_init(pf_init);module_exit(pf_exit);MODULE_LICENSE(GPL);5. 编译、构建内核模块cd /home/sa/source#vi Makefile /在source目录下建立Makefile文件在Makefile中添加如下内容:obj-m := pf.o编译内核模块:make -C /usr/src/linux-3.2.58 SUBDIRS=/home/sa/source modules6. 加载模块到内核中执行加载模块命令:#insmod pf.ko查看统计缺页次数:#cat /proc/pf/pfcount (注:文档可能无法思考全面,请浏览后下载,供参考。可复制、编制,期待你的好评与关注。

Logo

鸿蒙生态一站式服务平台。

更多推荐