| From 7e771de87cf728a8678f1f28f391bba3589e2496 Mon Sep 17 00:00:00 2001 |
| From: Chen Qi <Qi.Chen@windriver.com> |
| Date: Mon, 25 Feb 2019 14:18:21 +0800 |
| Subject: [PATCH] src/basic/missing.h: check for missing strndupa |
| |
| include missing.h for definition of strndupa |
| |
| Upstream-Status: Inappropriate [musl specific] |
| |
| Signed-off-by: Khem Raj <raj.khem@gmail.com> |
| Signed-off-by: Chen Qi <Qi.Chen@windriver.com> |
| [Rebased for v242] |
| Signed-off-by: Andrej Valek <andrej.valek@siemens.com> |
| [rebased for systemd 243] |
| Signed-off-by: Scott Murray <scott.murray@konsulko.com> |
| Signed-off-by: Alex Kiernan <alex.kiernan@gmail.com> |
| [rebased for systemd 244] |
| |
| --- |
| meson.build | 1 + |
| src/backlight/backlight.c | 1 + |
| src/basic/cgroup-util.c | 1 + |
| src/basic/env-util.c | 1 + |
| src/basic/log.c | 1 + |
| src/basic/missing_stdlib.h | 12 ++++++++++++ |
| src/basic/mkdir.c | 1 + |
| src/basic/parse-util.c | 1 + |
| src/basic/path-lookup.c | 1 + |
| src/basic/proc-cmdline.c | 1 + |
| src/basic/procfs-util.c | 1 + |
| src/basic/selinux-util.c | 1 + |
| src/basic/time-util.c | 1 + |
| src/boot/bless-boot.c | 1 + |
| src/core/dbus-cgroup.c | 1 + |
| src/core/dbus-execute.c | 1 + |
| src/core/dbus-util.c | 1 + |
| src/core/execute.c | 1 + |
| src/core/kmod-setup.c | 1 + |
| src/core/service.c | 1 + |
| src/coredump/coredump-vacuum.c | 1 + |
| src/journal-remote/journal-remote-main.c | 1 + |
| src/journal/journalctl.c | 1 + |
| src/journal/sd-journal.c | 1 + |
| src/libsystemd/sd-bus/bus-message.c | 1 + |
| src/libsystemd/sd-bus/bus-objects.c | 1 + |
| src/libsystemd/sd-bus/bus-socket.c | 1 + |
| src/libsystemd/sd-bus/sd-bus.c | 1 + |
| src/libsystemd/sd-bus/test-bus-benchmark.c | 1 + |
| src/locale/keymap-util.c | 1 + |
| src/login/pam_systemd.c | 1 + |
| src/network/generator/network-generator.c | 1 + |
| src/nspawn/nspawn-settings.c | 1 + |
| src/nss-mymachines/nss-mymachines.c | 1 + |
| src/portable/portable.c | 1 + |
| src/resolve/resolvectl.c | 1 + |
| src/shared/bus-get-properties.c | 1 + |
| src/shared/bus-unit-procs.c | 1 + |
| src/shared/bus-unit-util.c | 1 + |
| src/shared/bus-util.c | 1 + |
| src/shared/dns-domain.c | 1 + |
| src/shared/journal-importer.c | 1 + |
| src/shared/logs-show.c | 1 + |
| src/shared/pager.c | 1 + |
| src/shared/uid-range.c | 1 + |
| src/socket-proxy/socket-proxyd.c | 1 + |
| src/test/test-hexdecoct.c | 1 + |
| src/udev/udev-builtin-path_id.c | 1 + |
| src/udev/udev-event.c | 1 + |
| src/udev/udev-rules.c | 1 + |
| 50 files changed, 61 insertions(+) |
| |
| diff --git a/meson.build b/meson.build |
| index 9187439bdd..bea9935a91 100644 |
| --- a/meson.build |
| +++ b/meson.build |
| @@ -527,6 +527,7 @@ foreach ident : [ |
| #include <unistd.h> |
| #include <signal.h> |
| #include <sys/wait.h>'''], |
| + ['strndupa' , '''#include <string.h>'''], |
| ] |
| |
| have = cc.has_function(ident[0], prefix : ident[1], args : '-D_GNU_SOURCE') |
| diff --git a/src/backlight/backlight.c b/src/backlight/backlight.c |
| index 3a644363e1..73946a829b 100644 |
| --- a/src/backlight/backlight.c |
| +++ b/src/backlight/backlight.c |
| @@ -17,6 +17,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| static int find_pci_or_platform_parent(sd_device *device, sd_device **ret) { |
| const char *subsystem, *sysname, *value; |
| diff --git a/src/basic/cgroup-util.c b/src/basic/cgroup-util.c |
| index e94fcfad02..856a7068b0 100644 |
| --- a/src/basic/cgroup-util.c |
| +++ b/src/basic/cgroup-util.c |
| @@ -38,6 +38,7 @@ |
| #include "unit-name.h" |
| #include "user-util.h" |
| #include "xattr-util.h" |
| +#include "missing_stdlib.h" |
| |
| static int cg_enumerate_items(const char *controller, const char *path, FILE **_f, const char *item) { |
| _cleanup_free_ char *fs = NULL; |
| diff --git a/src/basic/env-util.c b/src/basic/env-util.c |
| index b8dc98915f..5049b37594 100644 |
| --- a/src/basic/env-util.c |
| +++ b/src/basic/env-util.c |
| @@ -15,6 +15,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| #define VALID_CHARS_ENV_NAME \ |
| DIGITS LETTERS \ |
| diff --git a/src/basic/log.c b/src/basic/log.c |
| index c6fe203808..b7ef932d28 100644 |
| --- a/src/basic/log.c |
| +++ b/src/basic/log.c |
| @@ -35,6 +35,7 @@ |
| #include "terminal-util.h" |
| #include "time-util.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| #define SNDBUF_SIZE (8*1024*1024) |
| |
| diff --git a/src/basic/missing_stdlib.h b/src/basic/missing_stdlib.h |
| index 188a8d4406..1e16ec287a 100644 |
| --- a/src/basic/missing_stdlib.h |
| +++ b/src/basic/missing_stdlib.h |
| @@ -11,3 +11,15 @@ |
| # error "neither secure_getenv nor __secure_getenv are available" |
| # endif |
| #endif |
| + |
| +/* string.h */ |
| +#if ! HAVE_STRNDUPA |
| +#define strndupa(s, n) \ |
| + ({ \ |
| + const char *__old = (s); \ |
| + size_t __len = strnlen(__old, (n)); \ |
| + char *__new = (char *)alloca(__len + 1); \ |
| + __new[__len] = '\0'; \ |
| + (char *)memcpy(__new, __old, __len); \ |
| + }) |
| +#endif |
| diff --git a/src/basic/mkdir.c b/src/basic/mkdir.c |
| index 6ebc2b95fd..88f4359bab 100644 |
| --- a/src/basic/mkdir.c |
| +++ b/src/basic/mkdir.c |
| @@ -13,6 +13,7 @@ |
| #include "stat-util.h" |
| #include "stdio-util.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| int mkdir_safe_internal( |
| const char *path, |
| diff --git a/src/basic/parse-util.c b/src/basic/parse-util.c |
| index 44f0438cf4..54b4133343 100644 |
| --- a/src/basic/parse-util.c |
| +++ b/src/basic/parse-util.c |
| @@ -19,6 +19,7 @@ |
| #include "stat-util.h" |
| #include "string-util.h" |
| #include "strv.h" |
| +#include "missing_stdlib.h" |
| |
| int parse_boolean(const char *v) { |
| if (!v) |
| diff --git a/src/basic/path-lookup.c b/src/basic/path-lookup.c |
| index 52968dee34..2f4f7e3dcd 100644 |
| --- a/src/basic/path-lookup.c |
| +++ b/src/basic/path-lookup.c |
| @@ -15,6 +15,7 @@ |
| #include "strv.h" |
| #include "tmpfile-util.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| int xdg_user_runtime_dir(char **ret, const char *suffix) { |
| const char *e; |
| diff --git a/src/basic/proc-cmdline.c b/src/basic/proc-cmdline.c |
| index ba47ca5812..8baf728fde 100644 |
| --- a/src/basic/proc-cmdline.c |
| +++ b/src/basic/proc-cmdline.c |
| @@ -15,6 +15,7 @@ |
| #include "string-util.h" |
| #include "util.h" |
| #include "virt.h" |
| +#include "missing_stdlib.h" |
| |
| int proc_cmdline(char **ret) { |
| const char *e; |
| diff --git a/src/basic/procfs-util.c b/src/basic/procfs-util.c |
| index 7aaf95bfce..da7e836f14 100644 |
| --- a/src/basic/procfs-util.c |
| +++ b/src/basic/procfs-util.c |
| @@ -11,6 +11,7 @@ |
| #include "procfs-util.h" |
| #include "stdio-util.h" |
| #include "string-util.h" |
| +#include "missing_stdlib.h" |
| |
| int procfs_tasks_get_limit(uint64_t *ret) { |
| _cleanup_free_ char *value = NULL; |
| diff --git a/src/basic/selinux-util.c b/src/basic/selinux-util.c |
| index c94ee26bd9..14e35b4653 100644 |
| --- a/src/basic/selinux-util.c |
| +++ b/src/basic/selinux-util.c |
| @@ -27,6 +27,7 @@ |
| #include "selinux-util.h" |
| #include "stdio-util.h" |
| #include "time-util.h" |
| +#include "missing_stdlib.h" |
| |
| #if HAVE_SELINUX |
| DEFINE_TRIVIAL_CLEANUP_FUNC(context_t, context_free); |
| diff --git a/src/basic/time-util.c b/src/basic/time-util.c |
| index 15cc1b8851..02bb3f01f9 100644 |
| --- a/src/basic/time-util.c |
| +++ b/src/basic/time-util.c |
| @@ -26,6 +26,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "time-util.h" |
| +#include "missing_stdlib.h" |
| |
| static clockid_t map_clock_id(clockid_t c) { |
| |
| diff --git a/src/boot/bless-boot.c b/src/boot/bless-boot.c |
| index b96e1f927f..cba979baca 100644 |
| --- a/src/boot/bless-boot.c |
| +++ b/src/boot/bless-boot.c |
| @@ -18,6 +18,7 @@ |
| #include "util.h" |
| #include "verbs.h" |
| #include "virt.h" |
| +#include "missing_stdlib.h" |
| |
| static char **arg_path = NULL; |
| |
| diff --git a/src/core/dbus-cgroup.c b/src/core/dbus-cgroup.c |
| index b7d2e32639..fdbc1df95e 100644 |
| --- a/src/core/dbus-cgroup.c |
| +++ b/src/core/dbus-cgroup.c |
| @@ -15,6 +15,7 @@ |
| #include "fileio.h" |
| #include "limits-util.h" |
| #include "path-util.h" |
| +#include "missing_stdlib.h" |
| |
| BUS_DEFINE_PROPERTY_GET(bus_property_get_tasks_max, "t", TasksMax, tasks_max_resolve); |
| |
| diff --git a/src/core/dbus-execute.c b/src/core/dbus-execute.c |
| index 50f7ada8ce..5c760ee487 100644 |
| --- a/src/core/dbus-execute.c |
| +++ b/src/core/dbus-execute.c |
| @@ -41,6 +41,7 @@ |
| #include "unit-printf.h" |
| #include "user-util.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| BUS_DEFINE_PROPERTY_GET_ENUM(bus_property_get_exec_output, exec_output, ExecOutput); |
| static BUS_DEFINE_PROPERTY_GET_ENUM(property_get_exec_input, exec_input, ExecInput); |
| diff --git a/src/core/dbus-util.c b/src/core/dbus-util.c |
| index 951450e53d..50d134e9a1 100644 |
| --- a/src/core/dbus-util.c |
| +++ b/src/core/dbus-util.c |
| @@ -7,6 +7,7 @@ |
| #include "unit-printf.h" |
| #include "user-util.h" |
| #include "unit.h" |
| +#include "missing_stdlib.h" |
| |
| int bus_property_get_triggered_unit( |
| sd_bus *bus, |
| diff --git a/src/core/execute.c b/src/core/execute.c |
| index 2a4840a3a9..d3f1e0e0f8 100644 |
| --- a/src/core/execute.c |
| +++ b/src/core/execute.c |
| @@ -89,6 +89,7 @@ |
| #include "unit.h" |
| #include "user-util.h" |
| #include "utmp-wtmp.h" |
| +#include "missing_stdlib.h" |
| |
| #define IDLE_TIMEOUT_USEC (5*USEC_PER_SEC) |
| #define IDLE_TIMEOUT2_USEC (1*USEC_PER_SEC) |
| diff --git a/src/core/kmod-setup.c b/src/core/kmod-setup.c |
| index 09ccd613e3..f4e64fa283 100644 |
| --- a/src/core/kmod-setup.c |
| +++ b/src/core/kmod-setup.c |
| @@ -11,6 +11,7 @@ |
| #include "macro.h" |
| #include "string-util.h" |
| #include "missing_type.h" |
| +#include "missing_stdlib.h" |
| |
| #if HAVE_KMOD |
| #include "module-util.h" |
| diff --git a/src/core/service.c b/src/core/service.c |
| index 00e61945ba..1ecab28354 100644 |
| --- a/src/core/service.c |
| +++ b/src/core/service.c |
| @@ -41,6 +41,7 @@ |
| #include "unit.h" |
| #include "utf8.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| static const UnitActiveState state_translation_table[_SERVICE_STATE_MAX] = { |
| [SERVICE_DEAD] = UNIT_INACTIVE, |
| diff --git a/src/coredump/coredump-vacuum.c b/src/coredump/coredump-vacuum.c |
| index 35885dfb47..bb9f0660a6 100644 |
| --- a/src/coredump/coredump-vacuum.c |
| +++ b/src/coredump/coredump-vacuum.c |
| @@ -16,6 +16,7 @@ |
| #include "string-util.h" |
| #include "time-util.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| #define DEFAULT_MAX_USE_LOWER (uint64_t) (1ULL*1024ULL*1024ULL) /* 1 MiB */ |
| #define DEFAULT_MAX_USE_UPPER (uint64_t) (4ULL*1024ULL*1024ULL*1024ULL) /* 4 GiB */ |
| diff --git a/src/journal-remote/journal-remote-main.c b/src/journal-remote/journal-remote-main.c |
| index 77dfdefd64..e21ecbeff8 100644 |
| --- a/src/journal-remote/journal-remote-main.c |
| +++ b/src/journal-remote/journal-remote-main.c |
| @@ -22,6 +22,7 @@ |
| #include "stat-util.h" |
| #include "string-table.h" |
| #include "strv.h" |
| +#include "missing_stdlib.h" |
| |
| #define PRIV_KEY_FILE CERTIFICATE_ROOT "/private/journal-remote.pem" |
| #define CERT_FILE CERTIFICATE_ROOT "/certs/journal-remote.pem" |
| diff --git a/src/journal/journalctl.c b/src/journal/journalctl.c |
| index 8d4897b942..15476b3c83 100644 |
| --- a/src/journal/journalctl.c |
| +++ b/src/journal/journalctl.c |
| @@ -69,6 +69,7 @@ |
| #include "unit-name.h" |
| #include "user-util.h" |
| #include "varlink.h" |
| +#include "missing_stdlib.h" |
| |
| #define DEFAULT_FSS_INTERVAL_USEC (15*USEC_PER_MINUTE) |
| #define PROCESS_INOTIFY_INTERVAL 1024 /* Every 1,024 messages processed */ |
| diff --git a/src/journal/sd-journal.c b/src/journal/sd-journal.c |
| index 6fb0abb419..2d94d9938e 100644 |
| --- a/src/journal/sd-journal.c |
| +++ b/src/journal/sd-journal.c |
| @@ -40,6 +40,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "syslog-util.h" |
| +#include "missing_stdlib.h" |
| |
| #define JOURNAL_FILES_MAX 7168 |
| |
| diff --git a/src/libsystemd/sd-bus/bus-message.c b/src/libsystemd/sd-bus/bus-message.c |
| index 55e35cd902..0ed98f9224 100644 |
| --- a/src/libsystemd/sd-bus/bus-message.c |
| +++ b/src/libsystemd/sd-bus/bus-message.c |
| @@ -21,6 +21,7 @@ |
| #include "strv.h" |
| #include "time-util.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| static int message_append_basic(sd_bus_message *m, char type, const void *p, const void **stored); |
| |
| diff --git a/src/libsystemd/sd-bus/bus-objects.c b/src/libsystemd/sd-bus/bus-objects.c |
| index 6abac8822c..c74c9cd7fa 100644 |
| --- a/src/libsystemd/sd-bus/bus-objects.c |
| +++ b/src/libsystemd/sd-bus/bus-objects.c |
| @@ -13,6 +13,7 @@ |
| #include "set.h" |
| #include "string-util.h" |
| #include "strv.h" |
| +#include "missing_stdlib.h" |
| |
| static int node_vtable_get_userdata( |
| sd_bus *bus, |
| diff --git a/src/libsystemd/sd-bus/bus-socket.c b/src/libsystemd/sd-bus/bus-socket.c |
| index fc7e8e844a..7af4dd2712 100644 |
| --- a/src/libsystemd/sd-bus/bus-socket.c |
| +++ b/src/libsystemd/sd-bus/bus-socket.c |
| @@ -28,6 +28,7 @@ |
| #include "string-util.h" |
| #include "user-util.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| #define SNDBUF_SIZE (8*1024*1024) |
| |
| diff --git a/src/libsystemd/sd-bus/sd-bus.c b/src/libsystemd/sd-bus/sd-bus.c |
| index 9de5e454a6..fe86c93c63 100644 |
| --- a/src/libsystemd/sd-bus/sd-bus.c |
| +++ b/src/libsystemd/sd-bus/sd-bus.c |
| @@ -41,6 +41,7 @@ |
| #include "process-util.h" |
| #include "string-util.h" |
| #include "strv.h" |
| +#include "missing_stdlib.h" |
| |
| #define log_debug_bus_message(m) \ |
| do { \ |
| diff --git a/src/libsystemd/sd-bus/test-bus-benchmark.c b/src/libsystemd/sd-bus/test-bus-benchmark.c |
| index 8de0a859ee..58044b6ba9 100644 |
| --- a/src/libsystemd/sd-bus/test-bus-benchmark.c |
| +++ b/src/libsystemd/sd-bus/test-bus-benchmark.c |
| @@ -14,6 +14,7 @@ |
| #include "missing_resource.h" |
| #include "time-util.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| #define MAX_SIZE (2*1024*1024) |
| |
| diff --git a/src/locale/keymap-util.c b/src/locale/keymap-util.c |
| index 233d081300..40a32b9700 100644 |
| --- a/src/locale/keymap-util.c |
| +++ b/src/locale/keymap-util.c |
| @@ -21,6 +21,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "tmpfile-util.h" |
| +#include "missing_stdlib.h" |
| |
| static bool startswith_comma(const char *s, const char *prefix) { |
| s = startswith(s, prefix); |
| diff --git a/src/login/pam_systemd.c b/src/login/pam_systemd.c |
| index 16f4289585..6c5e438b36 100644 |
| --- a/src/login/pam_systemd.c |
| +++ b/src/login/pam_systemd.c |
| @@ -31,6 +31,7 @@ |
| #include "locale-util.h" |
| #include "login-util.h" |
| #include "macro.h" |
| +#include "missing_stdlib.h" |
| #include "pam-util.h" |
| #include "parse-util.h" |
| #include "path-util.h" |
| diff --git a/src/network/generator/network-generator.c b/src/network/generator/network-generator.c |
| index bed1e42697..e4847c2bee 100644 |
| --- a/src/network/generator/network-generator.c |
| +++ b/src/network/generator/network-generator.c |
| @@ -13,6 +13,7 @@ |
| #include "string-table.h" |
| #include "string-util.h" |
| #include "strv.h" |
| +#include "missing_stdlib.h" |
| |
| /* |
| # .network |
| diff --git a/src/nspawn/nspawn-settings.c b/src/nspawn/nspawn-settings.c |
| index d341fa25aa..91646bc2c2 100644 |
| --- a/src/nspawn/nspawn-settings.c |
| +++ b/src/nspawn/nspawn-settings.c |
| @@ -16,6 +16,7 @@ |
| #include "strv.h" |
| #include "user-util.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| Settings *settings_new(void) { |
| Settings *s; |
| diff --git a/src/nss-mymachines/nss-mymachines.c b/src/nss-mymachines/nss-mymachines.c |
| index 5db0dcef76..681f8677e4 100644 |
| --- a/src/nss-mymachines/nss-mymachines.c |
| +++ b/src/nss-mymachines/nss-mymachines.c |
| @@ -19,6 +19,7 @@ |
| #include "nss-util.h" |
| #include "signal-util.h" |
| #include "string-util.h" |
| +#include "missing_stdlib.h" |
| |
| NSS_GETHOSTBYNAME_PROTOTYPES(mymachines); |
| NSS_GETPW_PROTOTYPES(mymachines); |
| diff --git a/src/portable/portable.c b/src/portable/portable.c |
| index 3a1367ec2b..f29336cb1e 100644 |
| --- a/src/portable/portable.c |
| +++ b/src/portable/portable.c |
| @@ -31,6 +31,7 @@ |
| #include "strv.h" |
| #include "tmpfile-util.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| static const char profile_dirs[] = CONF_PATHS_NULSTR("systemd/portable/profile"); |
| |
| diff --git a/src/resolve/resolvectl.c b/src/resolve/resolvectl.c |
| index 3072b984e5..c46ae374bf 100644 |
| --- a/src/resolve/resolvectl.c |
| +++ b/src/resolve/resolvectl.c |
| @@ -36,6 +36,7 @@ |
| #include "strv.h" |
| #include "terminal-util.h" |
| #include "verbs.h" |
| +#include "missing_stdlib.h" |
| |
| static int arg_family = AF_UNSPEC; |
| static int arg_ifindex = 0; |
| diff --git a/src/shared/bus-get-properties.c b/src/shared/bus-get-properties.c |
| index 8ad4694046..da5082c02a 100644 |
| --- a/src/shared/bus-get-properties.c |
| +++ b/src/shared/bus-get-properties.c |
| @@ -3,6 +3,7 @@ |
| #include "bus-get-properties.h" |
| #include "rlimit-util.h" |
| #include "string-util.h" |
| +#include "missing_stdlib.h" |
| |
| int bus_property_get_bool( |
| sd_bus *bus, |
| diff --git a/src/shared/bus-unit-procs.c b/src/shared/bus-unit-procs.c |
| index b21fe39326..af2640005c 100644 |
| --- a/src/shared/bus-unit-procs.c |
| +++ b/src/shared/bus-unit-procs.c |
| @@ -10,6 +10,7 @@ |
| #include "sort-util.h" |
| #include "string-util.h" |
| #include "terminal-util.h" |
| +#include "missing_stdlib.h" |
| |
| struct CGroupInfo { |
| char *cgroup_path; |
| diff --git a/src/shared/bus-unit-util.c b/src/shared/bus-unit-util.c |
| index f2652ed9a5..eb019fc89f 100644 |
| --- a/src/shared/bus-unit-util.c |
| +++ b/src/shared/bus-unit-util.c |
| @@ -39,6 +39,7 @@ |
| #include "unit-def.h" |
| #include "user-util.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| int bus_parse_unit_info(sd_bus_message *message, UnitInfo *u) { |
| assert(message); |
| diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c |
| index 77c1c62182..5cd31f3c15 100644 |
| --- a/src/shared/bus-util.c |
| +++ b/src/shared/bus-util.c |
| @@ -22,6 +22,7 @@ |
| #include "socket-util.h" |
| #include "stdio-util.h" |
| /* #include "string-util.h" */ |
| +#include "missing_stdlib.h" |
| |
| static int name_owner_change_callback(sd_bus_message *m, void *userdata, sd_bus_error *ret_error) { |
| sd_event *e = userdata; |
| diff --git a/src/shared/dns-domain.c b/src/shared/dns-domain.c |
| index b812665315..8e68f7f8fc 100644 |
| --- a/src/shared/dns-domain.c |
| +++ b/src/shared/dns-domain.c |
| @@ -23,6 +23,7 @@ |
| #include "string-util.h" |
| #include "strv.h" |
| #include "utf8.h" |
| +#include "missing_stdlib.h" |
| |
| int dns_label_unescape(const char **name, char *dest, size_t sz, DNSLabelFlags flags) { |
| const char *n; |
| diff --git a/src/shared/journal-importer.c b/src/shared/journal-importer.c |
| index 7c4fc7021d..3fbaf5a639 100644 |
| --- a/src/shared/journal-importer.c |
| +++ b/src/shared/journal-importer.c |
| @@ -14,6 +14,7 @@ |
| #include "parse-util.h" |
| #include "string-util.h" |
| #include "unaligned.h" |
| +#include "missing_stdlib.h" |
| |
| enum { |
| IMPORTER_STATE_LINE = 0, /* waiting to read, or reading line */ |
| diff --git a/src/shared/logs-show.c b/src/shared/logs-show.c |
| index 899e894ab7..628854ac9c 100644 |
| --- a/src/shared/logs-show.c |
| +++ b/src/shared/logs-show.c |
| @@ -41,6 +41,7 @@ |
| #include "utf8.h" |
| #include "util.h" |
| #include "web-util.h" |
| +#include "missing_stdlib.h" |
| |
| /* up to three lines (each up to 100 characters) or 300 characters, whichever is less */ |
| #define PRINT_LINE_THRESHOLD 3 |
| diff --git a/src/shared/pager.c b/src/shared/pager.c |
| index e03be6d23b..50e3d1f75c 100644 |
| --- a/src/shared/pager.c |
| +++ b/src/shared/pager.c |
| @@ -23,6 +23,7 @@ |
| #include "strv.h" |
| #include "terminal-util.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| static pid_t pager_pid = 0; |
| |
| diff --git a/src/shared/uid-range.c b/src/shared/uid-range.c |
| index 7cb7d8a477..8e7d7f9e7c 100644 |
| --- a/src/shared/uid-range.c |
| +++ b/src/shared/uid-range.c |
| @@ -9,6 +9,7 @@ |
| #include "sort-util.h" |
| #include "uid-range.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| static bool uid_range_intersect(UidRange *range, uid_t start, uid_t nr) { |
| assert(range); |
| diff --git a/src/socket-proxy/socket-proxyd.c b/src/socket-proxy/socket-proxyd.c |
| index b461aead60..9941695ed9 100644 |
| --- a/src/socket-proxy/socket-proxyd.c |
| +++ b/src/socket-proxy/socket-proxyd.c |
| @@ -26,6 +26,7 @@ |
| #include "socket-util.h" |
| #include "string-util.h" |
| #include "util.h" |
| +#include "missing_stdlib.h" |
| |
| #define BUFFER_SIZE (256 * 1024) |
| |
| diff --git a/src/test/test-hexdecoct.c b/src/test/test-hexdecoct.c |
| index 52217429b1..70708dedf3 100644 |
| --- a/src/test/test-hexdecoct.c |
| +++ b/src/test/test-hexdecoct.c |
| @@ -6,6 +6,7 @@ |
| #include "hexdecoct.h" |
| #include "macro.h" |
| #include "string-util.h" |
| +#include "missing_stdlib.h" |
| |
| static void test_hexchar(void) { |
| assert_se(hexchar(0xa) == 'a'); |
| diff --git a/src/udev/udev-builtin-path_id.c b/src/udev/udev-builtin-path_id.c |
| index 6c020ac0ed..10723ec46c 100644 |
| --- a/src/udev/udev-builtin-path_id.c |
| +++ b/src/udev/udev-builtin-path_id.c |
| @@ -22,6 +22,7 @@ |
| #include "strv.h" |
| #include "sysexits.h" |
| #include "udev-builtin.h" |
| +#include "missing_stdlib.h" |
| |
| _printf_(2,3) |
| static void path_prepend(char **path, const char *fmt, ...) { |
| diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c |
| index e1c2baf7f2..62d4086802 100644 |
| --- a/src/udev/udev-event.c |
| +++ b/src/udev/udev-event.c |
| @@ -34,6 +34,7 @@ |
| #include "udev-util.h" |
| #include "udev-watch.h" |
| #include "user-util.h" |
| +#include "missing_stdlib.h" |
| |
| typedef struct Spawn { |
| sd_device *device; |
| diff --git a/src/udev/udev-rules.c b/src/udev/udev-rules.c |
| index c36f032f66..36970813d8 100644 |
| --- a/src/udev/udev-rules.c |
| +++ b/src/udev/udev-rules.c |
| @@ -30,6 +30,7 @@ |
| #include "udev-rules.h" |
| #include "user-util.h" |
| #include "virt.h" |
| +#include "missing_stdlib.h" |
| |
| #define RULES_DIRS (const char* const*) CONF_PATHS_STRV("udev/rules.d") |
| |