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

参考:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值