kasan: support instrumented bitops combined with generic bitops
authorDaniel Axtens <dja@axtens.net>
Tue, 20 Aug 2019 02:49:40 +0000 (12:49 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 7 Nov 2019 02:15:39 +0000 (13:15 +1100)
commit81d2c6f81996e01fbcd2b5aeefbb519e21c806e9
tree33c5485ffb75626553956021e777a02c34e8d991
parentda0c9ea146cbe92b832f1b0f694840ea8eb33cce
kasan: support instrumented bitops combined with generic bitops

Currently bitops-instrumented.h assumes that the architecture provides
atomic, non-atomic and locking bitops (e.g. both set_bit and __set_bit).
This is true on x86 and s390, but is not always true: there is a
generic bitops/non-atomic.h header that provides generic non-atomic
operations, and also a generic bitops/lock.h for locking operations.

powerpc uses the generic non-atomic version, so it does not have it's
own e.g. __set_bit that could be renamed arch___set_bit.

Split up bitops-instrumented.h to mirror the atomic/non-atomic/lock
split. This allows arches to only include the headers where they
have arch-specific versions to rename. Update x86 and s390.

(The generic operations are automatically instrumented because they're
written in C, not asm.)

Suggested-by: Christophe Leroy <christophe.leroy@c-s.fr>
Reviewed-by: Christophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: Daniel Axtens <dja@axtens.net>
Acked-by: Marco Elver <elver@google.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20190820024941.12640-1-dja@axtens.net
Documentation/core-api/kernel-api.rst
arch/s390/include/asm/bitops.h
arch/x86/include/asm/bitops.h
include/asm-generic/bitops-instrumented.h [deleted file]
include/asm-generic/bitops/instrumented-atomic.h [new file with mode: 0644]
include/asm-generic/bitops/instrumented-lock.h [new file with mode: 0644]
include/asm-generic/bitops/instrumented-non-atomic.h [new file with mode: 0644]