Bootstrap

如何实现16位内部地址到20位实际地址的转换

物理地址=段地址*16+偏移地址(这里的物理地址是20位的,即0x00000 - 0xffffff这个范围的地址
就是一个寄存器里的左移4位  加上 另一个寄存器里的偏移地址(16×64k+表示范围是64k的地址即对应所谓的20位
20根地址线,表示 0x00000 - 0xffffff这个范围的地址
而寄存器16位 您想想还有4位怎么办? 刚好错开(左移4位) 相加 组成20位
附:
段地址:8086CPU将1MB的存储器空间分成许多逻辑段,每个段最大限制为64KB, 段地址就是逻辑段在主存中的起始位置

偏移地址:存储单元距离段起始位置的偏移量简称偏移地址,由于限定每段 不超过64KB,所以偏移地址也可以用16位数据表示。

物理地 址:在1M字节的存储器里,每一个存储单元都有一个唯一的20位地址,称为该存储单元的物理地址,把段地址左移4位再加上偏移地址就形成物理地址(0--65535的数据可以用16位来表达,但是超过65536了,16位表达不了,于是工程师们想了一个办法,比分说要表达65537,即为 1×65536+1,这里的第2个1即是偏移值,必须小于65536,第1个1其范围必须小于16,因为左移4位,最大表示是16嘛)。

;