__futex_atomic_op
__futex_atomic_op("mov %3,%1\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("addl %0,%3,%1\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("or %0,%3,%1\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("andnot %0,%3,%1\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("xor %0,%3,%1\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("xor %0, %1, %3", ret, oldval, uaddr, oparg);
__futex_atomic_op("mov %0, %3", ret, oldval, uaddr, oparg);
__futex_atomic_op("add %0, %1, %3", ret, oldval, uaddr, oparg);
__futex_atomic_op("or %0, %1, %3", ret, oldval, uaddr, oparg);
__futex_atomic_op("bic %0, %1, %3", ret, oldval, uaddr, oparg);
__futex_atomic_op("mov %0, %4", ret, oldval, tmp, uaddr, oparg);
__futex_atomic_op("add %0, %1, %4", ret, oldval, tmp, uaddr, oparg);
__futex_atomic_op("orr %0, %1, %4", ret, oldval, tmp, uaddr, oparg);
__futex_atomic_op("and %0, %1, %4", ret, oldval, tmp, uaddr, ~oparg);
__futex_atomic_op("eor %0, %1, %4", ret, oldval, tmp, uaddr, oparg);
__futex_atomic_op("mov %w3, %w5",
__futex_atomic_op("add %w3, %w1, %w5",
__futex_atomic_op("orr %w3, %w1, %w5",
__futex_atomic_op("and %w3, %w1, %w5",
__futex_atomic_op("eor %w3, %w1, %w5",
__futex_atomic_op("mov %[t], %[ov]",
__futex_atomic_op("add %[t], %[ov], %[op]",
__futex_atomic_op("or %[t], %[ov], %[op]",
__futex_atomic_op("and %[t], %[ov], %[op]",
__futex_atomic_op("xor %[t], %[ov], %[op]",
__futex_atomic_op("%1 = %4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("%1 = add(%0,%4)\n", ret, oldval, uaddr,
__futex_atomic_op("%1 = or(%0,%4)\n", ret, oldval, uaddr,
__futex_atomic_op("%1 = not(%4); %1 = and(%0,%1)\n", ret,
__futex_atomic_op("%1 = xor(%0,%4)\n", ret, oldval, uaddr,
__futex_atomic_op("move $t0, %z5", ret, oldval, uaddr, oparg);
__futex_atomic_op("add.w $t0, %1, %z5", ret, oldval, uaddr, oparg);
__futex_atomic_op("or $t0, %1, %z5", ret, oldval, uaddr, oparg);
__futex_atomic_op("and $t0, %1, %z5", ret, oldval, uaddr, ~oparg);
__futex_atomic_op("xor $t0, %1, %z5", ret, oldval, uaddr, oparg);
__futex_atomic_op("or %1,%4,%4;", ret, oldval, uaddr, oparg);
__futex_atomic_op("add %1,%0,%4;", ret, oldval, uaddr, oparg);
__futex_atomic_op("or %1,%0,%4;", ret, oldval, uaddr, oparg);
__futex_atomic_op("andn %1,%0,%4;", ret, oldval, uaddr, oparg);
__futex_atomic_op("xor %1,%0,%4;", ret, oldval, uaddr, oparg);
__futex_atomic_op(op, "move $1, %z5", ret, oldval, uaddr, oparg);
__futex_atomic_op(op, "addu $1, %1, %z5",
__futex_atomic_op(op, "or $1, %1, %z5",
__futex_atomic_op(op, "and $1, %1, %z5",
__futex_atomic_op(op, "xor $1, %1, %z5",
__futex_atomic_op("l.or %1,%4,%4", ret, oldval, uaddr, oparg);
__futex_atomic_op("l.add %1,%0,%4", ret, oldval, uaddr, oparg);
__futex_atomic_op("l.or %1,%0,%4", ret, oldval, uaddr, oparg);
__futex_atomic_op("l.and %1,%0,%4", ret, oldval, uaddr, ~oparg);
__futex_atomic_op("l.xor %1,%0,%4", ret, oldval, uaddr, oparg);
__futex_atomic_op("mr %1,%4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("add %1,%0,%4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("or %1,%0,%4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("andc %1,%0,%4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("xor %1,%0,%4\n", ret, oldval, uaddr, oparg);
__futex_atomic_op("amoswap.w.aqrl %[ov],%z[op],%[u]",
__futex_atomic_op("amoadd.w.aqrl %[ov],%z[op],%[u]",
__futex_atomic_op("amoor.w.aqrl %[ov],%z[op],%[u]",
__futex_atomic_op("amoand.w.aqrl %[ov],%z[op],%[u]",
__futex_atomic_op("amoxor.w.aqrl %[ov],%z[op],%[u]",
__futex_atomic_op("xor %[newval], %[oldval], %[oparg]",
__futex_atomic_op("mov %[newval], %[oparg]",
__futex_atomic_op("add %[newval], %[oldval], %[oparg]",
__futex_atomic_op("or %[newval], %[oldval], %[oparg]",
__futex_atomic_op("and %[newval], %[oldval], %[oparg]",