On Mon, Feb 26, 2018 at 03:04:56PM +0000, Will Deacon wrote: > Having asm/cmpxchg.h pull in linux/bug.h is problematic because this > ends up pulling in the atomic bitops which themselves may be built on > top of atomic.h and cmpxchg.h. > > Instead, just include build_bug.h for the definition of BUILD_BUG.
We also use VM_BUG_ON(), defined in <linux/mmdebug.h>, which includes <linux/bug.h>. ... so I think we still have some fragility here, albeit no worse than before. We also miss includes for: * <linux/percpu-defs.h> (raw_cpu_ptr) * <linux/preempt.h> (preempt_disable, preempt_enable) * <linux/compiler.h> (unreachable) I'm not sure if those are made worse by this change. Mark. > > Signed-off-by: Will Deacon <[email protected]> > --- > arch/arm64/include/asm/cmpxchg.h | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/arch/arm64/include/asm/cmpxchg.h > b/arch/arm64/include/asm/cmpxchg.h > index ae852add053d..bc9e07bc6428 100644 > --- a/arch/arm64/include/asm/cmpxchg.h > +++ b/arch/arm64/include/asm/cmpxchg.h > @@ -18,7 +18,7 @@ > #ifndef __ASM_CMPXCHG_H > #define __ASM_CMPXCHG_H > > -#include <linux/bug.h> > +#include <linux/build_bug.h> > > #include <asm/atomic.h> > #include <asm/barrier.h> > -- > 2.1.4 > > > _______________________________________________ > linux-arm-kernel mailing list > [email protected] > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

