ARM的LDR指令只能存取address在4的倍数上的变量(且取出来的宽度为32bit)。
如果此变量的address不在4的倍数上,则必须要依此变量的大小来决定要用LDRH或LDRB
比如,我要取一个24bit大小的变量,且此变量不在4的倍数的address上,那要用1个LDRH
与1个LDRB做组合,来取出此变量。
前提:
1. Compiler知道此变量的起始点在哪个address上
2. Compiler虽然不知道此变量的大小多长,但使用者可以透过data type告诉Compiler。
由于上述前提,我的假设是:
Compiler有办法知道什么时候该用LDR,什么时候该用LDRH或LDRB来取出正确的变量值
实验: https://imgur.com/a/q8jyBab
宣告一个array,并且把指标指到非4的倍数的address上(a[1]),然后再取32bit的长度,
arm进入exception。
分析: Compiler先把a[0]放在0x88000f1c的address上(前提1),但却用LDR来取出此变量。
问题:
1. 为什么Compiler不用两次的LDRH,而要用LDR? 还是只有TI的compiler才这样?
2. 还是我的前提1不够完整? Compiler虽然知道变量的起始点,但却不会保存起来?