首先:
本文引用地址:http://www.eepw.com.cn/article/201611/318096.htm
#define BITBAND(addr,bitnum) ((addr & 0xF0000000) + 0x2000000 + ((addr & 0xFFFFF) << 5) + (bitnum << 2))
对上句程序的解释:
利用宏定义的方式将位带地址的映射表示出来,该函数有两个参数addr和bitnum,分别是原本的地址和在数据中的第几位。我们知道两个公式如下:
0x2000_0000‐0x200F_FFFF地址空间:AliasAddr = 0x22000000 + (A – 0x20000000)*32 + n*4
0x4000_0000‐0x400F_FFFF地址空间:AliasAddr = 0x42000000 + (A – 0x40000000)*32 + n*4
仔细观察我们可以发现,是有规律可寻的。两个公式的基地址一个是0x22000000,一个是0x42000000,他们只是最高位不一样,这个最高位和最原始的地址的最高位是一致的。所以我们通过 (addr & 0xF0000000) 来取最高位,再加上0x2000000就得到了公式中的基地址。我们知道两个地址空间中地址的变换只是在低5位上,比如0x2000_0000 — 0x200F_FFFF(有5个F),利用(A – 0x20000000)的目的是得到地址addr和0x2000_0000之间的偏移,也就是低5位的内容,所以我们通过 (addr & 0xFFFFF)得到了低5位的数据,也即是偏移量。公