Blame SOURCES/0120-Move-ilog-functions-from-util.c-to-defs.h.patch

9a4987
From c9e41cd3485fa1a65dc6206c5b210b4be4c5597c Mon Sep 17 00:00:00 2001
9a4987
From: =?UTF-8?q?=C3=81kos=20Uzonyi?= <uzonyi.akos@gmail.com>
9a4987
Date: Sat, 13 Jun 2020 18:18:32 +0200
9a4987
Subject: [PATCH 120/138] Move ilog* functions from util.c to defs.h
9a4987
9a4987
* util.c (ILOG2_ITER_, ilog2_klong, ilog2_64, ilog2_32): Move ...
9a4987
* defs.h: ... here.
9a4987
---
9a4987
 defs.h | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
9a4987
 util.c | 62 --------------------------------------------------------------
9a4987
 2 files changed, 60 insertions(+), 62 deletions(-)
9a4987
9a4987
diff --git a/defs.h b/defs.h
9a4987
index 3aa07fb..d8bd513 100644
9a4987
--- a/defs.h
9a4987
+++ b/defs.h
9a4987
@@ -1698,4 +1698,64 @@ scno_is_valid(kernel_ulong_t scno)
9a4987
 
9a4987
 # define SYS_FUNC(syscall_name) int SYS_FUNC_NAME(sys_ ## syscall_name)(struct tcb *tcp)
9a4987
 
9a4987
+#define ILOG2_ITER_(val_, ret_, bit_)					\
9a4987
+	do {								\
9a4987
+		typeof(ret_) shift_ =					\
9a4987
+			((val_) > ((((typeof(val_)) 1)			\
9a4987
+				   << (1 << (bit_))) - 1)) << (bit_);	\
9a4987
+		(val_) >>= shift_;					\
9a4987
+		(ret_) |= shift_;					\
9a4987
+	} while (0)
9a4987
+
9a4987
+/**
9a4987
+ * Calculate floor(log2(val)), with the exception of val == 0, for which 0
9a4987
+ * is returned as well.
9a4987
+ *
9a4987
+ * @param val 64-bit value to calculate integer base-2 logarithm for.
9a4987
+ * @return    (unsigned int) floor(log2(val)) if val > 0, 0 if val == 0.
9a4987
+ */
9a4987
+static inline unsigned int
9a4987
+ilog2_64(uint64_t val)
9a4987
+{
9a4987
+	unsigned int ret = 0;
9a4987
+
9a4987
+	ILOG2_ITER_(val, ret, 5);
9a4987
+	ILOG2_ITER_(val, ret, 4);
9a4987
+	ILOG2_ITER_(val, ret, 3);
9a4987
+	ILOG2_ITER_(val, ret, 2);
9a4987
+	ILOG2_ITER_(val, ret, 1);
9a4987
+	ILOG2_ITER_(val, ret, 0);
9a4987
+
9a4987
+	return ret;
9a4987
+}
9a4987
+
9a4987
+/**
9a4987
+ * Calculate floor(log2(val)), with the exception of val == 0, for which 0
9a4987
+ * is returned as well.
9a4987
+ *
9a4987
+ * @param val 32-bit value to calculate integer base-2 logarithm for.
9a4987
+ * @return    (unsigned int) floor(log2(val)) if val > 0, 0 if val == 0.
9a4987
+ */
9a4987
+static inline unsigned int
9a4987
+ilog2_32(uint32_t val)
9a4987
+{
9a4987
+	unsigned int ret = 0;
9a4987
+
9a4987
+	ILOG2_ITER_(val, ret, 4);
9a4987
+	ILOG2_ITER_(val, ret, 3);
9a4987
+	ILOG2_ITER_(val, ret, 2);
9a4987
+	ILOG2_ITER_(val, ret, 1);
9a4987
+	ILOG2_ITER_(val, ret, 0);
9a4987
+
9a4987
+	return ret;
9a4987
+}
9a4987
+
9a4987
+#if SIZEOF_KERNEL_LONG_T > 4
9a4987
+# define ilog2_klong ilog2_64
9a4987
+#else
9a4987
+# define ilog2_klong ilog2_32
9a4987
+#endif
9a4987
+
9a4987
+#undef ILOG2_ITER_
9a4987
+
9a4987
 #endif /* !STRACE_DEFS_H */
9a4987
diff --git a/util.c b/util.c
9a4987
index 59696b5..cde76c1 100644
9a4987
--- a/util.c
9a4987
+++ b/util.c
9a4987
@@ -1120,68 +1120,6 @@ dumpiov_upto(struct tcb *const tcp, const int len, const kernel_ulong_t addr,
9a4987
 #undef iov
9a4987
 }
9a4987
 
9a4987
-#define ILOG2_ITER_(val_, ret_, bit_)					\
9a4987
-	do {								\
9a4987
-		typeof(ret_) shift_ =					\
9a4987
-			((val_) > ((((typeof(val_)) 1)			\
9a4987
-				   << (1 << (bit_))) - 1)) << (bit_);	\
9a4987
-		(val_) >>= shift_;					\
9a4987
-		(ret_) |= shift_;					\
9a4987
-	} while (0)
9a4987
-
9a4987
-#if SIZEOF_KERNEL_LONG_T > 4
9a4987
-
9a4987
-# define ilog2_klong ilog2_64
9a4987
-/**
9a4987
- * Calculate floor(log2(val)), with the exception of val == 0, for which 0
9a4987
- * is returned as well.
9a4987
- *
9a4987
- * @param val 64-bit value to calculate integer base-2 logarithm for.
9a4987
- * @return    (unsigned int) floor(log2(val)) if val > 0, 0 if val == 0.
9a4987
- */
9a4987
-static inline unsigned int
9a4987
-ilog2_64(uint64_t val)
9a4987
-{
9a4987
-	unsigned int ret = 0;
9a4987
-
9a4987
-	ILOG2_ITER_(val, ret, 5);
9a4987
-	ILOG2_ITER_(val, ret, 4);
9a4987
-	ILOG2_ITER_(val, ret, 3);
9a4987
-	ILOG2_ITER_(val, ret, 2);
9a4987
-	ILOG2_ITER_(val, ret, 1);
9a4987
-	ILOG2_ITER_(val, ret, 0);
9a4987
-
9a4987
-	return ret;
9a4987
-}
9a4987
-
9a4987
-#else /* SIZEOF_KERNEL_LONG_T == 4 */
9a4987
-
9a4987
-# define ilog2_klong ilog2_32
9a4987
-/**
9a4987
- * Calculate floor(log2(val)), with the exception of val == 0, for which 0
9a4987
- * is returned as well.
9a4987
- *
9a4987
- * @param val 32-bit value to calculate integer base-2 logarithm for.
9a4987
- * @return    (unsigned int) floor(log2(val)) if val > 0, 0 if val == 0.
9a4987
- */
9a4987
-static inline unsigned int
9a4987
-ilog2_32(uint32_t val)
9a4987
-{
9a4987
-	unsigned int ret = 0;
9a4987
-
9a4987
-	ILOG2_ITER_(val, ret, 4);
9a4987
-	ILOG2_ITER_(val, ret, 3);
9a4987
-	ILOG2_ITER_(val, ret, 2);
9a4987
-	ILOG2_ITER_(val, ret, 1);
9a4987
-	ILOG2_ITER_(val, ret, 0);
9a4987
-
9a4987
-	return ret;
9a4987
-}
9a4987
-
9a4987
-#endif /* SIZEOF_KERNEL_LONG_T */
9a4987
-
9a4987
-#undef ILOG2_ITER_
9a4987
-
9a4987
 void
9a4987
 dumpstr(struct tcb *const tcp, const kernel_ulong_t addr,
9a4987
 	const kernel_ulong_t len)
9a4987
-- 
9a4987
2.1.4
9a4987