读书笔记之-unix操作系统设计---Demand Paging

本文介绍了UNIX操作系统的Demand Paging。以前UNIX在PDP - 11上用Swapping,如今如bsd unix使用Demand Paging,其原理基于程序访问局部性。还阐述了Demand Paging所需的数据结构,如page table entries等,以及进程context中的相关内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天讲讲Demand Paging,以前的UNIX操作系统在PDP-11上使用的是Swapping,而不是Demand Paging,这是因为Demang Paging需要硬件的支持(restartable instructions )和操作系统的支持。现在的操作系统,如bsd unix使用的是Demand Paging,原理是程序访问的局部性,因此经常访问的页面组成一个集合,叫做工作集,(working set)。 Demand Paging需要的数据结构包括1)page table entries,2)disk block descriptors,3)page frame data table,4)swap-use table。 page frame data table是操作系统初始化时分配的全局的用于管理物理页面的数据结构,它使用hash list和free list,类似于文件系统中的buffer cache。 进程的context中包含per process region talbe,其中的每个entry对应一个region(如bss region,data region,stack region,shared region等等),每个entry包含此region在整个虚拟地址空间中的起始位置和大小,以及region的属性,如是可写的还是read-only(如text region是read-only的),以及一个指向这个region的页表的指针,这个页表完成对虚拟地址到物理地址的映射,<虚拟地址的索引,实际的物理地址的索引>,这个索引是以一个物理页的大小为单位的。未完待续。。。。。。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值