错误的写法:
这是参照 Open RISC-V Reference Card 的格式书写的,这将将产生错误:
正确的写法:
凡是 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 指令的写法示例:
不知道汇编指令语法的解决办法:
- 使用 .insn 伪指令构造机器码,然后通过 objdump 反汇编出来,看看反汇编是什么格式,那么汇编指令就用什么格式。比如上面的
amoadd.w a1, a2, (a0)
通过 .insn 伪指令构造 .insn r AMO, 2, 4, a1, a0, a2
。更多关于 .insn 伪指令的内容参考 gas 文档 RISC-V Instruction Formats 。 - The RISC-V Instruction Set Manual 会有一些示例代码可以参考。
参考: