Blame SOURCES/0028-mdadm.h-Introduced-unaligned-get-put-_unaligned-16-3.patch

5d5466
From 7039d1f8200b9599b23db5953934fdb43b0442e0 Mon Sep 17 00:00:00 2001
5d5466
From: Jes Sorensen <jsorensen@fb.com>
5d5466
Date: Tue, 9 Jul 2019 14:15:38 -0400
5d5466
Subject: [RHEL7.8 PATCH V2 28/47] mdadm.h: Introduced unaligned
5d5466
 {get,put}_unaligned{16,32}()
5d5466
5d5466
We need these to avoid gcc9 going all crazy on us.
5d5466
5d5466
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
5d5466
---
5d5466
 mdadm.h | 30 ++++++++++++++++++++++++++++++
5d5466
 1 file changed, 30 insertions(+)
5d5466
5d5466
diff --git a/mdadm.h b/mdadm.h
5d5466
index 427cc52..0fa9e1b 100644
5d5466
--- a/mdadm.h
5d5466
+++ b/mdadm.h
5d5466
@@ -192,6 +192,36 @@ struct dlm_lksb {
5d5466
 #endif /* __KLIBC__ */
5d5466
 
5d5466
 /*
5d5466
+ * Partially stolen from include/linux/unaligned/packed_struct.h
5d5466
+ */
5d5466
+struct __una_u16 { __u16 x; } __attribute__ ((packed));
5d5466
+struct __una_u32 { __u32 x; } __attribute__ ((packed));
5d5466
+
5d5466
+static inline __u16 __get_unaligned16(const void *p)
5d5466
+{
5d5466
+	const struct __una_u16 *ptr = (const struct __una_u16 *)p;
5d5466
+	return ptr->x;
5d5466
+}
5d5466
+
5d5466
+static inline __u32 __get_unaligned32(const void *p)
5d5466
+{
5d5466
+	const struct __una_u32 *ptr = (const struct __una_u32 *)p;
5d5466
+	return ptr->x;
5d5466
+}
5d5466
+
5d5466
+static inline void __put_unaligned16(__u16 val, void *p)
5d5466
+{
5d5466
+	struct __una_u16 *ptr = (struct __una_u16 *)p;
5d5466
+	ptr->x = val;
5d5466
+}
5d5466
+
5d5466
+static inline void __put_unaligned32(__u32 val, void *p)
5d5466
+{
5d5466
+	struct __una_u32 *ptr = (struct __una_u32 *)p;
5d5466
+	ptr->x = val;
5d5466
+}
5d5466
+
5d5466
+/*
5d5466
   * Check at compile time that something is of a particular type.
5d5466
   * Always evaluates to 1 so you may use it easily in comparisons.
5d5466
 */
5d5466
-- 
5d5466
2.7.5
5d5466