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

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