All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] arm64/neon: Disable -Wincompatible-pointer-types when building with Clang
@ 2019-02-15  1:39 ` Nathan Chancellor
  0 siblings, 0 replies; 22+ messages in thread
From: Nathan Chancellor @ 2019-02-15  1:39 UTC (permalink / raw)
  To: Catalin Marinas, Will Deacon
  Cc: Ard Biesheuvel, Kevin Hilman, Nick Desaulniers, linux-kernel,
	Mark Brown, Nathan Chancellor, linux-arm-kernel

After commit cc9f8349cb33 ("arm64: crypto: add NEON accelerated XOR
implementation"), Clang builds for arm64 started failing with the
following error message.

arch/arm64/lib/xor-neon.c:58:28: error: incompatible pointer types
assigning to 'const unsigned long *' from 'uint64_t *' (aka 'unsigned
long long *') [-Werror,-Wincompatible-pointer-types]
                v3 = veorq_u64(vld1q_u64(dp1 +  6), vld1q_u64(dp2 + 6));
                                         ^~~~~~~~
/usr/lib/llvm-9/lib/clang/9.0.0/include/arm_neon.h:7538:47: note:
expanded from macro 'vld1q_u64'
  __ret = (uint64x2_t) __builtin_neon_vld1q_v(__p0, 51); \
                                              ^~~~

There has been quite a bit of debate and triage that has gone into
figuring out what the proper fix is, viewable at the link below, which
is still ongoing. Ard suggested disabling this warning with Clang with a
pragma so no neon code will have this type of error. While this is not
at all an ideal solution, this build error is the only thing preventing
KernelCI from having successful arm64 defconfig and allmodconfig builds
on linux-next. Getting continuous integration running is more important
so new warnings/errors or boot failures can be caught and fixed quickly.

Link: https://github.com/ClangBuiltLinux/linux/issues/283
Suggested-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Nathan Chancellor <natechancellor@gmail.com>
---
 arch/arm64/include/asm/neon-intrinsics.h | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/arch/arm64/include/asm/neon-intrinsics.h b/arch/arm64/include/asm/neon-intrinsics.h
index 2ba6c6b9541f..71abfc7612b2 100644
--- a/arch/arm64/include/asm/neon-intrinsics.h
+++ b/arch/arm64/include/asm/neon-intrinsics.h
@@ -36,4 +36,8 @@
 #include <arm_neon.h>
 #endif
 
+#ifdef CONFIG_CC_IS_CLANG
+#pragma clang diagnostic ignored "-Wincompatible-pointer-types"
+#endif
+
 #endif /* __ASM_NEON_INTRINSICS_H */
-- 
2.21.0.rc1


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply related	[flat|nested] 22+ messages in thread

end of thread, other threads:[~2019-02-19 11:35 UTC | newest]

Thread overview: 22+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-02-15  1:39 [PATCH] arm64/neon: Disable -Wincompatible-pointer-types when building with Clang Nathan Chancellor
2019-02-15  1:39 ` Nathan Chancellor
2019-02-15 11:50 ` Mark Brown
2019-02-15 11:50   ` Mark Brown
2019-02-15 18:50 ` Will Deacon
2019-02-15 18:50   ` Will Deacon
2019-02-15 19:20   ` Ard Biesheuvel
2019-02-15 19:20     ` Ard Biesheuvel
2019-02-15 19:25     ` Nick Desaulniers
2019-02-15 19:25       ` Nick Desaulniers
2019-02-15 19:28       ` Ard Biesheuvel
2019-02-15 19:28         ` Ard Biesheuvel
2019-02-15 19:43         ` Nick Desaulniers
2019-02-15 19:43           ` Nick Desaulniers
2019-02-15 19:45           ` Ard Biesheuvel
2019-02-15 19:45             ` Ard Biesheuvel
2019-02-19 10:35             ` Ard Biesheuvel
2019-02-19 10:35               ` Ard Biesheuvel
2019-02-19 11:19               ` Greg KH
2019-02-19 11:19                 ` Greg KH
2019-02-19 11:35                 ` Ard Biesheuvel
2019-02-19 11:35                   ` Ard Biesheuvel

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.