我有两个要存储在堆栈上的寄存器 w1 和 w2。我想将完整的单词 w1 和 w2 的一半存储到堆栈中。这是我的实现:
STR w1, [sp, #-8]!
STRH w2, [sp, #-8]!
在编译时,第一条指令运行良好,但第二条指令引发总线错误。我知道这是一些对齐问题,但我无法正确理解为什么会这样?
我正在为 ARMv8(64 位)架构进行编译。
我有两个要存储在堆栈上的寄存器 w1 和 w2。我想将完整的单词 w1 和 w2 的一半存储到堆栈中。这是我的实现:
STR w1, [sp, #-8]!
STRH w2, [sp, #-8]!
在编译时,第一条指令运行良好,但第二条指令引发总线错误。我知道这是一些对齐问题,但我无法正确理解为什么会这样?
我正在为 ARMv8(64 位)架构进行编译。