首要,SST39VF16 FLASH是16位的,也便是以两个字节(半字)为最小操作单位的。也便是说你在FLASH地址上给0x00000,则它给出的数据是第一个16位的半字;在FLASH地址上给0x00001,它给出的是第二个16位的半字;在FLASH地址上给0x00002,它给出的是第三个16位的半字。。。但ARM的地址是以字节编址的,它能够以字节单位来读取或许写外设。
假定咱们要读取FLASH的第一个[color=#FF0000]字节[/color],LDRB R0,[R1];将R1内容写0x00000,这个时分ARM履行的是这样的操作:
1、送出地址0x00000
2、在D0-D15上读取数据
3、将读到的16位数据的[color=#FF0000]低[/color]8位给R0低8位(高24位为0)
假定咱们要读取FLASH的第二个[color=#FF0000]字节[/color],LDRB R0,[R1];将R1内容写0x00001,
这个时分ARM履行的是这样的操作:
1、送出地址ox00001
2、在D0-D15上读取数据
3、将读到的16位数据的[color=#FF0000]高[/color]8位给R0的低8位(高24位为0)
从上面的操作能够看到,假如咱们一一对应的将ARM和FLASH得地址衔接,那么咱们想读FLASH的第2个字节的话,就没有办法读到了。由于你地址给0x00001,FLASH就在数据线上给的是第3个字节和第4个字节的数据,并将高8位(FLASH的第4个字节)给R0;假如你给的地址是0x00000的话,ARM的了解便是将数据线D0-D15的低8位给R0,明显这个16位的数据是FLASH的第1个字节和第2个字节的数据,低8位指的便是第一个自己的数据。明显怎样也读不到FLASH的第2个数据。
咱们既要遵从ARM的规矩,又要让FLASH给咱们正确的数据。你自己想应该怎样办?很简单,把ARM给的地址最低位剪掉,把剩余的给FLASH。要读第2个字节,仍是送0x00001,可是最终的1被剪掉了,FLASH得到的地址是ox00000,明显给出的数据是第1个和第二个字节。而ARM觉得送出的地址是0x00001啊,应该把高地址给R0啊,即把第2个字节给了R0。便是一个“欺上瞒下”的进程。