/linux-master/arch/openrisc/include/asm/ |
H A D | futex.h | 11 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 43 __futex_atomic_op("l.or %1,%4,%4", ret, oldval, uaddr, oparg); 46 __futex_atomic_op("l.add %1,%0,%4", ret, oldval, uaddr, oparg); 49 __futex_atomic_op("l.or %1,%0,%4", ret, oldval, uaddr, oparg); 52 __futex_atomic_op("l.and %1,%0,%4", ret, oldval, uaddr, ~oparg); 55 __futex_atomic_op("l.xor %1,%0,%4", ret, oldval, uaddr, oparg);
|
/linux-master/arch/microblaze/include/asm/ |
H A D | futex.h | 11 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 42 __futex_atomic_op("or %1,%4,%4;", ret, oldval, uaddr, oparg); 45 __futex_atomic_op("add %1,%0,%4;", ret, oldval, uaddr, oparg); 48 __futex_atomic_op("or %1,%0,%4;", ret, oldval, uaddr, oparg); 51 __futex_atomic_op("andn %1,%0,%4;", ret, oldval, uaddr, oparg); 54 __futex_atomic_op("xor %1,%0,%4;", ret, oldval, uaddr, oparg);
|
/linux-master/arch/alpha/include/asm/ |
H A D | futex.h | 12 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 39 __futex_atomic_op("mov %3,%1\n", ret, oldval, uaddr, oparg); 42 __futex_atomic_op("addl %0,%3,%1\n", ret, oldval, uaddr, oparg); 45 __futex_atomic_op("or %0,%3,%1\n", ret, oldval, uaddr, oparg); 48 __futex_atomic_op("andnot %0,%3,%1\n", ret, oldval, uaddr, oparg); 51 __futex_atomic_op("xor %0,%3,%1\n", ret, oldval, uaddr, oparg);
|
/linux-master/arch/powerpc/include/asm/ |
H A D | futex.h | 12 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 41 __futex_atomic_op("mr %1,%4\n", ret, oldval, uaddr, oparg); 44 __futex_atomic_op("add %1,%0,%4\n", ret, oldval, uaddr, oparg); 47 __futex_atomic_op("or %1,%0,%4\n", ret, oldval, uaddr, oparg); 50 __futex_atomic_op("andc %1,%0,%4\n", ret, oldval, uaddr, oparg); 53 __futex_atomic_op("xor %1,%0,%4\n", ret, oldval, uaddr, oparg);
|
/linux-master/arch/hexagon/include/asm/ |
H A D | futex.h | 13 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 44 __futex_atomic_op("%1 = %4\n", ret, oldval, uaddr, oparg); 47 __futex_atomic_op("%1 = add(%0,%4)\n", ret, oldval, uaddr, 51 __futex_atomic_op("%1 = or(%0,%4)\n", ret, oldval, uaddr, 55 __futex_atomic_op("%1 = not(%4); %1 = and(%0,%1)\n", ret, 59 __futex_atomic_op("%1 = xor(%0,%4)\n", ret, oldval, uaddr,
|
/linux-master/arch/s390/include/asm/ |
H A D | futex.h | 11 #define __futex_atomic_op(insn, ret, oldval, newval, uaddr, oparg) \ macro 34 __futex_atomic_op("lr %2,%5\n", 38 __futex_atomic_op("lr %2,%1\nar %2,%5\n", 42 __futex_atomic_op("lr %2,%1\nor %2,%5\n", 46 __futex_atomic_op("lr %2,%1\nnr %2,%5\n", 50 __futex_atomic_op("lr %2,%1\nxr %2,%5\n",
|
/linux-master/arch/loongarch/include/asm/ |
H A D | futex.h | 14 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 17 "1: ll.w %1, %4 # __futex_atomic_op\n" \ 39 __futex_atomic_op("move $t0, %z5", ret, oldval, uaddr, oparg); 42 __futex_atomic_op("add.w $t0, %1, %z5", ret, oldval, uaddr, oparg); 45 __futex_atomic_op("or $t0, %1, %z5", ret, oldval, uaddr, oparg); 48 __futex_atomic_op("and $t0, %1, %z5", ret, oldval, uaddr, ~oparg); 51 __futex_atomic_op("xor $t0, %1, %z5", ret, oldval, uaddr, oparg);
|
/linux-master/arch/arc/include/asm/ |
H A D | futex.h | 18 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg)\ macro 46 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg)\ macro 87 __futex_atomic_op("mov %0, %3", ret, oldval, uaddr, oparg); 91 __futex_atomic_op("add %0, %1, %3", ret, oldval, uaddr, oparg); 94 __futex_atomic_op("or %0, %1, %3", ret, oldval, uaddr, oparg); 97 __futex_atomic_op("bic %0, %1, %3", ret, oldval, uaddr, oparg); 100 __futex_atomic_op("xor %0, %1, %3", ret, oldval, uaddr, oparg);
|
/linux-master/arch/xtensa/include/asm/ |
H A D | futex.h | 24 #define __futex_atomic_op(insn, ret, old, uaddr, arg) \ macro 48 #define __futex_atomic_op(insn, ret, old, uaddr, arg) \ macro 84 __futex_atomic_op("mov %[newval], %[oparg]", 88 __futex_atomic_op("add %[newval], %[oldval], %[oparg]", 92 __futex_atomic_op("or %[newval], %[oldval], %[oparg]", 96 __futex_atomic_op("and %[newval], %[oldval], %[oparg]", 100 __futex_atomic_op("xor %[newval], %[oldval], %[oparg]",
|
/linux-master/arch/csky/include/asm/ |
H A D | futex.h | 14 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 51 __futex_atomic_op("mov %[t], %[ov]", 55 __futex_atomic_op("add %[t], %[ov], %[op]", 59 __futex_atomic_op("or %[t], %[ov], %[op]", 63 __futex_atomic_op("and %[t], %[ov], %[op]", 67 __futex_atomic_op("xor %[t], %[ov], %[op]",
|
/linux-master/arch/arm64/include/asm/ |
H A D | futex.h | 15 #define __futex_atomic_op(insn, ret, oldval, uaddr, tmp, oparg) \ macro 51 __futex_atomic_op("mov %w3, %w5", 55 __futex_atomic_op("add %w3, %w1, %w5", 59 __futex_atomic_op("orr %w3, %w1, %w5", 63 __futex_atomic_op("and %w3, %w1, %w5", 67 __futex_atomic_op("eor %w3, %w1, %w5",
|
/linux-master/arch/riscv/include/asm/ |
H A D | futex.h | 22 #define __futex_atomic_op(insn, ret, oldval, uaddr, oparg) \ macro 46 __futex_atomic_op("amoswap.w.aqrl %[ov],%z[op],%[u]", 50 __futex_atomic_op("amoadd.w.aqrl %[ov],%z[op],%[u]", 54 __futex_atomic_op("amoor.w.aqrl %[ov],%z[op],%[u]", 58 __futex_atomic_op("amoand.w.aqrl %[ov],%z[op],%[u]", 62 __futex_atomic_op("amoxor.w.aqrl %[ov],%z[op],%[u]",
|
/linux-master/arch/arm/include/asm/ |
H A D | futex.h | 25 #define __futex_atomic_op(insn, ret, oldval, tmp, uaddr, oparg) \ macro 84 #define __futex_atomic_op(insn, ret, oldval, tmp, uaddr, oparg) \ macro 146 __futex_atomic_op("mov %0, %4", ret, oldval, tmp, uaddr, oparg); 149 __futex_atomic_op("add %0, %1, %4", ret, oldval, tmp, uaddr, oparg); 152 __futex_atomic_op("orr %0, %1, %4", ret, oldval, tmp, uaddr, oparg); 155 __futex_atomic_op("and %0, %1, %4", ret, oldval, tmp, uaddr, ~oparg); 158 __futex_atomic_op("eor %0, %1, %4", ret, oldval, tmp, uaddr, oparg); 170 * of the worries but GCC cannot figure out that __futex_atomic_op()
|
/linux-master/arch/mips/include/asm/ |
H A D | futex.h | 25 #define __futex_atomic_op(op, insn, ret, oldval, uaddr, oparg) \ macro 33 "1: ll %1, %4 # __futex_atomic_op \n" \ 63 "1: "user_ll("%1", "%4")" # __futex_atomic_op\n" \ 102 __futex_atomic_op(op, "move $1, %z5", ret, oldval, uaddr, oparg); 106 __futex_atomic_op(op, "addu $1, %1, %z5", 110 __futex_atomic_op(op, "or $1, %1, %z5", 114 __futex_atomic_op(op, "and $1, %1, %z5", 118 __futex_atomic_op(op, "xor $1, %1, %z5",
|