0

假设我有一个 64 位数据的 3 元素数组:

   src    DCQ    0x0200200AD00236DD
          DCQ    0x00003401AAC4D097
          DCQ    0X0001FC219AC931BE

假设我知道“src”的地址(命名为 srcAdr),我可以通过说:

   LDR    srcLo, [srcAdr, index, LSL#3]

为了得到这个元素更高的 32 位内容,我知道我可以:

   ADD    srcAdrHi, srcAdr, #4
   LDR    srcHi, [srcAdrHi, index, LSL#3]

问题是,有没有更优雅的方法来做到这一点?比如说,在一条指令中?

4

1 回答 1

0

按照我的评论:如果出于某种原因您必须像使用 uint64_t 数组一样使用索引来处理数据,我认为您不能在此处没有额外的说明。

对于“C”函数:

int foo(unsigned long long *srcT, int index) {
  unsigned int temp=0;
  temp = (unsigned int)(srcT[index]);
  temp += (unsigned int)(srcT[index] >> 32);
  return temp;
}

编译器(ARM gcc 8.2 -O3 -mcpu=arm7tdmi)产生:

foo:
    add     r3, r0, r1, lsl #3
    ldr     r3, [r3, #4]
    ldr     r0, [r0, r1, lsl #3]
    add     r0, r0, r3
    bx      lr

如您所见,它还产生了一个额外的指令 ( add) 来访问“高半部分”。当然,确切的指令顺序取决于对阵列执行的操作。如果您循环遍历它,您很可能会得到ldm+add Rx,#8等。

于 2019-04-30T23:26:44.400 回答