Linux中的逻辑地址与线性地址


做《操作系统》助教的过程中无意间学到的一点新知识。

A.问题起源

逻辑地址对程序来说实际上是个偏移地址,从0开始,它依赖于段基址组合成一个线性地址。段基址+逻辑地址=线性地址,线性地址经过硬件计算出相应的页表地址和页内偏移,从而得到物理地址。
到这里时,直觉上会认为这样的过程很麻烦,因为要经过逻辑地址-线性地址-物理地址的两次转换。在网上查资料后发现很多人说分段其实是一个冗余的操作,并且给了一个例子:Linux的所有段的段基址都是从0开始的!这一说法颠覆了我以往的认知,因为之前上的《操作系统》课程都在讲分段的这个好处那个好处,而且我也无法理解如果所有段基址都从0开始,那不同的程序之间如何做到逻辑地址到线性地址的转换不产生混淆。

B.分段的起源

分段最早用在16位ALU的时候,总线地址提到了20位,因此CPU无法计算,于是采用了分段。寄存器里保存16位段基址,再将16位偏移的前12位和段基址相加,偏移最后四位补在最后就得到了一个20位地址。这相当于是说段基址必须是16的倍数。

C.为什么不需要分段了?

因为只用分页就足够了。我们把线性地址整合到进程里就可以了,这实际上与分段是一个道理的。
例如,在分页机制里,我们直接把页表的地址分配给进程不就好了吗?一个新的进程被加载时,系统分配一个页表地址保存在进程的PCB里,这与分配一个段基址如出一辙。之后调用进程时,把页表地址读进寄存器,逻辑地址提供页表索引和页内偏移不就可以找到任意内存位置了吗?为不同的进程分配不同的起始页表地址,因此避免了混淆。当然

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值