模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

实验二模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断1、实验目的1)理解页式虚拟存储管理中的地址转换。2)理解用先进先出调度算法如何处理缺页中断。2、实验原理在页式虚拟存储管理中,如果访问的页面在内存,计算出相应的物理地址,如果访问的页面不在内存,产生缺页中断,将所缺页从外存调入,如果内存没有空间需要将内存的一页淘汰,再将所缺页调入,然后计算出相应的物理地址。3、实验仪器设备微型计算机、VisualC++开发软件4、实验内容与步骤编写程序,模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断。假定主存的每块长度为1024个字节,现有一个共7页的作业,其副本已在磁盘上。系统为该作业分配了4个主存块,且该作业的第0页至第3页已经装入主存,其余3页尚未装入主存,该作业的页表见下表。页号标志主存块号修改标志在磁盘上的位置0150010118001221900133110021400022500023600125实验步骤1)输入程序2)如果该作业执行的指令序列如下表所示:操作页号页内地址操作页号页内地址+0072+40565+1050—5023╳2015存(save)1037存(save)3026+2078取(load)0056—4001—6040存(save)6086执行上述的指令序列来调试你所设计的程序(仅模拟指令的执行,不必考虑指令序列中具体操作的执行)5、预习及实验报告要求预习页式虚拟存储管理中地址转换和页面置换算法的有关内容。实验报告要求写出程序的源代码及运行结果。分析:主存块有4个,物理地址=块号*块长(这里是1024)+块内地址(块内地址=页内地址),若页号不在主存中,则产生缺页中断,根据先进先出原则,今要执行的页号置换最先进入主存的页号,计算得到如下值:5192,8242,9231,1050,5176,5160,8248,9239,1061,5198,8193,8278012306451246000006666222111111444446222222255555333333331111#definesize1024//定义块的大小,本次模拟设为1024个字节。#includestdio.h#includestring.h#includeconio.hstructplist{intnumber;//页号intflag;//标志,如为1表示该页已调入主存,如为0则还没调入。intblock;//主存块号,表示该页在主存中的位置。intmodify;//修改标志,如在主存中修改过该页的内容则设为1,反之设为0intlocation;//在磁盘上的位置};//模拟之前初始化一个页表。structplistp1[7]={{0,1,5,0,010},{1,1,8,0,012},{2,1,9,0,013},{3,1,1,0,021},{4,0,-1,0,022},{5,0,-1,0,023},{6,0,-1,0,125}};//命令结构,包括操作符,页号,页内偏移地址。structilist{charoperation[10];intpagenumber;intaddress;};//在模拟之前初始化一个命令表,通过程序可以让其顺序执行。structilistp2[12]={{+,0,72},{5+,1,50},{*,2,15},{save,3,26},{load,0,56},{-,6,40},{+,4,56},{-,5,23},{save,1,37},{+,2,78},{-,4,1},{save,6,86}};main(){printf(模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断\n);inti,lpage,pflage,replacedpage,pmodify;intp[4]={0,1,2,3};intk=0;intm=4;longmemaddress;for(i=0;i12;i++)//作业执行指令序列,12个{lpage=p2[i].pagenumber;//获取页号pflage=p1[lpage].flag;//标志,是否在内存中printf(%s,%d,%d,p2[i].operation,p2[i].pagenumber,p2[i].address);printf(在主存块%d中执行,lpage);if(pflage==0)//如果页面不在内存中{printf(把页号%d,lpage);//置换replacedpage=p[k];pmodify=p1[replacedpage].modify;if(pmodify==1)printf(***放在页号%d的位置,replacedpage);elseprintf(放在页号%d的位置执行,replacedpage);p[k]=lpage;k=(k+1)%m;p1[lpage].flag=1;//标志位改为1p1[lpage].block=p1[replacedpage].block;p1[replacedpage].block=-1;p1[replacedpage].flag=0;p1[replacedpage].modify=0;}memaddress=p1[lpage].block*size+p2[i].address;if(p2[i].operation==save)p1[lpage].modify=1;printf(\n物理地址为%ld\n,memaddress);}}

1 / 4
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功