OS-lab2

启动之后,我们的操作系统要能运行,需要一个载体,就是内存。内存的访问不是直接的,而是通过MMU完成。在完成MMU之前,我们先看看一些需要用到的宏定义和函数。

include

  • pmap.h

    定义了内存控制块Page结构体,用于记录页面的分配和使用情况。其中pp_link有两个成员,*le_next用于指向下一个元素,le_prev用于指向前一个元素的**le_next的地址。pp_ref用于记录页面被引用的次数。

    page2pa函数通过给定的Page控制块计算对应的页面的物理地址。

    page2ppn函数通过给定的Page控制块计算这个页面控制块在整个页面控制块数组中的下标。

    pa2page函数通过给定的物理地址计算对应的页面控制块。

    page2kva函数通过给定的Page控制块计算计算这个页面对应的内核虚地址。

    va2pa函数通过给定的页目录和虚拟地址计算对应的物理地址。

    此外还声明了pmap.c中的一些函数。

  • queue.h

    通过宏定义定义了关于链表的一些操作,如初始化、插入删除等。

  • mmu.h

    定义了一系列变量如页面大小BY2PG、标志位PTE_V等。PDX(va)用于获得虚拟地址的高10位,PTX(va)类似。PADDR(kva)用于将内核虚拟地址转化为物理地址,KADDR正好相反。PTE_ADDR用于获得页表项存储的物理地址。

现在,我们一步一步实现MMU。

mm

  • pmap.c

    这个文件集合了管理内存的大部分函数。其中*pages是页面控制块数组,freemem是空闲内存的地址。

    mips_detect_memory函数手动给basememmaxpanpage等全局变量进行了赋值。

    *alloc函数手动分配n字节的空闲内存。具体思路即修改freemem的值,然后将alooced_mem清零后返回这个地址。

    *boot_pgdir_walk函数用于获取对应虚拟地址对应的二级页表项。具体流程是通过页目录找到页目录项地址;将页目录项的值转为虚拟地址;检查是否存在,若不存在且create为1,就分配一页,并给对应的页表项赋上标志位;然后再求得对应二级页表项的虚拟地址并返回。

    boot_map_segment函数用于将size大小的虚拟地址区间映射到size大小的物理地址区间。首先将sizeBY2PG取整;然后以页为单位,利用*boot_pgdir_walk获得每一页的页表项,再将物理地址和对应的标志位赋给对应的页表项,完成映射。

    mips_vm_init函数完成初始的建立两级页表的任务。首先是用alloc函数分配一页给页目录;然后分配npagePagepages数组,用于管理页面;再将pages数组这片区域映射到物理内存;类似的,分配空间给envs进程控制块数组,并映射到对应的物理内存区域。

    以上都是在启动过程中完成的操作。核心是mips_vm_init函数。

    page_init函数用于初始化pages数组并设置page_free_list数组。首先用LIST_INIT函数初始化page_free_list;然后通过freememend求得已经分配了多少空闲内存;将已分配的内存即freemem以下的内存以页为单位,通过修改pp_ref为1的方式记录下来;剩下的内存即freemem以上的内存则将pp_ref记为0,并利用LIST_INSERT_HEAD加入到page_free_list中。

    page_alloc函数用于分配一页物理内存。首先需要检查是否存在空闲内存,即利用LIST_EMPTY检查page_free_list是否为空;然后取出第一项并在链表中删掉这一项;最后将这一项对应的内存清零后返回这一页面控制块。

    page_free函数用来释放一页内存。当pp_ref为0时将这一页利用LIST_INSERT_HEAD加入到page_free_list中。

    pgdir_walk函数类似boot_pgdir_walk函数,基本思路一样。区别在于,pgdir_walk函数是在启动之后,所以在需要创建新页表的时候可以使用page_alloc函数,并且分配后将对应的pp_ref增加。boot_pgdir_walk函数由于没有建立页表映射机制,对于pp_ref是无法操作的。

    page_insert函数用于将物理页映射到特定虚拟地址。首先利用pgdir_walk函数取得虚拟地址va的页表项;检查这一页表项是否已经对应到了指定页面上,若页表项不为空且已经映射到了指定页面,则利用tlb_invalidate更新tlb,然后给对应的页表项赋值并返回;若这一页表项不为空且映射的页面不是指定页面,则需要用page_remove将这一虚拟地址对应的页面移除;然后利用tlb_invalidate更新tlb;再一次利用pgdir_walk函数取得页表项,对这一页表项赋值并增加pp_ref

    page_lookup函数用于获得虚拟地址对应的Page和页表项。首先通过pgdir_walk得到虚拟地址对应的页表项;如果页表项为空或页表项有效位为0则返回;然后通过pa2page得到Page

    page_decref函数用于减少pp_ref

    page_remove函数用于移除物理页面到虚拟地址的映射。首先利用page_lookup获得Page和对应的页表项;减少pp_ref,若pp_ref为0则需要用page_free释放掉这一物理页;将页表项清零,并用tlb_invalidate更新tlb。

    tlb_invalidate函数用于使虚拟地址对应的tlb表项失效,而下次访问这个地址就会触发tlb充填,完成对tlb的更新。核心是调用tlb_out函数。

    剩下的三个函数physical_memory_manage_checkpage_checkpageout用于检查以上的内存管理函数功能是否正确。

  • tlb_asm.S

    这个文件用于处理tlb更新,即tlb_out函数。首先将CP0_ENTRYHI寄存器的值取出来,将虚拟地址写入;通过tlbp查找与CP0_ENTRYHI内容匹配的页表项并写入CP0_INDEX,由于tlb内部采用流水线设计,因此这条指令后需要执行nop;若找到则将CP0_ENTRYHICP0_ENTRYLO0清零,这样在未来对这一虚拟地址进行访问就会诱发tlb充填;利用tlbwi根据CP0_INDEX写tlb,然后恢复CP0_ENTRYHI;若没找到则将CP0_ENTRYHI恢复为原来的值并返回。

OS-lab2的更多相关文章

  1. 【bug记录】OS Lab3 踩坑记

    OS Lab3 踩坑记 Lab3在之前Lab2的基础上,增加了进程建立.调度和中断异常处理.其中测试包括进程建立以及进程调度部分. 由于是第一次做bug记录,而且是调试完bug后再做的记录,所以导致记 ...

  2. OS课程 ucore_lab2实验报告

    练习零:填写已有实验    本实验依赖实验1.请把你做的实验1的代码填入本实验中代码中有"LAB1"的注释相应部分.提示:可采用diff和patch工具进行半自动的合并(merge ...

  3. ucore操作系统学习笔记(二) ucore lab2物理内存管理分析

    一.lab2物理内存管理介绍 操作系统的一个主要职责是管理硬件资源,并向应用程序提供具有良好抽象的接口来使用这些资源. 而内存作为重要的计算机硬件资源,也必然需要被操作系统统一的管理.最初没有操作系统 ...

  4. CMU15-455 Lab2 - task4 Concurrency Index -并发B+树索引算法的实现

    最近在做 CMU-15-445 Database System,lab2 是需要完成一个支持并发操作的B+树,最后一部分的 Task4 是完成并发的索引这里对这部分加锁的思路和完成做一个总结,关于 B ...

  5. [OS] 操作系统课程(三)

    工具 源码阅读:understand 源码文档自动生成工具:Doxygen 编译环境:gcc 运行环境:x86机器或QEMU 调试工具:QEMU+(GDB or IDE) IDE:Eclipse-CD ...

  6. MIT6.828 Lab2 内存管理

    Lab2 0. 任务介绍 你将编写一个内存管理代码.主要分为两大部分.分别对物理内存和虚拟内存的管理. 对于物理内存,每次分配内存分配器会为你分配4096bytes.也称为一个页(在大部分操作系统中一 ...

  7. NodeJs之OS

    OS Node.js提供了一些基本的底层操作系统的模块OS. API var os = require('os'); console.log('[arch] 操作系统CPU架构'+os.arch()) ...

  8. Node.js:OS模块

    os模块,可以用来获取操作系统相关的信息和机器物理信息,例如操作系统平台,内核,cpu架构,内存,cpu,网卡等信息. 使用如下所示: const os = require('os'); var de ...

  9. Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验

    Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...

  10. Mac OS 使用 Vagrant 管理虚拟机(VirtualBox)

    Vagrant(官网.github)是一款构建虚拟开发环境的工具,支持 Window,Linux,Mac OS,Vagrant 中的 Boxes 概念类似于 Docker(实质是不同的),你可以把它看 ...

随机推荐

  1. 新版Bing 搜索后台的.NET 技术栈

    微软在今天在Redmond 线下举办媒体一场活动,发布了新版的微软必应,在桌面上推出了测试版,移动版也即将推出.微软首席执行官纳德拉称Al-powered搜索为公司自云15年以来最大的事情. 2023 ...

  2. PDF-XChange Editor

    软件简介 PDF-XChange Editor官方版是PDF-XChange的增强版本编辑器,软件完全绿色免费,且功能无限制.PDF-XChange Editor官方版主要提供PDF电子文档的编辑功能 ...

  3. [java安全基础 02]反射

    java反射 这一篇和上一篇对不上,这里是补一下java反射知识点 一个需求引出反射 请根据配置文件re.properties指定信息,创建Cat对象并调用方法hi classfullpath=com ...

  4. [清华集训2016] Alice 和 Bob 又在玩游戏

    \(\text{Solution}\) 第一道有向图 \(SG\) 函数的博弈论 有根树,设 \(f[x]\) 表示以 \(x\) 为根子树的 \(SG\) 值 对于分裂的图的 \(SG\) 值为每个 ...

  5. JavaSE 对象与类(一)

    对象与类 1.面向对象程序概述 Java是完全面向对象的,必须熟悉OOP才能够编写Java程序. 概念:类class.实例(对象)instance 由类构造(construct)对象的过程称为创建类的 ...

  6. Android:Banner 和 Glide 在 Fragment 中实现轮播图

    添加依赖信息 引入 Banner 和 Glide 依赖信息: dependencies { implementation 'io.github.youth5201314:banner:2.2.2' i ...

  7. kali日常快捷命令(用到就更新)

    什么BASH命令? 在Linux上采用bash作为标准,基本上它描述了对带有".sh"扩展名的vi编辑器等文本的处理并执行. 与编程一样,它有许多函数,如变量,函数和算术处理,所以 ...

  8. form表单enctype扩展

    enctype就是encodetype就是编码类型的意思. multipart/form-data是指表单数据有多部分构成,既有文本数据,又有文件等二进制数据的意思. 需要注意的是:默认情况下,enc ...

  9. 【博图scl语言】313-2dp

    ①如果 if(***) then *** := ***; end_if; ②循环 for n1:=1 to 50 by 1 do end_for; WHILE #n1 < 54 DO END_W ...

  10. 第四周作业-N67044-张铭扬

    1. 自定义写出10个定时任务的示例:比如每周三凌晨三点执行data命令要求尽量的覆盖各种场景 1)每天早上8点对磁盘使用率进行查看,若超出空间的80%,则发邮件报警 [root@centos8 ~] ...