From 674fdb19de63084de5ad23b8d3db7127a1c514bd Mon Sep 17 00:00:00 2001 From: Ken Raeburn Date: Wed, 20 Mar 2024 09:39:07 -0400 Subject: [PATCH] dm vdo: use kernel byteswapping routines instead of GCC ones Reported-by: Guenter Roeck Signed-off-by: Ken Raeburn Signed-off-by: Matthew Sakai --- drivers/md/dm-vdo/murmurhash3.c | 18 ++++-------------- 1 file changed, 4 insertions(+), 14 deletions(-) diff --git a/drivers/md/dm-vdo/murmurhash3.c b/drivers/md/dm-vdo/murmurhash3.c index 00c9b9c05001..124026cb676a 100644 --- a/drivers/md/dm-vdo/murmurhash3.c +++ b/drivers/md/dm-vdo/murmurhash3.c @@ -8,6 +8,8 @@ #include "murmurhash3.h" +#include + static inline u64 rotl64(u64 x, s8 r) { return (x << r) | (x >> (64 - r)); @@ -16,24 +18,12 @@ static inline u64 rotl64(u64 x, s8 r) #define ROTL64(x, y) rotl64(x, y) static __always_inline u64 getblock64(const u64 *p, int i) { -#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ - return p[i]; -#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ - return __builtin_bswap64(p[i]); -#else -#error "can't figure out byte order" -#endif + return le64_to_cpup(&p[i]); } static __always_inline void putblock64(u64 *p, int i, u64 value) { -#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ - p[i] = value; -#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ - p[i] = __builtin_bswap64(value); -#else -#error "can't figure out byte order" -#endif + p[i] = cpu_to_le64(value); } /* Finalization mix - force all bits of a hash block to avalanche */