atomics/treewide: Make test ops optional
Some of the atomics return the result of a test applied after the atomic operation, and almost all architectures implement these as trivial wrappers around the underlying atomic. Specifically: * <atomic>_inc_and_test(v) is (<atomic>_inc_return(v) == 0) * <atomic>_dec_and_test(v) is (<atomic>_dec_return(v) == 0) * <atomic>_sub_and_test(i, v) is (<atomic>_sub_return(i, v) == 0) * <atomic>_add_negative(i, v) is (<atomic>_add_return(i, v) < 0) Rather than have these definitions duplicated in all architectures, with minor inconsistencies in formatting and documentation, let's make these operations optional, with default fallbacks as above. Implementations must now provide a preprocessor symbol. The instrumented atomics are updated accordingly. Both x86 and m68k have custom implementations, which are left as-is, given preprocessor symbols to avoid being overridden. There should be no functional change as a result of this patch. Signed-off-by:Mark Rutland <mark.rutland@arm.com> Reviewed-by:
Will Deacon <will.deacon@arm.com> Acked-by:
Geert Uytterhoeven <geert@linux-m68k.org> Acked-by:
Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by:
Palmer Dabbelt <palmer@sifive.com> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Thomas Gleixner <tglx@linutronix.de> Link: https://lore.kernel.org/lkml/20180621121321.4761-16-mark.rutland@arm.com Signed-off-by:
Ingo Molnar <mingo@kernel.org>
Showing
- arch/alpha/include/asm/atomic.h 0 additions, 12 deletionsarch/alpha/include/asm/atomic.h
- arch/arc/include/asm/atomic.h 0 additions, 10 deletionsarch/arc/include/asm/atomic.h
- arch/arm/include/asm/atomic.h 0 additions, 9 deletionsarch/arm/include/asm/atomic.h
- arch/arm64/include/asm/atomic.h 0 additions, 8 deletionsarch/arm64/include/asm/atomic.h
- arch/h8300/include/asm/atomic.h 0 additions, 5 deletionsarch/h8300/include/asm/atomic.h
- arch/hexagon/include/asm/atomic.h 0 additions, 5 deletionsarch/hexagon/include/asm/atomic.h
- arch/ia64/include/asm/atomic.h 0 additions, 23 deletionsarch/ia64/include/asm/atomic.h
- arch/m68k/include/asm/atomic.h 4 additions, 0 deletionsarch/m68k/include/asm/atomic.h
- arch/mips/include/asm/atomic.h 0 additions, 84 deletionsarch/mips/include/asm/atomic.h
- arch/parisc/include/asm/atomic.h 0 additions, 22 deletionsarch/parisc/include/asm/atomic.h
- arch/powerpc/include/asm/atomic.h 0 additions, 30 deletionsarch/powerpc/include/asm/atomic.h
- arch/riscv/include/asm/atomic.h 0 additions, 46 deletionsarch/riscv/include/asm/atomic.h
- arch/s390/include/asm/atomic.h 0 additions, 8 deletionsarch/s390/include/asm/atomic.h
- arch/sh/include/asm/atomic.h 0 additions, 4 deletionsarch/sh/include/asm/atomic.h
- arch/sparc/include/asm/atomic_32.h 0 additions, 15 deletionsarch/sparc/include/asm/atomic_32.h
- arch/sparc/include/asm/atomic_64.h 0 additions, 20 deletionsarch/sparc/include/asm/atomic_64.h
- arch/x86/include/asm/atomic.h 4 additions, 0 deletionsarch/x86/include/asm/atomic.h
- arch/x86/include/asm/atomic64_32.h 0 additions, 54 deletionsarch/x86/include/asm/atomic64_32.h
- arch/x86/include/asm/atomic64_64.h 4 additions, 0 deletionsarch/x86/include/asm/atomic64_64.h
- arch/xtensa/include/asm/atomic.h 0 additions, 42 deletionsarch/xtensa/include/asm/atomic.h
Please register or sign in to comment