当前位置: 首页 > news >正文

课堂练习4.4:页式虚存

4-7 课堂练习4.4:页式虚存

缺页异常在 Linux 内核处理中占有非常重要的位置,很多 Linux 特性,如写时复制,页框延迟分配,内存回收中的磁盘和内存交换,都需要借助缺页异常来进行。 本实训分析 Linux 0.11 的缺页处理机制。

bf52bde3c6254a1481868f1b1d2b5589.png

 

第1关版本 0 内核的第一次缺页页故障

任务描述

本关任务:分析版本 0 内核的第一次缺页页故障,回答下列问题: 1.该页故障由几号进程引发? 2.在该故障发生前,该进程执行的最后一个可执行文件是什么?该可执行文件的第 2 块(每块 1KB )的头 16 字节的内容是什么? 3.引发该页故障的线性地址是什么?该进程的代码段起始地址是多少? 4.该页故障处理前,该线性地址对应的页目录项的地址和值分别是什么? 5.该页故障处理时,申请到的空闲页帧的起始地址是什么?该页帧的头 16 字节的内容是什么? 6.该页故障处理过程中、读入硬盘数据后,上述页帧的头 16 字节的内容是什么? 7.该页故障处理过程中、修改对应的页表项后,上述线性地址对应的页表项的值是什么?

相关知识

为了完成本关任务,你需要掌握: 1.如何跟踪到缺页页故障的发生; 2.如何跟踪可执行文件的执行; 3.如何显示 bochs 虚拟机硬盘中某个可执行文件的内容; 4.在 gdb 中如何知道引发缺页页故障的线性地址是多少; 5.函数 do_no_page 的处理过程是怎样的; 6.在 gdb 中如何查看当前进程的(用户)代码段的起始地址; 7.如何分析线性地址空间到物理地址空间的映射关系; 8.如何计算一个线性地址对应的物理地址; 9.如何计算一个线性地址的高 10 位和中间 10 位的值; 10.页目录项和页表项的格式是什么; 11.如何查看某个页目录项的值; 12.在 gdb 调试时,如何知道某页帧的头 16 字节的内容。

实验准备

本关卡使用版本 0 内核进行分析,内核文件为 ~/os/linux-0.11-lab/0

编程要求

分析版本 0 内核的第一次缺页页故障,回答下列问题:将第一关答案填写在/data/workspace/myshixun/第一关.txt 1.该页故障由几号进程引发? 2.在该故障发生前,该进程执行的最后一个可执行文件是什么?该可执行文件的第 2 块(每块 1KB )的头 16 字节的内容是什么? 3.引发该页故障的线性地址是什么?该进程的代码段起始地址是多少? 4.该页故障处理前,该线性地址对应的页目录项的地址和值分别是什么? 5.该页故障处理时,申请到的空闲页帧的起始地址是什么?该页帧的头 16 字节的内容是什么? 6.该页故障处理过程中、读入硬盘数据后,上述页帧的头 16 字节的内容是什么? 7.该页故障处理过程中、修改对应的页表项后,上述线性地址对应的页表项的值是什么?

实验过程及答案

实验过程

默认为0内核所以本次不需额外配置

cd os/linux-0.11-lab
./rungdb

7d11d3027c154dcd98e98cbf444fee29.png23f0bde27ee344dd940cda4d4cb7acf8.png

另开一个终端

cd os/linux-0.11-lab
./mygdb

164f5c0adaf1445daea419b6f8c24e68.png

595a8dfc2b004bf288dfaefc2e4d503e.png2c41108ff95646239a20b0fbe0d9cbec.png

3478ab99bd0c42e7bbbca194b39d21a1.png14f5ccebe82f48ee85dc8fc9709f221b.png

[/usr/root]hexdump /bin/sh | less

b0a766ccd6e24bb69f8a62c4c8e9af5a.png

输入q退出

90982977e9cc4b85abb72a6c05cd0151.png

再次进入gdb调试

 92c5f38d933d47c187d525d65dcabbb6.pngf7a9d05576144da5bc0a7a06049d76d2.png67241350dbc44fdfbeda51951f7c6e67.png32f4a43365404ba09f4958614e0eb80a.png04c9f4d9edfc4ee89da6653b727cd5e6.png0ed828d08c484ce9976018bbee7bfa90.pngf57ec48df2ad4631b5fb0c3078ec5385.pnge939691b8d614f37a8b309c8a9234a7b.png1843d36b02c74355a9db7da33c25797d.png

答案

c71f6a8570d04ee8998c98d5fcc10a2d.png

 

 

第2关第一次使用零页的缺页页故障

任务描述

本关任务回答问题:在版本 0 内核中处理第一次使用零页的缺页页故障时: 1.该页故障由几号进程引发? 2.在该故障发生前,该进程执行的最后一个可执行文件是什么?该可执行文件的未初始化数据段( BSS )的起始虚拟地址( VMA )是什么? 3.引发该页故障的线性地址是什么? 4.该页故障处理前,该线性地址对应的页表项的地址和值分别是什么? 5.该页故障处理后,上述线性地址对应的页表项的值是什么?该线性地址被映射到的零页(新页帧)的起始地址是什么? 6.该新页帧的头 16 个字节是什么?

相关知识

为了完成本关任务,你需要掌握: 1.如何跟踪到缺页页故障的发生; 2.如何跟踪可执行文件的执行; 3.如何分析一个可执行文件的结构和指令; 4.如何将文件放入 bochs 虚拟机; 5.在 bochs 虚拟机中如何编辑文件; 6.如何将一个文件从 bochs 虚拟机拷入 Ubuntu 容器; 7.在 gdb 中如何知道引发缺页页故障的线性地址是多少; 8.函数 do_no_page 的处理过程是怎样的; 9.在 gdb 中如何查看当前进程的(用户)代码段的起始地址; 10.如何分析线性地址空间到物理地址空间的映射关系; 11.如何计算一个线性地址对应的物理地址; 12.如何计算一个线性地址的高 10 位和中间 10 位的值; 13.页目录项和页表项的格式是什么; 14.如何查看某个页目录项的值; 15.在 gdb 调试时,如何知道某页帧的头 16 字节的内容。

实验准备

本关卡使用版本 0 内核进行分析。

编程要求

本关任务回答问题:在版本 0 内核中处理第一次使用零页的缺页页故障时: 1.该页故障由几号进程引发? 2.在该故障发生前,该进程执行的最后一个可执行文件是什么?该可执行文件的未初始化数据段( BSS )的起始虚拟地址( VMA )是什么? 3.引发该页故障的线性地址是什么? 4.该页故障处理前,该线性地址对应的页表项的地址和值分别是什么? 5.该页故障处理后,上述线性地址对应的页表项的值是什么?该线性地址被映射到的零页(新页帧)的起始地址是什么? 6.该新页帧的头 16 个字节是什么?

实验过程及答案

实验过程

默认为0内核所以本次不需额外配置

cd os/linux-0.11-lab
./rungdb

7d11d3027c154dcd98e98cbf444fee29.png23f0bde27ee344dd940cda4d4cb7acf8.png

另开一个终端

cd os/linux-0.11-lab
./mygdb

164f5c0adaf1445daea419b6f8c24e68.png

 

00292f2ef59b4028b8f1dd17e19d5f0e.png34314bb29f554882af5bb0eae741ce57.png

 

进入虚拟机

d22e948b869545a78b756ca097530265.png6aa01fc1dc334388af8bacd3d42bb188.pngf8adb96a5c964969b42ddfc27c7ad288.pngaa46b33c84d24f97aa5f2306839044eb.png

点yes

7d61c4d4cde44009bd0c003705bcbd52.pnga25f5412970246beba2562a04d3a3ebd.png

eba56e8e6fd74751bcdd5b1dc1cfda34.png

然后一直c,直到第一次跳到376行

2335ecb7dbbe45e08ba97dfab4c44aec.pngb7fdcc73eedf4ecda032dcba20e26c9b.pngc4d9bc00e1f24b619de61a4599c0e02c.png96e90639ab8a470bae58974a6479cf0f.png8f5a4daa2c3b4006b27ad53275d9d396.pngf5b820b6dafe41d2be7af0a0eff6ab47.png

答案

3016fe6f64024d96910d8fdbd0ed53ca.png

4-8 课堂练习4.4:页式虚存

缺页异常在 Linux 内核处理中占有非常重要的位置,很多 Linux 特性,如写时复制,页框延迟分配,内存回收中的磁盘和内存交换,都需要借助缺页异常来进行。 本实训分析 Linux 0.11 的缺页处理机制。

 

第1关可执行文件的执行

任务描述

本关任务:在 bochs 虚拟机中编译程序 01.c ,可以得到一个可执行文件。请分析该程序的运行,回答下列问题: 1.执行该文件的 execve 系统调用刚开始执行时,当前进程的用户虚空间是什么?该空间的第一个页表项和最后一个页表项分别是什么? 2.执行该文件的 execve 系统调用执行结束时,该进程的用户虚空间是什么?该空间占据几个页目录项?第一个页目录项的地址和值分别是什么? 3.该可执行文件的代码段和数据段的长度之和是多少?

相关知识

为了完成本关任务,你需要掌握: 1.如何跟踪可执行文件的执行; 2.如何确定一个进程的用户虚空间范围; 3.如何分析一个可执行文件的结构和指令; 4.如何将文件放入 bochs 虚拟机; 5.在 bochs 虚拟机中如何编辑文件; 6.如何将一个文件从 bochs 虚拟机拷入 Ubuntu 容器; 7.如何显示 bochs 虚拟机硬盘中某个可执行文件的内容; 8.如何计算一个线性地址对应的物理地址; 9.如何计算一个线性地址的高 10 位和中间 10 位的值; 10.页目录项和页表项的格式是什么; 11.如何查看某个页目录项的值。

实验准备

本关卡使用版本 0 内核进行分析,01.c 文件存放在/data/workspace/myshixun/exp1下。

编程要求

本关任务:在 bochs 虚拟机中编译程序 01.c ,可以得到一个可执行文件。请分析该程序的运行,回答下列问题: 1.执行该文件的 execve 系统调用刚开始执行时,当前进程的用户虚空间是什么?该空间的第一个页表项和最后一个页表项分别是什么? 2.执行该文件的 execve 系统调用执行结束时,该进程的用户虚空间是什么?该空间占据几个页目录项?第一个页目录项的地址和值分别是什么? 3.该可执行文件的代码段和数据段的长度之和是多少?

实验过程及答案

实验过程

直接简单粗暴手动把/data/workspace/myshixun/exp1的01.复制到os/linux-0.11-lab/bf32d9529b27e49909b6597a4b6f3c3b5.png

 

cd os/linux-0.11-lab
./run
65139ef469d749888ded3103fae0b58c.png

 

 

6f71b790208d46278db3b333aad71a00.png5961cc67c90f4dffbc8368abd1d4ed55.png

d59c74552eef471793b83d0423178d7f.png

点yes

打开gdb

9b1351c5936f4f1d819d681135e7a4de.png然后一直c96beba7ea046423cbb03c7f29a1d8ee3.png

转到虚拟机

0a100a525897414c8b9d1f5e34e29395.png

回到gdb

14c3cde728064eb5955ce35d83f3eabd.pngd6588c19d64a4a908f855d0eb88473e6.png5dcaae2925284a44b63f2fe48d66d002.png5fb7185cf5e54f1591f42eb90eef6cd1.png661b4b4730274ba9a3d1fe799eab4c31.pnga89eed204f954ae0bce1a327e6093103.pngb8b737ef95414f9eac9b6a0b5ee62b05.png2192ffeff36c499781a4b5c175442b35.png27295657ca6443b9a3d535e3bb143eb0.pngb0e4ac6d19a047acbc4caa899f4b8567.png2b9706580ed24272b3f27ca381708a68.png

答案

fe16c3d5f99c4fa9a1222f88e9507cfb.png

第2关可执行文件的加载

 

相关文章:

课堂练习4.4:页式虚存

4-7 课堂练习4.4:页式虚存 缺页异常在 Linux 内核处理中占有非常重要的位置,很多 Linux 特性,如写时复制,页框延迟分配,内存回收中的磁盘和内存交换,都需要借助缺页异常来进行。 本实训分析 Linux 0.11 的…...

javascript实现Stack(栈)数据结构

上一篇文章我们理解了List这种数据结构,知道了它的特点和一些使用场景,这篇文章我们就来看一下栈这种数据结构,这里的栈可不是客栈哦,哈哈 栈其实和List非常像,使用javascript实现都是基于数组来实现 尝试理解Stack …...

Layui深入

1、代码&#xff1a; <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>注册页面</title> <style> .container { max-width: 600px; margin: 0 auto; padding: 20px; …...

网络层--TCP/UDP协议

目录 一、TCP/UDP协议介绍 1、UDP(User Datagram Protocol)--用户数据报协议 1.1 UDP报文格式 1.2 UDP协议的特性 2、TCP(Transmission Control Protocol )--传输控制协议 2.1 TCP报文格式 2.2 TCP协议的特性 2.3 TCP三次握手 2.4 四次挥手 三、TCP和UDP的区别 四、t…...

前端发送请求之参数处理---multipart/form-data与application/x-www-form-urlencoded

Content-Type就是指 HTTP 发送信息至服务器时的内容编码类型&#xff0c;服务器根据编码类型使用特定的解析方式&#xff0c;获取数据流中的数据。 其实前后端发送请求的方式有 text/plain、application/json、application/x-www-form-urlencoded、 multipart/form-data等&…...

解决Ubuntu16.04没声音

第一步&#xff1a;安装 PulseAudio Volum Control Ubuntu没有声音&#xff08;听不到声音&#xff09;的解决方法 第二步&#xff1a;No cards available for configuration 【解决Ubuntu18.04没声音&#xff1a;No cards available for configuration】 完美解决&#xf…...

12.14每日一题(备战蓝桥杯归并排序)

12.14每日一题&#xff08;备战蓝桥杯归并排序&#xff09; 题目 归并排序 给定你一个长度为 n 的整数数列。 请你使用归并排序对这个数列按照从小到大进行排序。 并将排好序的数列按顺序输出。 输入格式 输入共两行&#xff0c;第一行包含整数 n。 第二行包含 n 个整数&…...

面试__Java常见异常有哪些?

java.lang.IllegalAccessError&#xff1a;违法访问错误。当一个应用试图访问、修改某个类的域&#xff08;Field&#xff09;或 者调用其方法&#xff0c;但是又违反域或方法的可见性声明&#xff0c;则抛出该异常。 java.lang.InstantiationError&#xff1a;实例化错误。当…...

linux 网络子系统 摘要

当你输入一个网址并按下回车键的时候&#xff0c;首先&#xff0c;应用层协议对该请求包做了格式定义;紧接着传输层协议加上了双方的端口号&#xff0c;确认了双方通信的应用程序;然后网络协议加上了双方的IP地址&#xff0c;确认了双方的网络位置;最后链路层协议加上了双方的M…...

java发起http、https请求,并携带cookie、header,post参数放body并可选关闭ssl证书验证,高可用版

公司有个需求是发起https请求对接国家数据接口&#xff0c;需要带header、cookie&#xff0c;并关闭ssl证书验证&#xff0c;搜了很多文章&#xff0c;都说用HttpsURLConnection发起请求&#xff0c;但不知为啥在封装body参数的时候一直报400封装出错&#xff0c;也欢迎指出不足…...

windows系统nodeJs报错node-sass npm ERR! command failed

报错信息 npm WARN deprecated request2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142 npm WARN deprecated tar2.2.2: This version of tar is no longer supported, and will not receive security updates. Please upgrade asa…...

从零构建属于自己的GPT系列5:模型部署1(文本生成函数解读、模型本地化部署、文本生成文本网页展示、代码逐行解读)

&#x1f6a9;&#x1f6a9;&#x1f6a9;Hugging Face 实战系列 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在PyCharm中进行 本篇文章配套的代码资源已经上传 从零构建属于自己的GPT系列1&#xff1a;数据预处理 从零构建属于自己的GPT系列2&#xff1a;模型训…...

电脑篇——360浏览器打开新标签页自定义,和关闭360导航(强迫症福音)

1.点击“”按钮打开新标签页时会自动打开“资讯聚合”页面&#xff0c;如下图。 如何让我们打开新标签页可以自定义呢&#xff08;如我这般强迫症必须要新打开的页面干干净净&#xff09;&#xff1f; 方法&#xff1a;点击号打开新标签页后&#xff0c;在新标签页界面上找到…...

常见的Linux基本指令

目录 什么是Linux&#xff1f; Xshell如何远程控制云服务器 Xshell远程连接云服务器 Linux基本指令 用户管理指令 pwd指令 touch指令 mkdir指令 ls指令 cd指令 rm指令 man命令 cp指令 mv指令 cat指令 head指令 ​编辑 tail指令 ​编辑echo指令 find命令 gr…...

ESXI 6.7升级update3

一、适用场景 1、企业已有专业服务器&#xff0c;通过虚拟化环境搭建了vm server&#xff1b; 2、备份整个vm server时&#xff0c;需要使用ovftool工具完成&#xff0c;直接导出ovf模板时报错&#xff1b; 3、升级EXSI6.7的build 8169922版本为update 3版本后&#xff0c;已保…...

bugku--source

dirsearch扫一下 题目提示源代码&#xff08;source&#xff09; 也就是源代码泄露&#xff0c;然后发现有.git 猜到是git泄露 拼接后发现有文件 但是点开啥也没有 kali里面下载下来 wegt -r 下载网站的所有内容 ls 查看目录 cd 进入到目录里面 gie reflog 引用日志使用…...

SpringBoot Maven 项目打包的艺术--主清单属性缺失与NoClassDefFoundError的优雅解决方案

Maven项目的Jar包打包问题-没有主清单属性&&ClassNotFoundException 与 NoClassDefFoundError 文章目录 Maven项目的Jar包打包问题-没有主清单属性&&ClassNotFoundException 与 NoClassDefFoundError1、问题出现1.1、Jar包运行&#xff1a;没有主清单属性解决方…...

2023-12-14 二叉树的最大深度和二叉树的最小深度以及完全二叉树的节点个数

二叉树的最大深度和二叉树的最小深度以及完全二叉树的节点个数 104. 二叉树的最大深度 思想&#xff1a;可以使用迭代法或者递归&#xff01;使用递归更好&#xff0c;帮助理解递归思路&#xff01;明确递归三部曲–①确定参数以及返回参数 ②递归结束条件 ③单层逻辑是怎么样…...

利用闭包与高阶函数实现缓存函数的创建

缓存函数是一种用于存储和重复利用计算结果的机制。其基本思想是&#xff0c;当一个函数被调用并计算出结果时&#xff0c;将该结果存储在某种数据结构中 (通常是一个缓存对象)以备将来使用。当相同的输入参数再次传递给函数时&#xff0c;不再执行实际的计算&#xff0c;而是直…...

P1042 [NOIP2003 普及组] 乒乓球 JAVA 题解

题目背景 国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革&#xff0c;以推动乒乓球运动在全球的普及。其中11分制改革引起了很大的争议&#xff0c;有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位&#xff0c;他退役之后走上了乒乓球研究工作&…...

内存分配函数malloc kmalloc vmalloc

内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容

基于 ​UniApp + WebSocket​实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配​微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...

Matlab | matlab常用命令总结

常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...

三体问题详解

从物理学角度&#xff0c;三体问题之所以不稳定&#xff0c;是因为三个天体在万有引力作用下相互作用&#xff0c;形成一个非线性耦合系统。我们可以从牛顿经典力学出发&#xff0c;列出具体的运动方程&#xff0c;并说明为何这个系统本质上是混沌的&#xff0c;无法得到一般解…...

实现弹窗随键盘上移居中

实现弹窗随键盘上移的核心思路 在Android中&#xff0c;可以通过监听键盘的显示和隐藏事件&#xff0c;动态调整弹窗的位置。关键点在于获取键盘高度&#xff0c;并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...

Element Plus 表单(el-form)中关于正整数输入的校验规则

目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入&#xff08;联动&#xff09;2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

代码随想录刷题day30

1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额&#xff0c;返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...

BLEU评分:机器翻译质量评估的黄金标准

BLEU评分&#xff1a;机器翻译质量评估的黄金标准 1. 引言 在自然语言处理(NLP)领域&#xff0c;衡量一个机器翻译模型的性能至关重要。BLEU (Bilingual Evaluation Understudy) 作为一种自动化评估指标&#xff0c;自2002年由IBM的Kishore Papineni等人提出以来&#xff0c;…...

脑机新手指南(七):OpenBCI_GUI:从环境搭建到数据可视化(上)

一、OpenBCI_GUI 项目概述 &#xff08;一&#xff09;项目背景与目标 OpenBCI 是一个开源的脑电信号采集硬件平台&#xff0c;其配套的 OpenBCI_GUI 则是专为该硬件设计的图形化界面工具。对于研究人员、开发者和学生而言&#xff0c;首次接触 OpenBCI 设备时&#xff0c;往…...

uniapp 集成腾讯云 IM 富媒体消息(地理位置/文件)

UniApp 集成腾讯云 IM 富媒体消息全攻略&#xff08;地理位置/文件&#xff09; 一、功能实现原理 腾讯云 IM 通过 消息扩展机制 支持富媒体类型&#xff0c;核心实现方式&#xff1a; 标准消息类型&#xff1a;直接使用 SDK 内置类型&#xff08;文件、图片等&#xff09;自…...