MIPS: bitops: Use BIT_WORD() & BITS_PER_LONG
authorPaul Burton <paul.burton@mips.com>
Tue, 1 Oct 2019 21:53:34 +0000 (21:53 +0000)
committerPaul Burton <paul.burton@mips.com>
Mon, 7 Oct 2019 16:42:55 +0000 (09:42 -0700)
commitc042be02d730534ee93cb446f194a558b5a84adf
tree15a7eb2062ee388110d88645f2c465964691d6d3
parentcc99987c375e499a95572504d69c215591222072
MIPS: bitops: Use BIT_WORD() & BITS_PER_LONG

Rather than using custom SZLONG_LOG & SZLONG_MASK macros to shift & mask
a bit index to form word & bit offsets respectively, make use of the
standard BIT_WORD() & BITS_PER_LONG macros for the same purpose.

volatile is added to the definition of pointers to the long-sized word
we'll operate on, in order to prevent the compiler complaining that we
cast away the volatile qualifier of the addr argument. This should have
no effect on generated code, which in the LL/SC case is inline asm
anyway & in the non-LLSC case access is constrained by compiler barriers
provided by raw_local_irq_{save,restore}().

Signed-off-by: Paul Burton <paul.burton@mips.com>
Cc: linux-mips@vger.kernel.org
Cc: Huacai Chen <chenhc@lemote.com>
Cc: Jiaxun Yang <jiaxun.yang@flygoat.com>
Cc: linux-kernel@vger.kernel.org
arch/mips/include/asm/bitops.h
arch/mips/include/asm/llsc.h
arch/mips/lib/bitops.c