diff options
31 files changed, 138 insertions, 52 deletions
| diff --git a/Makefile.am b/Makefile.am index 71e0664c74..97e2c26442 100644 --- a/Makefile.am +++ b/Makefile.am @@ -6162,7 +6162,6 @@ DISTCHECK_CONFIGURE_FLAGS += \  endif  .PHONY: dist-check-help -  dist-check-help: $(rootbin_PROGRAMS) $(bin_PROGRAMS)  	for i in $(abspath $^); do                                             \              if $$i  --help | grep -v 'default:' | grep -E -q '.{80}.' ; then   \ @@ -6171,6 +6170,18 @@ dist-check-help: $(rootbin_PROGRAMS) $(bin_PROGRAMS)  	        exit 1;                                                        \              fi; done +include_compilers = "$(CC)" "$(CC) -ansi" "$(CC) -std=iso9899:1990" +public_headers = $(filter-out src/systemd/_sd-common.h, $(pkginclude_HEADERS) $(include_HEADERS)) +.PHONY: dist-check-includes +dist-check-includes: $(public_headers) +	@res=0;                                                        	        \ +	for i in $(abspath $^); do	                                        \ +	    for cc in $(include_compilers); do                                  \ +	        echo "$$cc -o/dev/null -c -x c -include "$$i" - </dev/null";    \ +	        $$cc -o/dev/null -c -x c -include "$$i" - </dev/null || res=1;  \ +	    done;                                                               \ +	done; exit $$res +  .PHONY: hwdb-update  hwdb-update:  	( cd $(top_srcdir)/hwdb && \ @@ -1345,7 +1345,7 @@ CHANGES WITH 219:          * machinectl is now able to clone container images            efficiently, if the underlying file system (btrfs) supports -          it, with the new "machinectl list-images" command. It also +          it, with the new "machinectl clone" command. It also            gained commands for renaming and removing images, as well as            marking them read-only or read-write (supported also on            legacy file systems). diff --git a/hwdb/60-evdev.hwdb b/hwdb/60-evdev.hwdb index 598172256b..4f04539e12 100644 --- a/hwdb/60-evdev.hwdb +++ b/hwdb/60-evdev.hwdb @@ -98,6 +98,12 @@ evdev:name:ETPS/2 Elantech Touchpad:dmi:bvn*:bvr*:bd*:svnASUSTeKComputerInc.:pnK   EVDEV_ABS_35=::18   EVDEV_ABS_36=::16 +evdev:name:ETPS/2 Elantech Touchpad:dmi:*:svnASUSTeKCOMPUTERINC.:pnX550CC:* + EVDEV_ABS_00=::31 + EVDEV_ABS_01=::30 + EVDEV_ABS_35=::31 + EVDEV_ABS_36=::30 +  #########################################  # Dell  ######################################### diff --git a/man/systemd-nspawn.xml b/man/systemd-nspawn.xml index 86cdb4e124..7e87865ba8 100644 --- a/man/systemd-nspawn.xml +++ b/man/systemd-nspawn.xml @@ -595,9 +595,8 @@          order to trigger an orderly shutdown of the          container. Defaults to SIGRTMIN+3 if <option>--boot</option>          is used (on systemd-compatible init systems SIGRTMIN+3 -        triggers an orderly shutdown). Takes a signal name like -        <literal>SIGHUP</literal>, <literal>SIGTERM</literal> or -        similar as argument.</para></listitem> +        triggers an orderly shutdown). For a list of valid signals, see +        <citerefentry project='man-pages'><refentrytitle>signal</refentrytitle><manvolnum>7</manvolnum></citerefentry>.</para></listitem>        </varlistentry>        <varlistentry> diff --git a/man/systemd.nspawn.xml b/man/systemd.nspawn.xml index c07a4b0243..5ec878512a 100644 --- a/man/systemd.nspawn.xml +++ b/man/systemd.nspawn.xml @@ -224,6 +224,18 @@        </varlistentry>        <varlistentry> +        <term><option>KillSignal=</option></term> + +        <listitem><para>Specify the process signal to send to the +        container's PID 1 when nspawn itself receives SIGTERM, in +        order to trigger an orderly shutdown of the container. +        Defaults to SIGRTMIN+3 if <option>Boot=</option> is used +        (on systemd-compatible init systems SIGRTMIN+3 triggers an +        orderly shutdown). For a list of valid signals, see +        <citerefentry project='man-pages'><refentrytitle>signal</refentrytitle><manvolnum>7</manvolnum></citerefentry>.</para></listitem> +      </varlistentry> + +      <varlistentry>          <term><varname>Personality=</varname></term>          <listitem><para>Configures the kernel personality for the diff --git a/src/basic/c-rbtree.c b/src/basic/c-rbtree.c index 914d7e5229..cf5a7242df 100644 --- a/src/basic/c-rbtree.c +++ b/src/basic/c-rbtree.c @@ -195,11 +195,6 @@ static inline void c_rbnode_set_parent_and_color(CRBNode *n, CRBNode *p, unsigne          n->__parent_and_color = (CRBNode*)((unsigned long)p | c);  } -/* same as c_rbnode_set_parent_and_color(), but keeps the current parent */ -static inline void c_rbnode_set_color(CRBNode *n, unsigned long c) { -        c_rbnode_set_parent_and_color(n, c_rbnode_parent(n), c); -} -  /* same as c_rbnode_set_parent_and_color(), but keeps the current color */  static inline void c_rbnode_set_parent(CRBNode *n, CRBNode *p) {          c_rbnode_set_parent_and_color(n, p, c_rbnode_color(n)); diff --git a/src/basic/log.h b/src/basic/log.h index f9fb1742a1..b6356228d9 100644 --- a/src/basic/log.h +++ b/src/basic/log.h @@ -246,5 +246,4 @@ int log_syntax_internal(                          log_syntax_internal(unit, _level, config_file, config_line, 0, __FILE__, __LINE__, __func__, \                                              "String is not UTF-8 clean, ignoring assignment: %s", strna(_p)); \                  }                                                       \ -                -EINVAL;                                                \          }) diff --git a/src/basic/macro.h b/src/basic/macro.h index c34441d75d..e41aa4260f 100644 --- a/src/basic/macro.h +++ b/src/basic/macro.h @@ -23,10 +23,15 @@  #include <inttypes.h>  #include <stdbool.h>  #include <sys/param.h> +#include <sys/sysmacros.h>  #include <sys/types.h>  #define _printf_(a,b) __attribute__ ((format (printf, a, b))) -#define _alloc_(...) __attribute__ ((alloc_size(__VA_ARGS__))) +#ifdef __clang__ +#  define _alloc_(...) +#else +#  define _alloc_(...) __attribute__ ((alloc_size(__VA_ARGS__))) +#endif  #define _sentinel_ __attribute__ ((sentinel))  #define _unused_ __attribute__ ((unused))  #define _destructor_ __attribute__ ((destructor)) diff --git a/src/basic/selinux-util.c b/src/basic/selinux-util.c index 5e6181f662..10c2f39369 100644 --- a/src/basic/selinux-util.c +++ b/src/basic/selinux-util.c @@ -152,7 +152,7 @@ int mac_selinux_fix(const char *path, bool ignore_enoent, bool ignore_erofs) {                          return 0;                  if (r >= 0) { -                        r = lsetfilecon(path, fcon); +                        r = lsetfilecon_raw(path, fcon);                          /* If the FS doesn't support labels, then exit without warning */                          if (r < 0 && errno == EOPNOTSUPP) @@ -262,7 +262,7 @@ int mac_selinux_get_child_mls_label(int socket_fd, const char *exe, const char *          if (r < 0)                  return -errno; -        r = getpeercon(socket_fd, &peercon); +        r = getpeercon_raw(socket_fd, &peercon);          if (r < 0)                  return -errno; @@ -371,7 +371,7 @@ void mac_selinux_create_file_clear(void) {          if (!mac_selinux_use())                  return; -        setfscreatecon(NULL); +        setfscreatecon_raw(NULL);  #endif  } @@ -402,7 +402,7 @@ void mac_selinux_create_socket_clear(void) {          if (!mac_selinux_use())                  return; -        setsockcreatecon(NULL); +        setsockcreatecon_raw(NULL);  #endif  } @@ -461,7 +461,7 @@ int mac_selinux_bind(int fd, const struct sockaddr *addr, socklen_t addrlen) {                          return -errno;          } else { -                if (setfscreatecon(fcon) < 0) { +                if (setfscreatecon_raw(fcon) < 0) {                          log_enforcing("Failed to set SELinux security context %s for %s: %m", fcon, path);                          if (security_getenforce() > 0)                                  return -errno; @@ -472,7 +472,7 @@ int mac_selinux_bind(int fd, const struct sockaddr *addr, socklen_t addrlen) {          r = bind(fd, addr, addrlen) < 0 ? -errno : 0;          if (context_changed) -                setfscreatecon(NULL); +                setfscreatecon_raw(NULL);          return r; diff --git a/src/basic/time-util.c b/src/basic/time-util.c index 7ca764abeb..c16460a198 100644 --- a/src/basic/time-util.c +++ b/src/basic/time-util.c @@ -47,12 +47,15 @@ static clockid_t map_clock_id(clockid_t c) {          /* Some more exotic archs (s390, ppc, …) lack the "ALARM" flavour of the clocks. Thus, clock_gettime() will           * fail for them. Since they are essentially the same as their non-ALARM pendants (their only difference is           * when timers are set on them), let's just map them accordingly. This way, we can get the correct time even on -         * those archs. */ +         * those archs. +         * +         * Also, older kernels don't support CLOCK_BOOTTIME: fall back to CLOCK_MONOTONIC. */          switch (c) { +        case CLOCK_BOOTTIME:          case CLOCK_BOOTTIME_ALARM: -                return CLOCK_BOOTTIME; +                return clock_boottime_or_monotonic ();          case CLOCK_REALTIME_ALARM:                  return CLOCK_REALTIME; diff --git a/src/basic/util.h b/src/basic/util.h index e095254b57..286db05159 100644 --- a/src/basic/util.h +++ b/src/basic/util.h @@ -36,6 +36,7 @@  #include <sys/socket.h>  #include <sys/stat.h>  #include <sys/statfs.h> +#include <sys/sysmacros.h>  #include <sys/types.h>  #include <time.h>  #include <unistd.h> diff --git a/src/core/job.c b/src/core/job.c index 012cf72d1f..719cb0a3e5 100644 --- a/src/core/job.c +++ b/src/core/job.c @@ -690,17 +690,20 @@ _pure_ static const char *job_get_status_message_format(Unit *u, JobType t, JobR  }  static void job_print_status_message(Unit *u, JobType t, JobResult result) { -        static const char* const job_result_status_table[_JOB_RESULT_MAX] = { -                [JOB_DONE]        = ANSI_GREEN            "  OK  " ANSI_NORMAL, -                [JOB_TIMEOUT]     = ANSI_HIGHLIGHT_RED    " TIME " ANSI_NORMAL, -                [JOB_FAILED]      = ANSI_HIGHLIGHT_RED    "FAILED" ANSI_NORMAL, -                [JOB_DEPENDENCY]  = ANSI_HIGHLIGHT_YELLOW "DEPEND" ANSI_NORMAL, -                [JOB_SKIPPED]     = ANSI_HIGHLIGHT        " INFO " ANSI_NORMAL, -                [JOB_ASSERT]      = ANSI_HIGHLIGHT_YELLOW "ASSERT" ANSI_NORMAL, -                [JOB_UNSUPPORTED] = ANSI_HIGHLIGHT_YELLOW "UNSUPP" ANSI_NORMAL, +        static struct { +                const char *color, *word; +        } const statuses[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = {ANSI_GREEN,            "  OK  "}, +                [JOB_TIMEOUT]     = {ANSI_HIGHLIGHT_RED,    " TIME "}, +                [JOB_FAILED]      = {ANSI_HIGHLIGHT_RED,    "FAILED"}, +                [JOB_DEPENDENCY]  = {ANSI_HIGHLIGHT_YELLOW, "DEPEND"}, +                [JOB_SKIPPED]     = {ANSI_HIGHLIGHT,        " INFO "}, +                [JOB_ASSERT]      = {ANSI_HIGHLIGHT_YELLOW, "ASSERT"}, +                [JOB_UNSUPPORTED] = {ANSI_HIGHLIGHT_YELLOW, "UNSUPP"},          };          const char *format; +        const char *status;          assert(u);          assert(t >= 0); @@ -714,11 +717,16 @@ static void job_print_status_message(Unit *u, JobType t, JobResult result) {          if (!format)                  return; +        if (log_get_show_color()) +                status = strjoina(statuses[result].color, statuses[result].word, ANSI_NORMAL); +        else +                status = statuses[result].word; +          if (result != JOB_DONE)                  manager_flip_auto_status(u->manager, true);          DISABLE_WARNING_FORMAT_NONLITERAL; -        unit_status_printf(u, job_result_status_table[result], format); +        unit_status_printf(u, status, format);          REENABLE_WARNING;          if (t == JOB_START && result == JOB_FAILED) { diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index e1bfdccbca..d078924c5b 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -3507,7 +3507,19 @@ static int merge_by_names(Unit **u, Set *names, const char *id) {                           * ours? Then let's try it the other way                           * round */ -                        other = manager_get_unit((*u)->manager, k); +                        /* If the symlink name we are looking at is unit template, then +                           we must search for instance of this template */ +                        if (unit_name_is_valid(k, UNIT_NAME_TEMPLATE)) { +                                _cleanup_free_ char *instance = NULL; + +                                r = unit_name_replace_instance(k, (*u)->instance, &instance); +                                if (r < 0) +                                        return r; + +                                other = manager_get_unit((*u)->manager, instance); +                        } else +                                other = manager_get_unit((*u)->manager, k); +                          free(k);                          if (other) { diff --git a/src/core/main.c b/src/core/main.c index 1783b9c7af..78701805ea 100644 --- a/src/core/main.c +++ b/src/core/main.c @@ -1218,10 +1218,15 @@ static int status_welcome(void) {          if (r < 0 && r != -ENOENT)                  log_warning_errno(r, "Failed to read os-release file: %m"); -        return status_printf(NULL, false, false, -                             "\nWelcome to \x1B[%sm%s\x1B[0m!\n", -                             isempty(ansi_color) ? "1" : ansi_color, -                             isempty(pretty_name) ? "Linux" : pretty_name); +        if (log_get_show_color()) +                return status_printf(NULL, false, false, +                                     "\nWelcome to \x1B[%sm%s\x1B[0m!\n", +                                     isempty(ansi_color) ? "1" : ansi_color, +                                     isempty(pretty_name) ? "Linux" : pretty_name); +        else +                return status_printf(NULL, false, false, +                                     "\nWelcome to %s!\n", +                                     isempty(pretty_name) ? "Linux" : pretty_name);  }  static int write_container_id(void) { diff --git a/src/core/selinux-setup.c b/src/core/selinux-setup.c index 9a115a4387..4072df58e6 100644 --- a/src/core/selinux-setup.c +++ b/src/core/selinux-setup.c @@ -88,7 +88,7 @@ int mac_selinux_setup(bool *loaded_policy) {                          log_open();                          log_error("Failed to compute init label, ignoring.");                  } else { -                        r = setcon(label); +                        r = setcon_raw(label);                          log_open();                          if (r < 0) diff --git a/src/core/transaction.c b/src/core/transaction.c index b28fc76785..c894001cf9 100644 --- a/src/core/transaction.c +++ b/src/core/transaction.c @@ -391,6 +391,7 @@ static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi                  if (delete) { +                        const char *status;                          /* logging for j not k here here to provide consistent narrative */                          log_unit_warning(j->unit,                                           "Breaking ordering cycle by deleting job %s/%s", @@ -399,7 +400,13 @@ static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi                                         "Job %s/%s deleted to break ordering cycle starting with %s/%s",                                         delete->unit->id, job_type_to_string(delete->type),                                         j->unit->id, job_type_to_string(j->type)); -                        unit_status_printf(delete->unit, ANSI_HIGHLIGHT_RED " SKIP " ANSI_NORMAL, + +                        if (log_get_show_color()) +                                status = ANSI_HIGHLIGHT_RED " SKIP " ANSI_NORMAL; +                        else +                                status = " SKIP "; + +                        unit_status_printf(delete->unit, status,                                             "Ordering cycle found, skipping %s");                          transaction_delete_unit(tr, delete->unit);                          return -EAGAIN; diff --git a/src/libsystemd/sd-path/sd-path.c b/src/libsystemd/sd-path/sd-path.c index 480f1ad065..b7aec1f20a 100644 --- a/src/libsystemd/sd-path/sd-path.c +++ b/src/libsystemd/sd-path/sd-path.c @@ -89,7 +89,8 @@ static int from_home_dir(const char *envname, const char *suffix, char **buffer,  static int from_user_dir(const char *field, char **buffer, const char **ret) {          _cleanup_fclose_ FILE *f = NULL;          _cleanup_free_ char *b = NULL; -        const char *fn = NULL; +        _cleanup_free_ const char *fn = NULL; +        const char *c = NULL;          char line[LINE_MAX];          size_t n;          int r; @@ -98,10 +99,14 @@ static int from_user_dir(const char *field, char **buffer, const char **ret) {          assert(buffer);          assert(ret); -        r = from_home_dir(NULL, ".config/user-dirs.dirs", &b, &fn); +        r = from_home_dir("XDG_CONFIG_HOME", ".config", &b, &c);          if (r < 0)                  return r; +        fn = strappend(c, "/user-dirs.dirs"); +        if (!fn) +                return -ENOMEM; +          f = fopen(fn, "re");          if (!f) {                  if (errno == ENOENT) diff --git a/src/libudev/libudev.h b/src/libudev/libudev.h index eb58740d26..3f6d0ed16c 100644 --- a/src/libudev/libudev.h +++ b/src/libudev/libudev.h @@ -21,6 +21,7 @@  #define _LIBUDEV_H_  #include <stdarg.h> +#include <sys/sysmacros.h>  #include <sys/types.h>  #ifdef __cplusplus diff --git a/src/login/70-uaccess.rules b/src/login/70-uaccess.rules index 694df2cfc8..ff3e68e961 100644 --- a/src/login/70-uaccess.rules +++ b/src/login/70-uaccess.rules @@ -42,8 +42,9 @@ SUBSYSTEM=="firewire", ATTR{units}=="*0x00b09d:0x00010*",  TAG+="uaccess"  SUBSYSTEM=="firewire", ATTR{units}=="*0x00a02d:0x010001*", TAG+="uaccess"  SUBSYSTEM=="firewire", ATTR{units}=="*0x00a02d:0x014001*", TAG+="uaccess" -# DRI video devices +# DRI and frame buffer video devices  SUBSYSTEM=="drm", KERNEL=="card*|renderD*", TAG+="uaccess" +SUBSYSTEM=="graphics", KERNEL=="fb*", TAG+="uaccess"  # KVM  SUBSYSTEM=="misc", KERNEL=="kvm", TAG+="uaccess" diff --git a/src/nspawn/nspawn-cgroup.c b/src/nspawn/nspawn-cgroup.c index 1db5ba7116..9f9a4759d1 100644 --- a/src/nspawn/nspawn-cgroup.c +++ b/src/nspawn/nspawn-cgroup.c @@ -73,7 +73,7 @@ int sync_cgroup(pid_t pid, bool unified_requested) {          unified = cg_unified();          if (unified < 0) -                return log_error_errno(unified, "Failed to determine whether the unified hierachy is used: %m"); +                return log_error_errno(unified, "Failed to determine whether the unified hierarchy is used: %m");          if ((unified > 0) == unified_requested)                  return 0; @@ -135,7 +135,7 @@ int create_subcgroup(pid_t pid, bool unified_requested) {          unified = cg_unified();          if (unified < 0) -                return log_error_errno(unified, "Failed to determine whether the unified hierachy is used: %m"); +                return log_error_errno(unified, "Failed to determine whether the unified hierarchy is used: %m");          if (unified == 0)                  return 0; diff --git a/src/systemd/_sd-common.h b/src/systemd/_sd-common.h index 2d4e1f26e1..3bb886be75 100644 --- a/src/systemd/_sd-common.h +++ b/src/systemd/_sd-common.h @@ -74,7 +74,7 @@  #endif  #define _SD_DEFINE_POINTER_CLEANUP_FUNC(type, func)             \ -        static inline void func##p(type **p) {                  \ +        static __inline__ void func##p(type **p) {              \                  if (*p)                                         \                          func(*p);                               \          }                                                       \ diff --git a/src/systemd/sd-bus-protocol.h b/src/systemd/sd-bus-protocol.h index 47b256d5b9..623cee0c50 100644 --- a/src/systemd/sd-bus-protocol.h +++ b/src/systemd/sd-bus-protocol.h @@ -59,7 +59,7 @@ enum {          SD_BUS_TYPE_STRUCT_END       = ')',          SD_BUS_TYPE_DICT_ENTRY       = 'e', /* not actually used in signatures */          SD_BUS_TYPE_DICT_ENTRY_BEGIN = '{', -        SD_BUS_TYPE_DICT_ENTRY_END   = '}', +        SD_BUS_TYPE_DICT_ENTRY_END   = '}'  };  /* Well-known errors. Note that this is only a sanitized subset of the diff --git a/src/systemd/sd-bus-vtable.h b/src/systemd/sd-bus-vtable.h index 6ad6d51979..e8f84eb545 100644 --- a/src/systemd/sd-bus-vtable.h +++ b/src/systemd/sd-bus-vtable.h @@ -34,7 +34,7 @@ enum {          _SD_BUS_VTABLE_METHOD            = 'M',          _SD_BUS_VTABLE_SIGNAL            = 'S',          _SD_BUS_VTABLE_PROPERTY          = 'P', -        _SD_BUS_VTABLE_WRITABLE_PROPERTY = 'W', +        _SD_BUS_VTABLE_WRITABLE_PROPERTY = 'W'  };  enum { diff --git a/src/systemd/sd-bus.h b/src/systemd/sd-bus.h index 2a2ef0eb98..295989cd69 100644 --- a/src/systemd/sd-bus.h +++ b/src/systemd/sd-bus.h @@ -89,13 +89,13 @@ enum {          SD_BUS_CREDS_WELL_KNOWN_NAMES   = 1ULL << 32,          SD_BUS_CREDS_DESCRIPTION        = 1ULL << 33,          SD_BUS_CREDS_AUGMENT            = 1ULL << 63, /* special flag, if on sd-bus will augment creds struct, in a potentially race-full way. */ -        _SD_BUS_CREDS_ALL               = (1ULL << 34) -1, +        _SD_BUS_CREDS_ALL               = (1ULL << 34) -1  };  enum {          SD_BUS_NAME_REPLACE_EXISTING  = 1ULL << 0,          SD_BUS_NAME_ALLOW_REPLACEMENT = 1ULL << 1, -        SD_BUS_NAME_QUEUE             = 1ULL << 2, +        SD_BUS_NAME_QUEUE             = 1ULL << 2  };  /* Callbacks */ diff --git a/src/systemd/sd-device.h b/src/systemd/sd-device.h index 5bfca6ecec..c1d07561d7 100644 --- a/src/systemd/sd-device.h +++ b/src/systemd/sd-device.h @@ -22,6 +22,7 @@  ***/  #include <inttypes.h> +#include <sys/sysmacros.h>  #include <sys/types.h>  #include "_sd-common.h" diff --git a/src/systemd/sd-event.h b/src/systemd/sd-event.h index 1ea97e47f8..531ace1c34 100644 --- a/src/systemd/sd-event.h +++ b/src/systemd/sd-event.h @@ -55,7 +55,7 @@ enum {          SD_EVENT_RUNNING,          SD_EVENT_EXITING,          SD_EVENT_FINISHED, -        SD_EVENT_PREPARING, +        SD_EVENT_PREPARING  };  enum { @@ -69,7 +69,11 @@ typedef int (*sd_event_handler_t)(sd_event_source *s, void *userdata);  typedef int (*sd_event_io_handler_t)(sd_event_source *s, int fd, uint32_t revents, void *userdata);  typedef int (*sd_event_time_handler_t)(sd_event_source *s, uint64_t usec, void *userdata);  typedef int (*sd_event_signal_handler_t)(sd_event_source *s, const struct signalfd_siginfo *si, void *userdata); +#if defined __USE_POSIX199309 || defined __USE_XOPEN_EXTENDED  typedef int (*sd_event_child_handler_t)(sd_event_source *s, const siginfo_t *si, void *userdata); +#else +typedef void* sd_event_child_handler_t; +#endif  int sd_event_default(sd_event **e); diff --git a/src/systemd/sd-id128.h b/src/systemd/sd-id128.h index a3bf5897b8..4dff0b9b81 100644 --- a/src/systemd/sd-id128.h +++ b/src/systemd/sd-id128.h @@ -100,11 +100,11 @@ int sd_id128_get_boot(sd_id128_t *ret);                  ((x).bytes[15] & 15) >= 10 ? 'a' + ((x).bytes[15] & 15) - 10 : '0' + ((x).bytes[15] & 15), \                  0 }) -_sd_pure_ static inline int sd_id128_equal(sd_id128_t a, sd_id128_t b) { +_sd_pure_ static __inline__ int sd_id128_equal(sd_id128_t a, sd_id128_t b) {          return memcmp(&a, &b, 16) == 0;  } -_sd_pure_ static inline int sd_id128_is_null(sd_id128_t a) { +_sd_pure_ static __inline__ int sd_id128_is_null(sd_id128_t a) {          return a.qwords[0] == 0 && a.qwords[1] == 0;  } diff --git a/src/systemd/sd-journal.h b/src/systemd/sd-journal.h index abb9eca576..d4c6f409cd 100644 --- a/src/systemd/sd-journal.h +++ b/src/systemd/sd-journal.h @@ -72,7 +72,7 @@ enum {          SD_JOURNAL_SYSTEM = 4,          SD_JOURNAL_CURRENT_USER = 8, -        SD_JOURNAL_SYSTEM_ONLY = SD_JOURNAL_SYSTEM, /* deprecated name */ +        SD_JOURNAL_SYSTEM_ONLY = SD_JOURNAL_SYSTEM /* deprecated name */  };  /* Wakeup event types */ diff --git a/src/udev/udev.h b/src/udev/udev.h index 56590517ef..8433e8d9f2 100644 --- a/src/udev/udev.h +++ b/src/udev/udev.h @@ -19,6 +19,7 @@   */  #include <sys/param.h> +#include <sys/sysmacros.h>  #include <sys/types.h>  #include "libudev.h" diff --git a/test/test-functions b/test/test-functions index 92e1ae9f8d..29f647ece4 100644 --- a/test/test-functions +++ b/test/test-functions @@ -199,6 +199,17 @@ EOF      chmod 0755 $_valgrind_wrapper  } +create_strace_wrapper() { +    local _strace_wrapper=$initdir/$ROOTLIBDIR/systemd-under-strace +    ddebug "Create $_strace_wrapper" +    cat >$_strace_wrapper <<EOF +#!/bin/bash + +exec strace -D -o /strace.out $ROOTLIBDIR/systemd "\$@" +EOF +    chmod 0755 $_strace_wrapper +} +  install_fsck() {      dracut_install /sbin/fsck*      dracut_install -o /bin/fsck* diff --git a/units/ldconfig.service b/units/ldconfig.service index 994edd9908..0910fff054 100644 --- a/units/ldconfig.service +++ b/units/ldconfig.service @@ -10,9 +10,8 @@ Description=Rebuild Dynamic Linker Cache  Documentation=man:ldconfig(8)  DefaultDependencies=no  Conflicts=shutdown.target -After=systemd-remount-fs.service +After=local-fs.target  Before=sysinit.target shutdown.target systemd-update-done.service -ConditionNeedsUpdate=|/etc  ConditionFileNotEmpty=|!/etc/ld.so.cache  [Service] | 
