risc-v gcc 编译 atomic 指令时产生 illegal operands 错误的解决办法

时间:2022-11-20 22:57:12


错误的写法:

amoadd.w a1, a0, a2

这是参照 Open RISC-V Reference Card 的格式书写的,这将将产生错误:

illegal operands `amoadd.w a1,a0,a2'

正确的写法:

amoadd.w a1, a2, (a0)

凡是 Load、Store 类型的指令,汇编指令和 Reference Card 的格式是不一样的,存储地址的那个寄存器要加上圆括号,而且要放在指令的最后。如果有偏移量,那么要加在圆括号前面,例如 Load Word 指令,在 Reference Card 中是这样的格式:​​lw rd, rs1, imm​​​ ,汇编指令要这么写: ​​lw rd, imm(rs1)​​。

Atomic 指令都是 Load、Store 类型的,其中的 rs1 存储的是要 Load、Store 的内存地址。

带 aq 或 rl 的 Atomic 指令的写法示例:

amoswap.w.aq  a1,a2,(a0)
amoswap.w.rl a1,a2,(a0)
amoswap.w.aqrl a1,a2,(a0)

不知道汇编指令语法的解决办法:

  1. 使用 .insn 伪指令构造机器码,然后通过 objdump 反汇编出来,看看反汇编是什么格式,那么汇编指令就用什么格式。比如上面的 ​​amoadd.w a1, a2, (a0)​​​ 通过 .insn 伪指令构造 ​​.insn r AMO, 2, 4, a1, a0, a2​​​ 。更多关于 .insn 伪指令的内容参考 gas 文档 ​​RISC-V Instruction Formats​​ 。
  2. The RISC-V Instruction Set Manual 会有一些示例代码可以参考。

参考: