欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > PPTX文档下载  

    操作系统原理.pptx

    • 资源ID:353715       资源大小:149.70KB        全文页数:13页
    • 资源格式: PPTX        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    操作系统原理.pptx

    操作系统原理实验,四、虚拟内存,实验目的,理解EPOS内核的重定位理解虚拟内存的初始化过程掌握页表和页目录的构造掌握page fault的处理掌握物理内存的管理掌握页面置换算法,重定位EPOS内核,EPOS被链接到地址(3GB+1MB)从eposkrnl.map可知道(0 xc0100000=3GB+1MB)然而,EPOS被GRUB加载到物理地址为1MB的内存运行即链接地址加载地址因此,EPOS需要初始化虚拟内存,然后把自己重定位到链接的地址上去运行,重定位EPOS内核,思考题在初始化虚拟内存之前,不能访问任何(显式或隐式的)全局变量,但可以进行函数调用。为什么?例如,不能调用printk(“foo bar%d”,i),其中的字符串“foo bar%d”会被当作全局变量保存,初始化虚拟内存,ROM BIOS,EPOS,R(_end),FreeRAM,机器信息struct multiboot_info(multiboot.h),0 xA-0000,0 x10-0000,0,内核入口_entry(entry.S),GRUB加载EPOS之后、将控制传给EPOS之前的布局,RAM,ROM BIOS,EPOS,FreeRAM,A-0000,10-0000,0,Page dir.,20 Page tables,1023770769768767210,102310,102310,ROM BIOS,EPOS,ROM BIOS,EPOS,虚拟地址空间,C000-0000,0,FFFF-FFFF,Page dir.,20 Page tables,BFC0-0000,BFEF-F000,PT,PTD,physfree,static uint32_t init_paging(uint32_t physfree)uint32_t i,*pgdir,*pte;,pgdir=(uint32_t*)physfree;physfree+=PAGE_SIZE;memset(pgdir,0,PAGE_SIZE);,for(i=0;i PGDR_SHIFT)/*768*/=physfree|PTE_V|PTE_RW;memset(void*)physfree,0,PAGE_SIZE);physfree+=PAGE_SIZE;,pte=(uint32_t*)(PAGE_TRUNCATE(pgdir0);for(i=0;i PAGE_SHIFT=(i)|PTE_V|PTE_RW;,pgdir(KERNBASEPGDR_SHIFT)-1=(uint32_t)(pgdir)|PTE_V|PTE_RW;,pgdir,_asm_ _volatile_(movl%0,%eaxnt movl%eax,%cr3nt movl%cr0,%eaxnt orl$0 x80000000,%eaxnt movl%eax,%cr0nt“:m(pgdir):%eax”);return physfree;,void cstart(uint32_t magic,uint32_t addr)if(77)uint32_t i;for(i=0;i NR_KERN_PAGETABLE/*20*/;i+)PTDi=0;invltlb();/*refresh TLB*/,物理地址空间,BFF0-0000,20 Page tables,ROM BIOS,EPOS,虚拟地址空间,C000-0000,0,FFFF-FFFF,Page dir.,20 Page tables,BFC0-0000,BFEF-F000,PT,PTD,ROM BIOS,EPOS,FreeRAM,A-0000,10-0000,0,Page dir.,20 Page tables,物理地址空间,void cstart(uint32_t magic,uint32_t addr)if(78)/reserve and commit freemap if(79)/reserve kernel heap for kmalloc/kfree,freemap,freemap,Kernel heap,freemap用于管理空闲的物理内存,一个页面用一个字节来记录,0表示空闲,非0表示已被占用。,内核堆(kernel heap)用于内核运行过程中内存的动态分配(kmalloc)与回收(kfree)。,BFF0-0000,初始化虚拟内存系统,思考题对于freemap,不仅为它保留了地址空间,而且映射到了物理内存。而对于内核堆(kernel heap),为什么只保留了地址空间,并未映射到物理内存?,处理Page Fault,int do_page_fault(struct context*ctx,uint32_t vaddr,uint32_t code)-page.cctx 发生page fault时的现场vaddr 触发page fault的虚拟地址code page fault异常代码,如下图所示,处理Page Fault,思考题阅读page.c中的函数do_page_fault,理解page fault的处理流程和方法。提示:虚拟地址空间中最低的4MB被保留作为NULL指针vtopte(vaddr):是一个宏定义,用于获取虚拟地址vaddr对应的页表项(PTE)的指针invlpg:invalidate TLB entry,ROM BIOS,EPOS,虚拟地址空间,C000-0000,0,FFFF-FFFF,Page dir.,BFC0-0000,BFEF-F000,USER_MAX_ADDR,KERN_MIN_ADDR,freemap,Kernel heap,400-0000,NULL,USER_MIN_ADDR,KERN_MAX_ADDR,20 Page tables,BFF0-0000,实验内容,增加两个系统调用,获取系统的ticksticks记录了EPOS启动以来定时器中断的次数,可以用于粗略的计时请参考timer.c获取系统已经触发的page fault的次数自行实现在app/main.c中创建一个新线程tsk_loop为tsk_loop申请5MB的栈在tsk_loop中,定义局部变量int arr10241024sizeof(arr)=sizeof(int)*1024*1024=4MB;,实验内容,tsk_loop分别执行如下两个循环for(i=0;i 1024;i+)for(j=0;j 1024;j+)arrij=i-j;for(j=0;j 1024;j+)for(i=0;i 1024;i+)arrij=i-j;比较两个循环的执行时间和触发的page fault次数注意在循环体的后面,必须得引用数组arr里面的某个元素,以避免编译器把局部变量arr优化掉!线程函数的最后,一定要调用task_exit,不能直接return!,Thats allEnjoy hacking,

    注意事项

    本文(操作系统原理.pptx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开