600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > risc-v gcc 编译 atomic 指令时产生 illegal operands 错误的解决办法

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

时间:2023-09-11 13:46:40

相关推荐

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

错误的写法:

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.aqa1,a2,(a0)amoswap.w.rla1,a2,(a0)amoswap.w.aqrla1,a2,(a0)

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

使用 .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 会有一些示例代码可以参考。

参考:

RISCV Inline Assembly in GCC: Atomic Load/Store

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。