@@ -1315,6 +1315,10 @@ PHONY += scripts_unifdef
scripts_unifdef: scripts_basic
$(Q)$(MAKE) $(build)=scripts scripts/unifdef
+PHONY += scripts_gen_packed_field_checks
+scripts_gen_packed_field_checks: scripts_basic
+ $(Q)$(MAKE) $(build)=scripts scripts/gen_packed_field_checks
+
# ---------------------------------------------------------------------------
# Install
@@ -7,6 +7,7 @@
#include <linux/types.h>
#include <linux/bitops.h>
+#include <linux/packing_types.h>
#define QUIRK_MSB_ON_THE_RIGHT BIT(0)
#define QUIRK_LITTLE_ENDIAN BIT(1)
@@ -26,4 +27,40 @@ int pack(void *pbuf, u64 uval, size_t startbit, size_t endbit, size_t pbuflen,
int unpack(const void *pbuf, u64 *uval, size_t startbit, size_t endbit,
size_t pbuflen, u8 quirks);
+void pack_fields_s(void *pbuf, size_t pbuflen, const void *ustruct,
+ const struct packed_field_s *fields, size_t num_fields,
+ u8 quirks);
+
+void pack_fields_m(void *pbuf, size_t pbuflen, const void *ustruct,
+ const struct packed_field_m *fields, size_t num_fields,
+ u8 quirks);
+
+void unpack_fields_s(const void *pbuf, size_t pbuflen, void *ustruct,
+ const struct packed_field_s *fields, size_t num_fields,
+ u8 quirks);
+
+void unpack_fields_m(const void *pbuf, size_t pbuflen, void *ustruct,
+ const struct packed_field_m *fields, size_t num_fields,
+ u8 quirks);
+
+#define pack_fields(pbuf, pbuflen, ustruct, fields, quirks) \
+ ({ \
+ CHECK_PACKED_FIELDS(fields); \
+ CHECK_PACKED_FIELDS_SIZE((fields), (pbuflen)); \
+ _Generic((fields), \
+ const struct packed_field_s * : pack_fields_s, \
+ const struct packed_field_m * : pack_fields_m \
+ )((pbuf), (pbuflen), (ustruct), (fields), ARRAY_SIZE(fields), (quirks)); \
+ })
+
+#define unpack_fields(pbuf, pbuflen, ustruct, fields, quirks) \
+ ({ \
+ CHECK_PACKED_FIELDS(fields); \
+ CHECK_PACKED_FIELDS_SIZE((fields), (pbuflen)); \
+ _Generic((fields), \
+ const struct packed_field_s * : unpack_fields_s, \
+ const struct packed_field_m * : unpack_fields_m \
+ )((pbuf), (pbuflen), (ustruct), (fields), ARRAY_SIZE(fields), (quirks)); \
+ })
+
#endif
new file mode 100644
@@ -0,0 +1,2831 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright (c) 2024, Intel Corporation
+ * Copyright (c) 2024, Vladimir Oltean <olteanv@gmail.com>
+ */
+#ifndef _LINUX_PACKING_TYPES_H
+#define _LINUX_PACKING_TYPES_H
+
+#include <linux/types.h>
+
+/* If you add another packed field type, please update
+ * scripts/mod/packed_fields.c to enable compile time sanity checks.
+ */
+
+#define GEN_PACKED_FIELD_MEMBERS(__type) \
+ __type startbit; \
+ __type endbit; \
+ __type offset; \
+ __type size
+
+/* Small packed field. Use with bit offsets < 256, buffers < 32B and
+ * unpacked structures < 256B.
+ */
+struct packed_field_s {
+ GEN_PACKED_FIELD_MEMBERS(u8);
+};
+
+/* Medium packed field. Use with bit offsets < 65536, buffers < 8KB and
+ * unpacked structures < 64KB.
+ */
+struct packed_field_m {
+ GEN_PACKED_FIELD_MEMBERS(u16);
+};
+
+#define PACKED_FIELD(start, end, struct_name, struct_field) \
+{ \
+ (start), \
+ (end), \
+ offsetof(struct_name, struct_field), \
+ sizeof_field(struct_name, struct_field), \
+}
+
+#define CHECK_PACKED_FIELD(field) ({ \
+ typeof(field) __f = (field); \
+ BUILD_BUG_ON(__f.startbit < __f.endbit); \
+ BUILD_BUG_ON(__f.startbit - __f.endbit >= BITS_PER_BYTE * __f.size); \
+ BUILD_BUG_ON(__f.size != 1 && __f.size != 2 && \
+ __f.size != 4 && __f.size != 8); \
+})
+
+
+#define CHECK_PACKED_FIELD_OVERLAP(ascending, field1, field2) ({ \
+ typeof(field1) _f1 = (field1); typeof(field2) _f2 = (field2); \
+ const bool _a = (ascending); \
+ BUILD_BUG_ON(_a && _f1.startbit >= _f2.startbit); \
+ BUILD_BUG_ON(!_a && _f1.startbit <= _f2.startbit); \
+ BUILD_BUG_ON(max(_f1.endbit, _f2.endbit) <= \
+ min(_f1.startbit, _f2.startbit)); \
+})
+
+#define CHECK_PACKED_FIELDS_SIZE(fields, pbuflen) ({ \
+ typeof(&(fields)[0]) _f = (fields); \
+ typeof(pbuflen) _len = (pbuflen); \
+ const size_t num_fields = ARRAY_SIZE(fields); \
+ BUILD_BUG_ON(!__builtin_constant_p(_len)); \
+ BUILD_BUG_ON(_f[0].startbit >= BITS_PER_BYTE * _len); \
+ BUILD_BUG_ON(_f[num_fields - 1].startbit >= BITS_PER_BYTE * _len); \
+})
+
+/* Do not hand-edit the following packed field check macros!
+ *
+ * They are generated using scripts/gen_packed_field_checks.c, which may be
+ * built via "make scripts_gen_packed_field_checks". If larger macro sizes are
+ * needed in the future, please use this program to re-generate the macros and
+ * insert them here.
+ */
+
+#define CHECK_PACKED_FIELDS_1(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 1); \
+ CHECK_PACKED_FIELD(_f[0]); })
+
+#define CHECK_PACKED_FIELDS_2(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 2); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); })
+
+#define CHECK_PACKED_FIELDS_3(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 3); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); })
+
+#define CHECK_PACKED_FIELDS_4(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 4); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); })
+
+#define CHECK_PACKED_FIELDS_5(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 5); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); })
+
+#define CHECK_PACKED_FIELDS_6(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 6); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); })
+
+#define CHECK_PACKED_FIELDS_7(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 7); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); })
+
+#define CHECK_PACKED_FIELDS_8(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 8); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); })
+
+#define CHECK_PACKED_FIELDS_9(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 9); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); })
+
+#define CHECK_PACKED_FIELDS_10(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 10); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); })
+
+#define CHECK_PACKED_FIELDS_11(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 11); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); })
+
+#define CHECK_PACKED_FIELDS_12(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 12); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); })
+
+#define CHECK_PACKED_FIELDS_13(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 13); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); })
+
+#define CHECK_PACKED_FIELDS_14(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 14); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); })
+
+#define CHECK_PACKED_FIELDS_15(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 15); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); })
+
+#define CHECK_PACKED_FIELDS_16(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 16); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); })
+
+#define CHECK_PACKED_FIELDS_17(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 17); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); })
+
+#define CHECK_PACKED_FIELDS_18(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 18); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); })
+
+#define CHECK_PACKED_FIELDS_19(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 19); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); })
+
+#define CHECK_PACKED_FIELDS_20(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 20); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); })
+
+#define CHECK_PACKED_FIELDS_21(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 21); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); })
+
+#define CHECK_PACKED_FIELDS_22(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 22); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); })
+
+#define CHECK_PACKED_FIELDS_23(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 23); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); })
+
+#define CHECK_PACKED_FIELDS_24(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 24); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); })
+
+#define CHECK_PACKED_FIELDS_25(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 25); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); })
+
+#define CHECK_PACKED_FIELDS_26(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 26); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); })
+
+#define CHECK_PACKED_FIELDS_27(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 27); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); })
+
+#define CHECK_PACKED_FIELDS_28(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 28); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); })
+
+#define CHECK_PACKED_FIELDS_29(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 29); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); })
+
+#define CHECK_PACKED_FIELDS_30(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 30); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); })
+
+#define CHECK_PACKED_FIELDS_31(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 31); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); })
+
+#define CHECK_PACKED_FIELDS_32(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 32); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); })
+
+#define CHECK_PACKED_FIELDS_33(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 33); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); })
+
+#define CHECK_PACKED_FIELDS_34(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 34); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); })
+
+#define CHECK_PACKED_FIELDS_35(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 35); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); })
+
+#define CHECK_PACKED_FIELDS_36(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 36); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); })
+
+#define CHECK_PACKED_FIELDS_37(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 37); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); })
+
+#define CHECK_PACKED_FIELDS_38(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 38); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); })
+
+#define CHECK_PACKED_FIELDS_39(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 39); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); })
+
+#define CHECK_PACKED_FIELDS_40(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 40); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); })
+
+#define CHECK_PACKED_FIELDS_41(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 41); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); })
+
+#define CHECK_PACKED_FIELDS_42(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 42); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); })
+
+#define CHECK_PACKED_FIELDS_43(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 43); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); })
+
+#define CHECK_PACKED_FIELDS_44(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 44); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); })
+
+#define CHECK_PACKED_FIELDS_45(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 45); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); })
+
+#define CHECK_PACKED_FIELDS_46(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 46); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD(_f[45]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[44], _f[45]); })
+
+#define CHECK_PACKED_FIELDS_47(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 47); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD(_f[45]); \
+ CHECK_PACKED_FIELD(_f[46]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[44], _f[45]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[45], _f[46]); })
+
+#define CHECK_PACKED_FIELDS_48(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 48); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD(_f[45]); \
+ CHECK_PACKED_FIELD(_f[46]); \
+ CHECK_PACKED_FIELD(_f[47]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[44], _f[45]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[45], _f[46]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[46], _f[47]); })
+
+#define CHECK_PACKED_FIELDS_49(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 49); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD(_f[45]); \
+ CHECK_PACKED_FIELD(_f[46]); \
+ CHECK_PACKED_FIELD(_f[47]); \
+ CHECK_PACKED_FIELD(_f[48]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[44], _f[45]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[45], _f[46]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[46], _f[47]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[47], _f[48]); })
+
+#define CHECK_PACKED_FIELDS_50(fields) \
+ ({ typeof(&(fields)[0]) _f = (fields); \
+ BUILD_BUG_ON(ARRAY_SIZE(fields) != 50); \
+ CHECK_PACKED_FIELD(_f[0]); \
+ CHECK_PACKED_FIELD(_f[1]); \
+ CHECK_PACKED_FIELD(_f[2]); \
+ CHECK_PACKED_FIELD(_f[3]); \
+ CHECK_PACKED_FIELD(_f[4]); \
+ CHECK_PACKED_FIELD(_f[5]); \
+ CHECK_PACKED_FIELD(_f[6]); \
+ CHECK_PACKED_FIELD(_f[7]); \
+ CHECK_PACKED_FIELD(_f[8]); \
+ CHECK_PACKED_FIELD(_f[9]); \
+ CHECK_PACKED_FIELD(_f[10]); \
+ CHECK_PACKED_FIELD(_f[11]); \
+ CHECK_PACKED_FIELD(_f[12]); \
+ CHECK_PACKED_FIELD(_f[13]); \
+ CHECK_PACKED_FIELD(_f[14]); \
+ CHECK_PACKED_FIELD(_f[15]); \
+ CHECK_PACKED_FIELD(_f[16]); \
+ CHECK_PACKED_FIELD(_f[17]); \
+ CHECK_PACKED_FIELD(_f[18]); \
+ CHECK_PACKED_FIELD(_f[19]); \
+ CHECK_PACKED_FIELD(_f[20]); \
+ CHECK_PACKED_FIELD(_f[21]); \
+ CHECK_PACKED_FIELD(_f[22]); \
+ CHECK_PACKED_FIELD(_f[23]); \
+ CHECK_PACKED_FIELD(_f[24]); \
+ CHECK_PACKED_FIELD(_f[25]); \
+ CHECK_PACKED_FIELD(_f[26]); \
+ CHECK_PACKED_FIELD(_f[27]); \
+ CHECK_PACKED_FIELD(_f[28]); \
+ CHECK_PACKED_FIELD(_f[29]); \
+ CHECK_PACKED_FIELD(_f[30]); \
+ CHECK_PACKED_FIELD(_f[31]); \
+ CHECK_PACKED_FIELD(_f[32]); \
+ CHECK_PACKED_FIELD(_f[33]); \
+ CHECK_PACKED_FIELD(_f[34]); \
+ CHECK_PACKED_FIELD(_f[35]); \
+ CHECK_PACKED_FIELD(_f[36]); \
+ CHECK_PACKED_FIELD(_f[37]); \
+ CHECK_PACKED_FIELD(_f[38]); \
+ CHECK_PACKED_FIELD(_f[39]); \
+ CHECK_PACKED_FIELD(_f[40]); \
+ CHECK_PACKED_FIELD(_f[41]); \
+ CHECK_PACKED_FIELD(_f[42]); \
+ CHECK_PACKED_FIELD(_f[43]); \
+ CHECK_PACKED_FIELD(_f[44]); \
+ CHECK_PACKED_FIELD(_f[45]); \
+ CHECK_PACKED_FIELD(_f[46]); \
+ CHECK_PACKED_FIELD(_f[47]); \
+ CHECK_PACKED_FIELD(_f[48]); \
+ CHECK_PACKED_FIELD(_f[49]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[0], _f[1]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[1], _f[2]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[2], _f[3]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[3], _f[4]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[4], _f[5]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[5], _f[6]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[6], _f[7]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[7], _f[8]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[8], _f[9]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[9], _f[10]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[10], _f[11]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[11], _f[12]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[12], _f[13]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[13], _f[14]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[14], _f[15]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[15], _f[16]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[16], _f[17]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[17], _f[18]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[18], _f[19]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[19], _f[20]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[20], _f[21]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[21], _f[22]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[22], _f[23]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[23], _f[24]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[24], _f[25]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[25], _f[26]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[26], _f[27]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[27], _f[28]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[28], _f[29]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[29], _f[30]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[30], _f[31]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[31], _f[32]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[32], _f[33]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[33], _f[34]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[34], _f[35]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[35], _f[36]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[36], _f[37]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[37], _f[38]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[38], _f[39]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[39], _f[40]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[40], _f[41]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[41], _f[42]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[42], _f[43]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[43], _f[44]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[44], _f[45]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[45], _f[46]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[46], _f[47]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[47], _f[48]); \
+ CHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[48], _f[49]); })
+
+#define CHECK_PACKED_FIELDS(fields) \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 1, CHECK_PACKED_FIELDS_1(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 2, CHECK_PACKED_FIELDS_2(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 3, CHECK_PACKED_FIELDS_3(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 4, CHECK_PACKED_FIELDS_4(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 5, CHECK_PACKED_FIELDS_5(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 6, CHECK_PACKED_FIELDS_6(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 7, CHECK_PACKED_FIELDS_7(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 8, CHECK_PACKED_FIELDS_8(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 9, CHECK_PACKED_FIELDS_9(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 10, CHECK_PACKED_FIELDS_10(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 11, CHECK_PACKED_FIELDS_11(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 12, CHECK_PACKED_FIELDS_12(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 13, CHECK_PACKED_FIELDS_13(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 14, CHECK_PACKED_FIELDS_14(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 15, CHECK_PACKED_FIELDS_15(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 16, CHECK_PACKED_FIELDS_16(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 17, CHECK_PACKED_FIELDS_17(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 18, CHECK_PACKED_FIELDS_18(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 19, CHECK_PACKED_FIELDS_19(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 20, CHECK_PACKED_FIELDS_20(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 21, CHECK_PACKED_FIELDS_21(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 22, CHECK_PACKED_FIELDS_22(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 23, CHECK_PACKED_FIELDS_23(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 24, CHECK_PACKED_FIELDS_24(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 25, CHECK_PACKED_FIELDS_25(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 26, CHECK_PACKED_FIELDS_26(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 27, CHECK_PACKED_FIELDS_27(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 28, CHECK_PACKED_FIELDS_28(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 29, CHECK_PACKED_FIELDS_29(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 30, CHECK_PACKED_FIELDS_30(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 31, CHECK_PACKED_FIELDS_31(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 32, CHECK_PACKED_FIELDS_32(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 33, CHECK_PACKED_FIELDS_33(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 34, CHECK_PACKED_FIELDS_34(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 35, CHECK_PACKED_FIELDS_35(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 36, CHECK_PACKED_FIELDS_36(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 37, CHECK_PACKED_FIELDS_37(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 38, CHECK_PACKED_FIELDS_38(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 39, CHECK_PACKED_FIELDS_39(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 40, CHECK_PACKED_FIELDS_40(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 41, CHECK_PACKED_FIELDS_41(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 42, CHECK_PACKED_FIELDS_42(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 43, CHECK_PACKED_FIELDS_43(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 44, CHECK_PACKED_FIELDS_44(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 45, CHECK_PACKED_FIELDS_45(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 46, CHECK_PACKED_FIELDS_46(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 47, CHECK_PACKED_FIELDS_47(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 48, CHECK_PACKED_FIELDS_48(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 49, CHECK_PACKED_FIELDS_49(fields), \
+ __builtin_choose_expr(ARRAY_SIZE(fields) == 50, CHECK_PACKED_FIELDS_50(fields), \
+ ({ BUILD_BUG_ON_MSG(1, "CHECK_PACKED_FIELDS() must be regenerated to support array sizes larger than 50."); }) \
+ ))))))))))))))))))))))))))))))))))))))))))))))))))
+
+#endif
@@ -5,10 +5,37 @@
#include <linux/packing.h>
#include <linux/module.h>
#include <linux/bitops.h>
+#include <linux/bits.h>
#include <linux/errno.h>
#include <linux/types.h>
#include <linux/bitrev.h>
+#define __pack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks) \
+ ({ \
+ for (size_t i = 0; i < (num_fields); i++) { \
+ typeof(&(fields)[0]) field = &(fields)[i]; \
+ u64 uval; \
+ \
+ uval = ustruct_field_to_u64(ustruct, field->offset, field->size); \
+ \
+ __pack(pbuf, uval, field->startbit, field->endbit, \
+ pbuflen, quirks); \
+ } \
+ })
+
+#define __unpack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks) \
+ ({ \
+ for (size_t i = 0; i < (num_fields); i++) { \
+ typeof(&(fields)[0]) field = &fields[i]; \
+ u64 uval; \
+ \
+ __unpack(pbuf, &uval, field->startbit, field->endbit, \
+ pbuflen, quirks); \
+ \
+ u64_to_ustruct_field(ustruct, field->offset, field->size, uval); \
+ } \
+ })
+
/**
* calculate_box_addr - Determine physical location of byte in buffer
* @box: Index of byte within buffer seen as a logical big-endian big number
@@ -322,4 +349,122 @@ int packing(void *pbuf, u64 *uval, int startbit, int endbit, size_t pbuflen,
}
EXPORT_SYMBOL(packing);
+static u64 ustruct_field_to_u64(const void *ustruct, size_t field_offset,
+ size_t field_size)
+{
+ switch (field_size) {
+ case 1:
+ return *((u8 *)(ustruct + field_offset));
+ case 2:
+ return *((u16 *)(ustruct + field_offset));
+ case 4:
+ return *((u32 *)(ustruct + field_offset));
+ default:
+ return *((u64 *)(ustruct + field_offset));
+ }
+}
+
+static void u64_to_ustruct_field(void *ustruct, size_t field_offset,
+ size_t field_size, u64 uval)
+{
+ switch (field_size) {
+ case 1:
+ *((u8 *)(ustruct + field_offset)) = uval;
+ break;
+ case 2:
+ *((u16 *)(ustruct + field_offset)) = uval;
+ break;
+ case 4:
+ *((u32 *)(ustruct + field_offset)) = uval;
+ break;
+ default:
+ *((u64 *)(ustruct + field_offset)) = uval;
+ break;
+ }
+}
+
+/**
+ * pack_fields_s - Pack array of small fields
+ *
+ * @pbuf: Pointer to a buffer holding the packed value.
+ * @pbuflen: The length in bytes of the packed buffer pointed to by @pbuf.
+ * @ustruct: Pointer to CPU-readable structure holding the unpacked value.
+ * It is expected (but not checked) that this has the same data type
+ * as all struct packed_field_s definitions.
+ * @fields: Array of small packed fields definition. They must not overlap.
+ * @num_fields: Length of @fields array.
+ * @quirks: A bit mask of QUIRK_LITTLE_ENDIAN, QUIRK_LSW32_IS_FIRST and
+ * QUIRK_MSB_ON_THE_RIGHT.
+ */
+void pack_fields_s(void *pbuf, size_t pbuflen, const void *ustruct,
+ const struct packed_field_s *fields, size_t num_fields,
+ u8 quirks)
+{
+ __pack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks);
+}
+EXPORT_SYMBOL(pack_fields_s);
+
+/**
+ * pack_fields_m - Pack array of medium fields
+ *
+ * @pbuf: Pointer to a buffer holding the packed value.
+ * @pbuflen: The length in bytes of the packed buffer pointed to by @pbuf.
+ * @ustruct: Pointer to CPU-readable structure holding the unpacked value.
+ * It is expected (but not checked) that this has the same data type
+ * as all struct packed_field_s definitions.
+ * @fields: Array of medium packed fields definition. They must not overlap.
+ * @num_fields: Length of @fields array.
+ * @quirks: A bit mask of QUIRK_LITTLE_ENDIAN, QUIRK_LSW32_IS_FIRST and
+ * QUIRK_MSB_ON_THE_RIGHT.
+ */
+void pack_fields_m(void *pbuf, size_t pbuflen, const void *ustruct,
+ const struct packed_field_m *fields, size_t num_fields,
+ u8 quirks)
+{
+ __pack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks);
+}
+EXPORT_SYMBOL(pack_fields_m);
+
+/**
+ * unpack_fields_s - Unpack array of small fields
+ *
+ * @pbuf: Pointer to a buffer holding the packed value.
+ * @pbuflen: The length in bytes of the packed buffer pointed to by @pbuf.
+ * @ustruct: Pointer to CPU-readable structure holding the unpacked value.
+ * It is expected (but not checked) that this has the same data type
+ * as all struct packed_field_s definitions.
+ * @fields: Array of small packed fields definition. They must not overlap.
+ * @num_fields: Length of @fields array.
+ * @quirks: A bit mask of QUIRK_LITTLE_ENDIAN, QUIRK_LSW32_IS_FIRST and
+ * QUIRK_MSB_ON_THE_RIGHT.
+ */
+void unpack_fields_s(const void *pbuf, size_t pbuflen, void *ustruct,
+ const struct packed_field_s *fields, size_t num_fields,
+ u8 quirks)
+{
+ __unpack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks);
+}
+EXPORT_SYMBOL(unpack_fields_s);
+
+/**
+ * unpack_fields_m - Unpack array of medium fields
+ *
+ * @pbuf: Pointer to a buffer holding the packed value.
+ * @pbuflen: The length in bytes of the packed buffer pointed to by @pbuf.
+ * @ustruct: Pointer to CPU-readable structure holding the unpacked value.
+ * It is expected (but not checked) that this has the same data type
+ * as all struct packed_field_s definitions.
+ * @fields: Array of medium packed fields definition. They must not overlap.
+ * @num_fields: Length of @fields array.
+ * @quirks: A bit mask of QUIRK_LITTLE_ENDIAN, QUIRK_LSW32_IS_FIRST and
+ * QUIRK_MSB_ON_THE_RIGHT.
+ */
+void unpack_fields_m(const void *pbuf, size_t pbuflen, void *ustruct,
+ const struct packed_field_m *fields, size_t num_fields,
+ u8 quirks)
+{
+ __unpack_fields(pbuf, pbuflen, ustruct, fields, num_fields, quirks);
+}
+EXPORT_SYMBOL(unpack_fields_m);
+
MODULE_DESCRIPTION("Generic bitfield packing and unpacking");
@@ -396,9 +396,70 @@ static void packing_test_unpack(struct kunit *test)
KUNIT_EXPECT_EQ(test, uval, params->uval);
}
+#define PACKED_BUF_SIZE 8
+
+typedef struct __packed { u8 buf[PACKED_BUF_SIZE]; } packed_buf_t;
+
+struct test_data {
+ u32 field3;
+ u16 field2;
+ u16 field4;
+ u16 field6;
+ u8 field1;
+ u8 field5;
+};
+
+static const struct packed_field_s test_fields[] = {
+ PACKED_FIELD(63, 61, struct test_data, field1),
+ PACKED_FIELD(60, 52, struct test_data, field2),
+ PACKED_FIELD(51, 28, struct test_data, field3),
+ PACKED_FIELD(27, 14, struct test_data, field4),
+ PACKED_FIELD(13, 9, struct test_data, field5),
+ PACKED_FIELD(8, 0, struct test_data, field6),
+};
+
+static void packing_test_pack_fields(struct kunit *test)
+{
+ const struct test_data data = {
+ .field1 = 0x2,
+ .field2 = 0x100,
+ .field3 = 0xF00050,
+ .field4 = 0x7D3,
+ .field5 = 0x9,
+ .field6 = 0x10B,
+ };
+ packed_buf_t expect = {
+ .buf = { 0x50, 0x0F, 0x00, 0x05, 0x01, 0xF4, 0xD3, 0x0B },
+ };
+ packed_buf_t buf = {};
+
+ pack_fields(&buf, sizeof(buf), &data, test_fields, 0);
+
+ KUNIT_EXPECT_MEMEQ(test, &expect, &buf, sizeof(buf));
+}
+
+static void packing_test_unpack_fields(struct kunit *test)
+{
+ const packed_buf_t buf = {
+ .buf = { 0x17, 0x28, 0x10, 0x19, 0x3D, 0xA9, 0x07, 0x9C },
+ };
+ struct test_data data = {};
+
+ unpack_fields(&buf, sizeof(buf), &data, test_fields, 0);
+
+ KUNIT_EXPECT_EQ(test, 0, data.field1);
+ KUNIT_EXPECT_EQ(test, 0x172, data.field2);
+ KUNIT_EXPECT_EQ(test, 0x810193, data.field3);
+ KUNIT_EXPECT_EQ(test, 0x36A4, data.field4);
+ KUNIT_EXPECT_EQ(test, 0x3, data.field5);
+ KUNIT_EXPECT_EQ(test, 0x19C, data.field6);
+}
+
static struct kunit_case packing_test_cases[] = {
KUNIT_CASE_PARAM(packing_test_pack, packing_gen_params),
KUNIT_CASE_PARAM(packing_test_unpack, packing_gen_params),
+ KUNIT_CASE(packing_test_pack_fields),
+ KUNIT_CASE(packing_test_unpack_fields),
{},
};
new file mode 100644
@@ -0,0 +1,38 @@
+// SPDX-License-Identifier: GPL-2.0
+// Copyright (c) 2024, Intel Corporation
+#include <stdbool.h>
+#include <stdio.h>
+
+#define MAX_PACKED_FIELD_SIZE 50
+
+int main(int argc, char **argv)
+{
+ for (int i = 1; i <= MAX_PACKED_FIELD_SIZE; i++) {
+ printf("#define CHECK_PACKED_FIELDS_%d(fields) ({ \\\n", i);
+ printf("\ttypeof(&(fields)[0]) _f = (fields); \\\n");
+ printf("\tBUILD_BUG_ON(ARRAY_SIZE(fields) != %d); \\\n", i);
+
+ for (int j = 0; j < i; j++)
+ printf("\tCHECK_PACKED_FIELD(_f[%d]); \\\n", j);
+
+ for (int j = 1; j < i; j++)
+ printf("\tCHECK_PACKED_FIELD_OVERLAP(_f[0].startbit < _f[1].startbit, _f[%d], _f[%d]); \\\n",
+ j - 1, j);
+
+ printf("})\n\n");
+ }
+
+ printf("#define CHECK_PACKED_FIELDS(fields) \\\n");
+
+ for (int i = 1; i <= MAX_PACKED_FIELD_SIZE; i++)
+ printf("\t__builtin_choose_expr(ARRAY_SIZE(fields) == %d, CHECK_PACKED_FIELDS_%d(fields), \\\n",
+ i, i);
+
+ printf("\t({ BUILD_BUG_ON_MSG(1, \"CHECK_PACKED_FIELDS() must be regenerated to support array sizes larger than %d.\"); }) \\\n",
+ MAX_PACKED_FIELD_SIZE);
+
+ for (int i = 1; i <= MAX_PACKED_FIELD_SIZE; i++)
+ printf(")");
+
+ printf("\n");
+}
@@ -235,3 +235,61 @@ programmer against incorrect API use. The errors are not expected to occur
during runtime, therefore it is reasonable for xxx_packing() to return void
and simply swallow those errors. Optionally it can dump stack or print the
error description.
+
+The pack_fields() and unpack_fields() macros automatically select the
+appropriate function at compile time based on the type of the fields array
+passed in.
+
+Packed Fields
+-------------
+
+Drivers are encouraged to use the ``pack_fields()`` and ``unpack_fields()``
+APIs over using ``pack()``, ``unpack()``, or ``packing()``.
+
+These APIs use field definitions in arrays of ``struct packed_field_s`` or
+``struct packed_field_m`` stored as ``.rodata``. This significantly reduces
+the code footprint required to pack or unpack many fields. In addition,
+sanity checks on the field definitions are handled at compile time with
+``BUILD_BUG_ON`` rather than only when the offending code is executed.
+
+It is recommended, but not required, that you wrap your packed buffer into a
+structured type with a fixed size. This generally makes it easier for the
+compiler to enforce that the correct size buffer is used.
+
+Here is an example of how to use the fields APIs:
+
+.. code-block:: c
+
+ struct data {
+ u64 field3;
+ u32 field4;
+ u16 field1;
+ u8 field2;
+ };
+
+ #define SIZE 13
+
+ typdef struct __packed { u8 buf[SIZE]; } packed_buf_t;
+
+ static const struct packed_field_s fields[] = {
+ PACKED_FIELD(100, 90, struct data, field1),
+ PACKED_FIELD(90, 87, struct data, field2),
+ PACKED_FIELD(86, 30, struct data, field3),
+ PACKED_FIELD(29, 0, struct data, field4),
+ };
+
+ void unpack_your_data(const packed_buf_t *buf, struct data *unpacked)
+ {
+ BUILD_BUG_ON(sizeof(*buf) != SIZE;
+
+ unpack_fields(buf, sizeof(*buf), unpacked, fields,
+ QUIRK_LITTLE_ENDIAN);
+ }
+
+ void pack_your_data(const struct data *unpacked, packed_buf_t *buf)
+ {
+ BUILD_BUG_ON(sizeof(*buf) != SIZE;
+
+ pack_fields(buf, sizeof(*buf), unpacked, fields,
+ QUIRK_LITTLE_ENDIAN);
+ }
@@ -17559,8 +17559,10 @@ L: netdev@vger.kernel.org
S: Supported
F: Documentation/core-api/packing.rst
F: include/linux/packing.h
+F: include/linux/packing_types.h
F: lib/packing.c
F: lib/packing_test.c
+F: scripts/gen_packed_field_checks.c
PADATA PARALLEL EXECUTION MECHANISM
M: Steffen Klassert <steffen.klassert@secunet.com>
@@ -47,7 +47,7 @@ HOSTCFLAGS_sorttable.o += -DMCOUNT_SORT_ENABLED
endif
# The following programs are only built on demand
-hostprogs += unifdef
+hostprogs += unifdef gen_packed_field_checks
# The module linker script is preprocessed on demand
targets += module.lds