summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlejandro Colomar <alx@kernel.org>2024-04-18 15:08:33 +0200
committerAlejandro Colomar <alx@kernel.org>2024-04-18 15:08:41 +0200
commit8e16a21955fe3c5498b08dbdef56b9128ee6b78a (patch)
tree8af1662b98f15c9f9bb01c11d4d38ec929088ffa
parentad5fec747f90a19957f5549a45d80fda4d3cf493 (diff)
downloadliba2i-8e16a21955fe3c5498b08dbdef56b9128ee6b78a.tar.gz
include/a2i/a2i_func.h, lib/src/a2i/a2i_func.c: Don't inline these functions
We've learnt from the xz backdoor that dependencies can be very dangerous. By not inlining, we isolate the damage that our library could cause. If a bug is ever found here, fixing the library should be enough. If one wants to optimize, they still can use LTO. Signed-off-by: Alejandro Colomar <alx@kernel.org>
-rw-r--r--include/a2i/a2i_func.h271
-rw-r--r--lib/src/a2i/a2i_func.c219
2 files changed, 238 insertions, 252 deletions
diff --git a/include/a2i/a2i_func.h b/include/a2i/a2i_func.h
index b7e88ce..7247e96 100644
--- a/include/a2i/a2i_func.h
+++ b/include/a2i/a2i_func.h
@@ -6,254 +6,105 @@
#define INCLUDE_A2I_A2I_FUNC_H_
-#include <errno.h>
-
#include <a2i/attr.h>
-#include <a2i/inline.h>
#include <a2i/qual.h>
-#include <a2i/strtoi.h>
-
-
-#define a2i_a2I_nc(n, s, endp, base, min, max) \
-({ \
- int status_; \
- \
- *n = _Generic(*n, \
- signed char: a2i_strtoi, \
- short: a2i_strtoi, \
- int: a2i_strtoi, \
- long: a2i_strtoi, \
- long long: a2i_strtoi, \
- unsigned char: a2i_strtou_noneg, \
- unsigned short: a2i_strtou_noneg, \
- unsigned int: a2i_strtou_noneg, \
- unsigned long: a2i_strtou_noneg, \
- unsigned long long: a2i_strtou_noneg \
- )(s, endp, base, min, max, &status_); \
- if (status_ != 0) \
- errno = status_; \
- \
- -!!status_; \
-})
-#define A2I_A2I_PROTOTYPE(name, TYPE, TYPE2) \
+#define A2I_A2I_ATTR \
A2I_ATTR_ACCESS(write_only, 1) \
A2I_ATTR_ACCESS(read_only, 2) \
A2I_ATTR_ACCESS(write_only, 3) \
A2I_ATTR_STRING(2) \
- a2i_inline int name(TYPE *restrict n, const char *s, \
- TYPE2 a2i_nullable restrict endp, int base, TYPE min, TYPE max)
-
-#define A2I_A2I_PROTOTYPES(name, TYPE) \
- A2I_A2I_PROTOTYPE(name ## _c, TYPE, const char **); \
- A2I_A2I_PROTOTYPE(name ## _nc, TYPE, char **)
#if defined(__clang__)
# pragma clang assume_nonnull begin
#endif
-A2I_A2I_PROTOTYPES(a2shh, signed char);
-A2I_A2I_PROTOTYPES(a2sh, short);
-A2I_A2I_PROTOTYPES(a2si, int);
-A2I_A2I_PROTOTYPES(a2sl, long);
-A2I_A2I_PROTOTYPES(a2sll, long long);
-
-A2I_A2I_PROTOTYPES(a2uhh, unsigned char);
-A2I_A2I_PROTOTYPES(a2uh, unsigned short);
-A2I_A2I_PROTOTYPES(a2ui, unsigned int);
-A2I_A2I_PROTOTYPES(a2ul, unsigned long);
-A2I_A2I_PROTOTYPES(a2ull, unsigned long long);
-
-
-#if defined(__clang__)
-# pragma clang diagnostic push
-# pragma clang diagnostic ignored "-Wimplicit-int-conversion"
-# pragma clang diagnostic ignored "-Wshorten-64-to-32"
-#endif
-#pragma GCC diagnostic push
-#pragma GCC diagnostic ignored "-Wcast-qual"
-a2i_inline int
-a2shh_c(signed char *restrict n, const char *s,
+A2I_A2I_ATTR
+int a2shh_c(signed char *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- signed char min, signed char max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sh_c(short *restrict n, const char *s,
+ signed char min, signed char max);
+A2I_A2I_ATTR
+int a2sh_c(short *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- short min, short max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2si_c(int *restrict n, const char *s,
+ short min, short max);
+A2I_A2I_ATTR
+int a2si_c(int *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- int min, int max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sl_c(long *restrict n, const char *s,
+ int min, int max);
+A2I_A2I_ATTR
+int a2sl_c(long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- long min, long max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sll_c(long long *restrict n, const char *s,
+ long min, long max);
+A2I_A2I_ATTR
+int a2sll_c(long long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- long long min, long long max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
+ long long min, long long max);
-
-a2i_inline int
-a2uhh_c(unsigned char *restrict n, const char *s,
+A2I_A2I_ATTR
+int a2uhh_c(unsigned char *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned char min, unsigned char max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2uh_c(unsigned short *restrict n, const char *s,
+ unsigned char min, unsigned char max);
+A2I_A2I_ATTR
+int a2uh_c(unsigned short *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned short min, unsigned short max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ui_c(unsigned int *restrict n, const char *s,
+ unsigned short min, unsigned short max);
+A2I_A2I_ATTR
+int a2ui_c(unsigned int *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned int min, unsigned int max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ul_c(unsigned long *restrict n, const char *s,
+ unsigned int min, unsigned int max);
+A2I_A2I_ATTR
+int a2ul_c(unsigned long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned long min, unsigned long max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ull_c(unsigned long long *restrict n, const char *s,
+ unsigned long min, unsigned long max);
+A2I_A2I_ATTR
+int a2ull_c(unsigned long long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned long long min, unsigned long long max)
-{
- return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
-}
-#pragma GCC diagnostic pop // -Wcast-qual
+ unsigned long long min, unsigned long long max);
-a2i_inline int
-a2shh_nc(signed char *restrict n, const char *s,
+A2I_A2I_ATTR
+int a2shh_nc(signed char *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- signed char min, signed char max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sh_nc(short *restrict n, const char *s,
+ signed char min, signed char max);
+A2I_A2I_ATTR
+int a2sh_nc(short *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- short min, short max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2si_nc(int *restrict n, const char *s,
+ short min, short max);
+A2I_A2I_ATTR
+int a2si_nc(int *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- int min, int max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sl_nc(long *restrict n, const char *s,
+ int min, int max);
+A2I_A2I_ATTR
+int a2sl_nc(long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- long min, long max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2sll_nc(long long *restrict n, const char *s,
+ long min, long max);
+A2I_A2I_ATTR
+int a2sll_nc(long long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- long long min, long long max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
+ long long min, long long max);
-a2i_inline int
-a2uhh_nc(unsigned char *restrict n, const char *s,
+A2I_A2I_ATTR
+int a2uhh_nc(unsigned char *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned char min, unsigned char max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2uh_nc(unsigned short *restrict n, const char *s,
+ unsigned char min, unsigned char max);
+A2I_A2I_ATTR
+int a2uh_nc(unsigned short *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned short min, unsigned short max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ui_nc(unsigned int *restrict n, const char *s,
+ unsigned short min, unsigned short max);
+A2I_A2I_ATTR
+int a2ui_nc(unsigned int *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned int min, unsigned int max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ul_nc(unsigned long *restrict n, const char *s,
+ unsigned int min, unsigned int max);
+A2I_A2I_ATTR
+int a2ul_nc(unsigned long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned long min, unsigned long max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
-
-
-a2i_inline int
-a2ull_nc(unsigned long long *restrict n, const char *s,
+ unsigned long min, unsigned long max);
+A2I_A2I_ATTR
+int a2ull_nc(unsigned long long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned long long min, unsigned long long max)
-{
- return a2i_a2I_nc(n, s, endp, base, min, max);
-}
+ unsigned long long min, unsigned long long max);
#if defined(__clang__)
-# pragma clang diagnostic pop // -Wimplicit-int-conversion, -Wshorten-64-to-32
# pragma clang assume_nonnull end
#endif
diff --git a/lib/src/a2i/a2i_func.c b/lib/src/a2i/a2i_func.c
index a11e93e..e9016a4 100644
--- a/lib/src/a2i/a2i_func.c
+++ b/lib/src/a2i/a2i_func.c
@@ -4,72 +4,207 @@
#include <a2i/a2i_func.h>
+#include <errno.h>
+
#include <a2i/qual.h>
+#include <a2i/strtoi.h>
+
+
+#define a2i_a2I_nc(n, s, endp, base, min, max) \
+({ \
+ int status_; \
+ \
+ *n = _Generic(*n, \
+ signed char: a2i_strtoi, \
+ short: a2i_strtoi, \
+ int: a2i_strtoi, \
+ long: a2i_strtoi, \
+ long long: a2i_strtoi, \
+ unsigned char: a2i_strtou_noneg, \
+ unsigned short: a2i_strtou_noneg, \
+ unsigned int: a2i_strtou_noneg, \
+ unsigned long: a2i_strtou_noneg, \
+ unsigned long long: a2i_strtou_noneg \
+ )(s, endp, base, min, max, &status_); \
+ if (status_ != 0) \
+ errno = status_; \
+ \
+ -!!status_; \
+})
-#pragma clang assume_nonnull begin
-extern inline int a2shh_c(signed char *restrict n, const char *s,
+#if defined(__clang__)
+# pragma clang assume_nonnull begin
+# pragma clang diagnostic push
+# pragma clang diagnostic ignored "-Wimplicit-int-conversion"
+# pragma clang diagnostic ignored "-Wshorten-64-to-32"
+#endif
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wcast-qual"
+int
+a2shh_c(signed char *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- signed char min, signed char max);
-extern inline int a2sh_c(short *restrict n, const char *s,
+ signed char min, signed char max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2sh_c(short *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- short min, short max);
-extern inline int a2si_c(int *restrict n, const char *s,
+ short min, short max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2si_c(int *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- int min, int max);
-extern inline int a2sl_c(long *restrict n, const char *s,
+ int min, int max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2sl_c(long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- long min, long max);
-extern inline int a2sll_c(long long *restrict n, const char *s,
+ long min, long max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2sll_c(long long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- long long min, long long max);
+ long long min, long long max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
-extern inline int a2uhh_c(unsigned char *restrict n, const char *s,
+int
+a2uhh_c(unsigned char *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned char min, unsigned char max);
-extern inline int a2uh_c(unsigned short *restrict n, const char *s,
+ unsigned char min, unsigned char max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2uh_c(unsigned short *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned short min, unsigned short max);
-extern inline int a2ui_c(unsigned int *restrict n, const char *s,
+ unsigned short min, unsigned short max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2ui_c(unsigned int *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned int min, unsigned int max);
-extern inline int a2ul_c(unsigned long *restrict n, const char *s,
+ unsigned int min, unsigned int max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2ul_c(unsigned long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned long min, unsigned long max);
-extern inline int a2ull_c(unsigned long long *restrict n, const char *s,
+ unsigned long min, unsigned long max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+
+int
+a2ull_c(unsigned long long *restrict n, const char *s,
const char **a2i_nullable restrict endp, int base,
- unsigned long long min, unsigned long long max);
+ unsigned long long min, unsigned long long max)
+{
+ return a2i_a2I_nc(n, s, (char **a2i_nullable) endp, base, min, max);
+}
+#pragma GCC diagnostic pop // -Wcast-qual
-extern inline int a2shh_nc(signed char *restrict n, const char *s,
+int
+a2shh_nc(signed char *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- signed char min, signed char max);
-extern inline int a2sh_nc(short *restrict n, const char *s,
+ signed char min, signed char max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2sh_nc(short *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- short min, short max);
-extern inline int a2si_nc(int *restrict n, const char *s,
+ short min, short max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2si_nc(int *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- int min, int max);
-extern inline int a2sl_nc(long *restrict n, const char *s,
+ int min, int max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2sl_nc(long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- long min, long max);
-extern inline int a2sll_nc(long long *restrict n, const char *s,
+ long min, long max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2sll_nc(long long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- long long min, long long max);
+ long long min, long long max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
-extern inline int a2uhh_nc(unsigned char *restrict n, const char *s,
+
+int
+a2uhh_nc(unsigned char *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned char min, unsigned char max);
-extern inline int a2uh_nc(unsigned short *restrict n, const char *s,
+ unsigned char min, unsigned char max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2uh_nc(unsigned short *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned short min, unsigned short max);
-extern inline int a2ui_nc(unsigned int *restrict n, const char *s,
+ unsigned short min, unsigned short max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2ui_nc(unsigned int *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned int min, unsigned int max);
-extern inline int a2ul_nc(unsigned long *restrict n, const char *s,
+ unsigned int min, unsigned int max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2ul_nc(unsigned long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned long min, unsigned long max);
-extern inline int a2ull_nc(unsigned long long *restrict n, const char *s,
+ unsigned long min, unsigned long max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+
+int
+a2ull_nc(unsigned long long *restrict n, const char *s,
char **a2i_nullable restrict endp, int base,
- unsigned long long min, unsigned long long max);
-#pragma clang assume_nonnull end
+ unsigned long long min, unsigned long long max)
+{
+ return a2i_a2I_nc(n, s, endp, base, min, max);
+}
+#if defined(__clang__)
+# pragma clang diagnostic pop // -Wimplicit-int-conversion, -Wshorten-64-to-32
+# pragma clang assume_nonnull end
+#endif