diff --git a/src/asm_marshal.cpp b/src/asm_marshal.cpp index 76e290e0d..ae4438171 100644 --- a/src/asm_marshal.cpp +++ b/src/asm_marshal.cpp @@ -258,7 +258,7 @@ struct MarshalVisitor { vector operator()(Atomic const& b) { return {ebpf_inst{ - .opcode = static_cast(INST_CLS_ST | 0x1 | INST_MODE_ATOMIC | width_to_opcode(b.access.width)), + .opcode = static_cast(INST_CLS_STX | INST_MODE_ATOMIC | width_to_opcode(b.access.width)), .dst = b.access.basereg.v, .src = b.valreg.v, .offset = static_cast(b.access.offset), diff --git a/src/asm_unmarshal.cpp b/src/asm_unmarshal.cpp index 60d1864cd..22fca1cd7 100644 --- a/src/asm_unmarshal.cpp +++ b/src/asm_unmarshal.cpp @@ -287,8 +287,6 @@ struct Unmarshaller { ((inst.opcode & INST_SIZE_MASK) != INST_SIZE_W && (inst.opcode & INST_SIZE_MASK) != INST_SIZE_DW)) throw InvalidInstruction(pc, inst.opcode); - if (inst.imm != 0) - throw InvalidInstruction(pc, "Unsupported atomic instruction"); return Atomic{ .op = getAtomicOp(pc, inst), .access =