头歌操作系统 课堂练习4.2:页式内存管理 答案 无解析

第1关:1 号进程的 mynext 变量的物理地址

编程要求

通过 gdb 和 dbg 调试查找答案,将第一关的答案填写在/data/workspace/myshixun/第一关.txt中。

  1. 1 号进程第 1 次调用函数 output_char 时,它的 mynext 变量的物理地址是多少?
  2. 1 号进程第 2 次调用函数 output_char 时,它的 mynext 变量的物理地址是多少?

配置环境版本1.3内核与之前一样,详情请移步以下链接~头歌操作系统 课堂练习4.1:段式内存管理 答案_蓝莓奶油饺子·的博客-CSDN博客

启动gdb调试器 ,键入代码:

b 155
c
x/6i $eip
p/x current->ldt

关闭gdb调试器,启动dbg调试器,键入代码:

b 0x6969
c
c
b 0x6977
c
n
sreg
reg

x/38wx 0xffe000

xp/wx 0xffd7b0

第一关文档答案:

 第2关:0 号进程的 mynext 变量的物理地址

编程要求

通过 gdb 和 dbg 调试查找答案,将第二关的答案填写在/data/workspace/myshixun/第二关.txt中。

  1. 0 号进程第 1 次调用函数 output_char 时,它的 mynext 变量的物理地址是多少?
  2. 0 号进程第 2 次调用函数 output_char 时,它的 mynext 变量的物理地址是多少?

完成第一关代码并填完第二关文档答案直接评测即可~

第二关文档答案:

### 操作系统课堂练习4.2页式内存管理 #### 练习目标 该练习旨在帮助学习者理解操作系统页式内存管理机制,掌握虚拟地址到物理地址的映射过程以及分页表的作用。 #### 实验环境准备 为了完成此练习,需先配置好实验所需的内核开发环境。以下是基于引用中的相内容整理的操作步骤: ```bash cp /data/workspace/myshixun/exp1/1.3.tgz ~/os/ cd ~/os/linux-0.11-lab/ tar -zxvf ../1.3.tgz rm -rf cur ln -s 1.3 cur cd 1.3/linux make cd ../../.. ``` 以上命令用于初始化内核工作目录并编译内核代码[^2]。 --- #### 题目描述 假设当前系统采用的是简单的单级页表实现方式,页面大小为 \(4KB\),逻辑地址空间被划分为多个固定大小的页。已知某进程的部分页表如下所示: | 页面 | 物理帧 | |--------|----------| | 0 | 5 | | 1 | 10 | | 2 | 15 | 如果给定一个逻辑地址 `0x1FAC`,请计算其对应的物理地址,并解释具体的过程。 --- #### 解答思路 要将逻辑地址转化为物理地址,需要按照以下公式分解逻辑地址: \[ \text{逻辑地址} = \text{页} \times \text{页面大小} + \text{偏移量} \] 其中, - **页**通过逻辑地址除以页面大小取整得到; - **偏移量**通过逻辑地址对页面大小求余数获得。 对于题目中给出的逻辑地址 `0x1FAC`(十六进制),可以将其转为十进制形式以便于计算: \[ 0x1FAC_{(16)} = 8108_{(10)} \] 接着按页面大小 \(4KB = 4096\) 进行拆解: - 计算页:\( \lfloor 8108 / 4096 \rfloor = 1 \) - 计算偏移量:\( 8108 \% 4096 = 4012 \) 查页表可知,第一页对应物理帧为 \(10\)。因此最终物理地址可表示为: \[ \text{物理地址} = (\text{物理帧}) \times \text{页面大小} + \text{偏移量} \] 代入数据得: \[ \text{物理地址} = 10 \times 4096 + 4012 = 44972 \] 最后将结果转换回十六进制形式: \[ 44972_{(10)} = 0xAECC_{(16)} \] 所以,逻辑地址 `0x1FAC` 对应的物理地址为 `0xAECC`[^2]。 --- #### 参考代码片段 以下是一个模拟页式内存管理的小型程序示例,展示如何根据逻辑地址获取物理地址: ```c #include <stdio.h> #define PAGE_SIZE 4096 // 页面大小为 4KB int page_table[] = {5, 10, 15}; // 假设页表内容 unsigned int logical_to_physical(unsigned int logical_addr) { unsigned int page_number = logical_addr / PAGE_SIZE; unsigned int offset = logical_addr % PAGE_SIZE; if (page_number >= sizeof(page_table)/sizeof(int)) { printf("Page fault!\n"); return -1; } unsigned int frame_number = page_table[page_number]; unsigned int physical_addr = frame_number * PAGE_SIZE + offset; return physical_addr; } int main() { unsigned int logical_address = 0x1FAC; // 输入逻辑地址 unsigned int physical_address = logical_to_physical(logical_address); if (physical_address != -1) { printf("Physical Address: 0x%X\n", physical_address); } return 0; } ``` 运行上述代码会输出逻辑地址 `0x1FAC` 的物理地址为 `0xAECC`[^2]。 --- #### 总结 通过对页式内存管理的学习,能够深入理解操作系统如何利用硬件支持来实现高效的内存分配与访问控制。这不仅有助于提升理论认知水平,还能培养实际动手能力。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值