|
@@ -44,6 +44,16 @@ extern const char linux_proc_banner[];
|
|
|
|
|
|
#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
|
|
|
|
|
|
+/*
|
|
|
+ * This looks more complex than it should be. But we need to
|
|
|
+ * get the type for the ~ right in round_down (it needs to be
|
|
|
+ * as wide as the result!), and we want to evaluate the macro
|
|
|
+ * arguments just once each.
|
|
|
+ */
|
|
|
+#define __round_mask(x, y) ((__typeof__(x))((y)-1))
|
|
|
+#define round_up(x, y) ((((x)-1) | __round_mask(x, y))+1)
|
|
|
+#define round_down(x, y) ((x) & ~__round_mask(x, y))
|
|
|
+
|
|
|
#define FIELD_SIZEOF(t, f) (sizeof(((t*)0)->f))
|
|
|
#define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d))
|
|
|
#define roundup(x, y) ((((x) + ((y) - 1)) / (y)) * (y))
|