[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20220207162354.14293-12-w@1wt.eu>
Date: Mon, 7 Feb 2022 17:23:23 +0100
From: Willy Tarreau <w@....eu>
To: "Paul E . McKenney" <paulmck@...nel.org>
Cc: Mark Brown <broonie@...nel.org>, linux-kernel@...r.kernel.org,
Willy Tarreau <w@....eu>
Subject: [PATCH 11/42] tools/nolibc/types: move the FD_* functions to macros in types.h
FD_SET, FD_CLR, FD_ISSET, FD_ZERO are supposed to be macros and not
functions. In addition we already have a file dedicated to such macros
and types used by syscalls, it's types.h, so let's move them
there and turn them to macros. FD_CLR() and FD_ISSET() were missing,
so they were added. FD_ZERO() now deals with its own loop so that it
doesn't rely on memset() that sets one byte at a time.
Signed-off-by: Willy Tarreau <w@....eu>
---
tools/include/nolibc/nolibc.h | 14 --------------
tools/include/nolibc/types.h | 30 ++++++++++++++++++++++++++++++
2 files changed, 30 insertions(+), 14 deletions(-)
diff --git a/tools/include/nolibc/nolibc.h b/tools/include/nolibc/nolibc.h
index c96c6cb7f3ae..2267d98337ea 100644
--- a/tools/include/nolibc/nolibc.h
+++ b/tools/include/nolibc/nolibc.h
@@ -118,20 +118,6 @@ const char *ltoa(long in)
/* Here come a few helper functions */
-static __attribute__((unused))
-void FD_ZERO(fd_set *set)
-{
- memset(set, 0, sizeof(*set));
-}
-
-static __attribute__((unused))
-void FD_SET(int fd, fd_set *set)
-{
- if (fd < 0 || fd >= FD_SETSIZE)
- return;
- set->fd32[fd / 32] |= 1 << (fd & 31);
-}
-
/* WARNING, it only deals with the 4096 first majors and 256 first minors */
static __attribute__((unused))
dev_t makedev(unsigned int major, unsigned int minor)
diff --git a/tools/include/nolibc/types.h b/tools/include/nolibc/types.h
index 2f09abaf95f1..b79e10025780 100644
--- a/tools/include/nolibc/types.h
+++ b/tools/include/nolibc/types.h
@@ -75,6 +75,36 @@ typedef struct {
uint32_t fd32[FD_SETSIZE / 32];
} fd_set;
+#define FD_CLR(fd, set) do { \
+ int __fd = (int)(fd); \
+ fd_set *__set = (fd_set *)(set); \
+ if (__fd >= 0 && __fd < FD_SETSIZE) \
+ __set->fd32[__fd / 32] &= ~(1U << (__fd & 31)); \
+ } while (0)
+
+#define FD_SET(fd, set) do { \
+ int __fd = (int)(fd); \
+ fd_set *__set = (fd_set *)(set); \
+ if (__fd >= 0 && __fd < FD_SETSIZE) \
+ __set->fd32[__fd / 32] |= 1U << (__fd & 31); \
+ } while (0)
+
+#define FD_ISSET(fd, set) ({ \
+ int __fd = (int)(fd); \
+ fd_set *__set = (fd_set *)(set); \
+ if (__fd >= 0 && __fd < FD_SETSIZE) \
+ !!(__set->fd32[__fd / 32] & 1U << (__fd & 31)); \
+ else \
+ 0; \
+ })
+
+#define FD_ZERO(set) do { \
+ int __idx; \
+ fd_set *__set = (fd_set *)(set); \
+ for (__idx = 0; __idx < FD_SETSIZE / 32; __idx ++) \
+ __set->fd32[__idx] = 0; \
+ } while (0)
+
/* for poll() */
struct pollfd {
int fd;
--
2.35.1
Powered by blists - more mailing lists