先看图
从图中我们可以很好的了解到,位带区中一个字节(地址对应一个字节)中的一位,对应着别名区中的32位(4个字节)。
如位带区中地址为0x20000000中的第0位对应别名区地址为0x22000000~0x2200000003,共4字节,32位。
接下来我们推导公式:假设我们已知位带中的位,如何求出对应别名区中的双字的地址(4个字节),例如0x200FFFFF字节的第0位。
首先我们要用0x200FFFFF减去首地址0x20000000得到偏移量0xFFFFF,这个值可以理解为相对于首地址的距离,也就是说0x200FFFFF前面有0xFFFFF个字节(一个地址对应一个字节),也就是有0xFFFFF*8 个位,前面的位加上自身的位(第0位)也就得到这是第几位了,所以还要加上0,(0xFFFFF*8+0)。根据前面我们所知道的位带区1位对应别名区中4个字节,我们只需再乘以4便可以得到所对应的别名区中的地址,即(0xFFFFF*8+0)*4=0x23FFFFE0
接下来是第二个问题:给定别名区中的双字的地址,如何得到位带区中位的位置或字节(地址),例如0x22000518
同样的方法,首先我们用0x22000518减去别名区首地址0x22000000,得到偏移量0x518,代表距离首地址0x518个字节。别名区4个字节对应位带区中的1位,我们只需除4就可以得到在位带区中所在位,0x518/4=326 位。接下来我们再除以8便可得到所处字节,326/8=40 字节(也即偏移量,加上位带区首地址便是绝对地址了)。最后还有对应位带区中的位在字节中的序号,我们只需将所在位减去前面字节的位就可以得到序号,现在算出是在第40+1个字节(从0开始数是40,从1开始数便是41),那么前面还有40个字节,也即前面还有40*8=320 位, 326-320=6便是所在字节中的序号。