.*:101: Error: atomic memory operations insns require rd != rj && rd != rk when rd isn't r0
.*:102: Error: atomic memory operations insns require rd != rj && rd != rk when rd isn't r0
.*:103: Error: atomic memory operations insns require rd != rj && rd != rk when rd isn't r0
-.*:104: Error: atomic memory operations insns require rd != rj && rd != rk when rd isn't r0
-.*:105: Error: atomic memory operations insns require rd != rj && rd != rk when rd isn't r0
+.*:106: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
+.*:107: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
.*:108: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
.*:109: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
-.*:110: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
-.*:111: Error: bstr\(ins\|pick\)\.\[wd\] require msbd >= lsbd
+.*:112: Error: g\?csrxchg require rj != r0 && rj != r1
+.*:113: Error: g\?csrxchg require rj != r0 && rj != r1
.*:114: Error: g\?csrxchg require rj != r0 && rj != r1
.*:115: Error: g\?csrxchg require rj != r0 && rj != r1
-.*:116: Error: g\?csrxchg require rj != r0 && rj != r1
-.*:117: Error: g\?csrxchg require rj != r0 && rj != r1
--- /dev/null
+#as:
+#objdump: -d
+
+.*: file format .*
+
+
+Disassembly of section \.text:
+
+0+ <\.text>:
+ *[0-9a-f]+: 38600400 amswap.w \$zero, \$ra, \$zero
+ *[0-9a-f]+: 38600421 amswap.w \$ra, \$ra, \$ra
+ *[0-9a-f]+: 38600442 amswap.w \$tp, \$ra, \$tp
+ *[0-9a-f]+: 38600463 amswap.w \$sp, \$ra, \$sp
+ *[0-9a-f]+: 38600484 amswap.w \$a0, \$ra, \$a0
+ *[0-9a-f]+: 386004a5 amswap.w \$a1, \$ra, \$a1
+ *[0-9a-f]+: 386004c6 amswap.w \$a2, \$ra, \$a2
+ *[0-9a-f]+: 386004e7 amswap.w \$a3, \$ra, \$a3
+ *[0-9a-f]+: 38600508 amswap.w \$a4, \$ra, \$a4
+ *[0-9a-f]+: 38600529 amswap.w \$a5, \$ra, \$a5
+ *[0-9a-f]+: 3860054a amswap.w \$a6, \$ra, \$a6
+ *[0-9a-f]+: 3860056b amswap.w \$a7, \$ra, \$a7
+ *[0-9a-f]+: 3860058c amswap.w \$t0, \$ra, \$t0
+ *[0-9a-f]+: 386005ad amswap.w \$t1, \$ra, \$t1
+ *[0-9a-f]+: 386005ce amswap.w \$t2, \$ra, \$t2
+ *[0-9a-f]+: 386005ef amswap.w \$t3, \$ra, \$t3
+ *[0-9a-f]+: 38600610 amswap.w \$t4, \$ra, \$t4
+ *[0-9a-f]+: 38600631 amswap.w \$t5, \$ra, \$t5
+ *[0-9a-f]+: 38600652 amswap.w \$t6, \$ra, \$t6
+ *[0-9a-f]+: 38600673 amswap.w \$t7, \$ra, \$t7
+ *[0-9a-f]+: 38600694 amswap.w \$t8, \$ra, \$t8
+ *[0-9a-f]+: 386006b5 amswap.w \$r21, \$ra, \$r21
+ *[0-9a-f]+: 386006d6 amswap.w \$fp, \$ra, \$fp
+ *[0-9a-f]+: 386006f7 amswap.w \$s0, \$ra, \$s0
+ *[0-9a-f]+: 38600718 amswap.w \$s1, \$ra, \$s1
+ *[0-9a-f]+: 38600739 amswap.w \$s2, \$ra, \$s2
+ *[0-9a-f]+: 3860075a amswap.w \$s3, \$ra, \$s3
+ *[0-9a-f]+: 3860077b amswap.w \$s4, \$ra, \$s4
+ *[0-9a-f]+: 3860079c amswap.w \$s5, \$ra, \$s5
+ *[0-9a-f]+: 386007bd amswap.w \$s6, \$ra, \$s6
+ *[0-9a-f]+: 386007de amswap.w \$s7, \$ra, \$s7
+ *[0-9a-f]+: 386007ff amswap.w \$s8, \$ra, \$s8
#define LARCH_OP_CSRXCHG 0x04000000
#define LARCH_MK_GCSRXCHG 0xff000000
#define LARCH_OP_GCSRXCHG 0x05000000
+ #define LARCH_MK_AMSWAP_W 0xffff8000
+ #define LARCH_OP_AMSWAP_W 0x38600000
#define LARCH_INSN_OPS(insn, op) ((insn & LARCH_MK_##op) == LARCH_OP_##op)
#define LARCH_INSN_ADDI_D(insn) LARCH_INSN_OPS((insn), ADDI_D)
#define LARCH_INSN_BSTRPICK_D(insn) LARCH_INSN_OPS((insn), BSTRPICK_D)
#define LARCH_INSN_CSRXCHG(insn) LARCH_INSN_OPS((insn), CSRXCHG)
#define LARCH_INSN_GCSRXCHG(insn) LARCH_INSN_OPS((insn), GCSRXCHG)
+ #define LARCH_INSN_AMSWAP_W(insn) LARCH_INSN_OPS((insn), AMSWAP_W)
#define LARCH_INSN_ATOMIC_MEM(insn) \
((insn & 0xfff80000) == 0x38580000 \
{ 0, 0, "la.tls.desc", "r,l", INSN_LA_TLS_DESC64_LARGE_ABS, 0 },
{ 0, 0, "la.tls.desc", "r,l", INSN_LA_TLS_DESC64, 0 },
{ 0, 0, "la.tls.desc", "r,r,l", INSN_LA_TLS_DESC64_LARGE_PCREL,0 },
+ { 0, 0, "ud", "u", "amswap.w $r%1,$r1,$r%1", 0, 0, 0 },
{ 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list. */
};