|
@@ -202,4 +202,77 @@
|
|
|
|
|
|
#endif /* COMPILER_HAS_GENERIC_BUILTIN_OVERFLOW */
|
|
#endif /* COMPILER_HAS_GENERIC_BUILTIN_OVERFLOW */
|
|
|
|
|
|
|
|
+/**
|
|
|
|
+ * array_size() - Calculate size of 2-dimensional array.
|
|
|
|
+ *
|
|
|
|
+ * @a: dimension one
|
|
|
|
+ * @b: dimension two
|
|
|
|
+ *
|
|
|
|
+ * Calculates size of 2-dimensional array: @a * @b.
|
|
|
|
+ *
|
|
|
|
+ * Returns: number of bytes needed to represent the array or SIZE_MAX on
|
|
|
|
+ * overflow.
|
|
|
|
+ */
|
|
|
|
+static inline __must_check size_t array_size(size_t a, size_t b)
|
|
|
|
+{
|
|
|
|
+ size_t bytes;
|
|
|
|
+
|
|
|
|
+ if (check_mul_overflow(a, b, &bytes))
|
|
|
|
+ return SIZE_MAX;
|
|
|
|
+
|
|
|
|
+ return bytes;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * array3_size() - Calculate size of 3-dimensional array.
|
|
|
|
+ *
|
|
|
|
+ * @a: dimension one
|
|
|
|
+ * @b: dimension two
|
|
|
|
+ * @c: dimension three
|
|
|
|
+ *
|
|
|
|
+ * Calculates size of 3-dimensional array: @a * @b * @c.
|
|
|
|
+ *
|
|
|
|
+ * Returns: number of bytes needed to represent the array or SIZE_MAX on
|
|
|
|
+ * overflow.
|
|
|
|
+ */
|
|
|
|
+static inline __must_check size_t array3_size(size_t a, size_t b, size_t c)
|
|
|
|
+{
|
|
|
|
+ size_t bytes;
|
|
|
|
+
|
|
|
|
+ if (check_mul_overflow(a, b, &bytes))
|
|
|
|
+ return SIZE_MAX;
|
|
|
|
+ if (check_mul_overflow(bytes, c, &bytes))
|
|
|
|
+ return SIZE_MAX;
|
|
|
|
+
|
|
|
|
+ return bytes;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static inline __must_check size_t __ab_c_size(size_t n, size_t size, size_t c)
|
|
|
|
+{
|
|
|
|
+ size_t bytes;
|
|
|
|
+
|
|
|
|
+ if (check_mul_overflow(n, size, &bytes))
|
|
|
|
+ return SIZE_MAX;
|
|
|
|
+ if (check_add_overflow(bytes, c, &bytes))
|
|
|
|
+ return SIZE_MAX;
|
|
|
|
+
|
|
|
|
+ return bytes;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * struct_size() - Calculate size of structure with trailing array.
|
|
|
|
+ * @p: Pointer to the structure.
|
|
|
|
+ * @member: Name of the array member.
|
|
|
|
+ * @n: Number of elements in the array.
|
|
|
|
+ *
|
|
|
|
+ * Calculates size of memory needed for structure @p followed by an
|
|
|
|
+ * array of @n @member elements.
|
|
|
|
+ *
|
|
|
|
+ * Return: number of bytes needed or SIZE_MAX on overflow.
|
|
|
|
+ */
|
|
|
|
+#define struct_size(p, member, n) \
|
|
|
|
+ __ab_c_size(n, \
|
|
|
|
+ sizeof(*(p)->member) + __must_be_array((p)->member),\
|
|
|
|
+ sizeof(*(p)))
|
|
|
|
+
|
|
#endif /* __LINUX_OVERFLOW_H */
|
|
#endif /* __LINUX_OVERFLOW_H */
|