diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/basic/missing.h | 35 | ||||
| -rw-r--r-- | src/basic/user-util.c | 1 | ||||
| -rw-r--r-- | src/core/dbus-timer.c | 2 | ||||
| -rw-r--r-- | src/core/timer.c | 2 | ||||
| -rw-r--r-- | src/coredump/coredump.c | 84 | ||||
| -rw-r--r-- | src/libsystemd/sd-event/sd-event.c | 2 | ||||
| -rw-r--r-- | src/libsystemd/sd-netlink/netlink-types.c | 43 | ||||
| -rw-r--r-- | src/network/networkd-netdev-bridge.c | 17 | ||||
| -rw-r--r-- | src/network/networkd-netdev-bridge.h | 2 | ||||
| -rw-r--r-- | src/network/networkd-netdev-gperf.gperf | 1 | ||||
| -rw-r--r-- | src/shared/conf-parser.c | 2 | ||||
| -rw-r--r-- | src/shared/sleep-config.c | 4 | 
12 files changed, 158 insertions, 37 deletions
| diff --git a/src/basic/missing.h b/src/basic/missing.h index 66cd5921ad..6a49ccd281 100644 --- a/src/basic/missing.h +++ b/src/basic/missing.h @@ -746,7 +746,40 @@ struct btrfs_ioctl_quota_ctl_args {  #define IFLA_BR_AGEING_TIME 4  #define IFLA_BR_STP_STATE 5  #define IFLA_BR_PRIORITY 6 -#define __IFLA_BR_MAX 7 +#define IFLA_BR_VLAN_FILTERING 7 +#define IFLA_BR_VLAN_PROTOCOL 8 +#define IFLA_BR_GROUP_FWD_MASK 9 +#define IFLA_BR_ROOT_ID 10 +#define IFLA_BR_BRIDGE_ID 11 +#define IFLA_BR_ROOT_PORT 12 +#define IFLA_BR_ROOT_PATH_COST 13 +#define IFLA_BR_TOPOLOGY_CHANGE 14 +#define IFLA_BR_TOPOLOGY_CHANGE_DETECTED 15 +#define IFLA_BR_HELLO_TIMER 16 +#define IFLA_BR_TCN_TIMER 17 +#define IFLA_BR_TOPOLOGY_CHANGE_TIMER 18 +#define IFLA_BR_GC_TIMER 19 +#define IFLA_BR_GROUP_ADDR 20 +#define IFLA_BR_FDB_FLUSH 21 +#define IFLA_BR_MCAST_ROUTER 22 +#define IFLA_BR_MCAST_SNOOPING 23 +#define IFLA_BR_MCAST_QUERY_USE_IFADDR 24 +#define IFLA_BR_MCAST_QUERIER 25 +#define IFLA_BR_MCAST_HASH_ELASTICITY 26 +#define IFLA_BR_MCAST_HASH_MAX 27 +#define IFLA_BR_MCAST_LAST_MEMBER_CNT 28 +#define IFLA_BR_MCAST_STARTUP_QUERY_CNT 29 +#define IFLA_BR_MCAST_LAST_MEMBER_INTVL 30 +#define IFLA_BR_MCAST_MEMBERSHIP_INTVL 31 +#define IFLA_BR_MCAST_QUERIER_INTVL 32 +#define IFLA_BR_MCAST_QUERY_INTVL 33 +#define IFLA_BR_MCAST_QUERY_RESPONSE_INTVL 34 +#define IFLA_BR_MCAST_STARTUP_QUERY_INTVL 35 +#define IFLA_BR_NF_CALL_IPTABLES 36 +#define IFLA_BR_NF_CALL_IP6TABLES 37 +#define IFLA_BR_NF_CALL_ARPTABLES 38 +#define IFLA_BR_VLAN_DEFAULT_PVID 39 +#define __IFLA_BR_MAX 40  #define IFLA_BR_MAX (__IFLA_BR_MAX - 1)  #endif diff --git a/src/basic/user-util.c b/src/basic/user-util.c index 19155bce53..f65ca3edaa 100644 --- a/src/basic/user-util.c +++ b/src/basic/user-util.c @@ -30,6 +30,7 @@  #include <sys/stat.h>  #include <unistd.h> +#include "missing.h"  #include "alloc-util.h"  #include "fd-util.h"  #include "formats-util.h" diff --git a/src/core/dbus-timer.c b/src/core/dbus-timer.c index bc121b83a2..a0e61b023e 100644 --- a/src/core/dbus-timer.c +++ b/src/core/dbus-timer.c @@ -156,7 +156,7 @@ static int property_get_next_elapse_monotonic(                  usec_t a, b;                  a = now(CLOCK_MONOTONIC); -                b = now(CLOCK_BOOTTIME); +                b = now(clock_boottime_or_monotonic());                  if (t->next_elapse_monotonic_or_boottime + a > b)                          x = t->next_elapse_monotonic_or_boottime + a - b; diff --git a/src/core/timer.c b/src/core/timer.c index a51a67ea11..b286b714fa 100644 --- a/src/core/timer.c +++ b/src/core/timer.c @@ -320,7 +320,7 @@ static usec_t monotonic_to_boottime(usec_t t) {          if (t <= 0)                  return 0; -        a = now(CLOCK_BOOTTIME); +        a = now(clock_boottime_or_monotonic());          b = now(CLOCK_MONOTONIC);          if (t + a > b) diff --git a/src/coredump/coredump.c b/src/coredump/coredump.c index f65cb6f9dd..2bbb958861 100644 --- a/src/coredump/coredump.c +++ b/src/coredump/coredump.c @@ -49,6 +49,7 @@  #include "journald-native.h"  #include "log.h"  #include "macro.h" +#include "missing.h"  #include "mkdir.h"  #include "parse-util.h"  #include "process-util.h" @@ -212,6 +213,10 @@ static int fix_xattr(int fd, const char *context[_CONTEXT_MAX]) {  #define filename_escape(s) xescape((s), "./ ") +static inline const char *coredump_tmpfile_name(const char *s) { +        return s ? s : "(unnamed temporary file)"; +} +  static int fix_permissions(                  int fd,                  const char *filename, @@ -220,7 +225,6 @@ static int fix_permissions(                  uid_t uid) {          assert(fd >= 0); -        assert(filename);          assert(target);          assert(context); @@ -230,10 +234,20 @@ static int fix_permissions(          (void) fix_xattr(fd, context);          if (fsync(fd) < 0) -                return log_error_errno(errno, "Failed to sync coredump %s: %m", filename); +                return log_error_errno(errno, "Failed to sync coredump %s: %m", coredump_tmpfile_name(filename)); + +        if (filename) { +                if (rename(filename, target) < 0) +                        return log_error_errno(errno, "Failed to rename coredump %s -> %s: %m", filename, target); +        } else { +                _cleanup_free_ char *proc_fd_path = NULL; -        if (rename(filename, target) < 0) -                return log_error_errno(errno, "Failed to rename coredump %s -> %s: %m", filename, target); +                if (asprintf(&proc_fd_path, "/proc/self/fd/%d", fd) < 0) +                        return log_oom(); + +                if (linkat(AT_FDCWD, proc_fd_path, AT_FDCWD, target, AT_SYMLINK_FOLLOW) < 0) +                        return log_error_errno(errno, "Failed to create coredump %s: %m", target); +        }          return 0;  } @@ -294,6 +308,33 @@ static int make_filename(const char *context[_CONTEXT_MAX], char **ret) {          return 0;  } +static int open_coredump_tmpfile(const char *target, char **ret_filename) { +        _cleanup_free_ char *tmp = NULL; +        int fd; +        int r; + +        assert(target); +        assert(ret_filename); + +        fd = open("/var/lib/systemd/coredump", O_TMPFILE|O_CLOEXEC|O_NOCTTY|O_RDWR, 0640); +        if (fd < 0) { +                log_debug_errno(errno, "Failed to use O_TMPFILE: %m"); + +                r = tempfn_random(target, NULL, &tmp); +                if (r < 0) +                        return log_error_errno(r, "Failed to determine temporary file name: %m"); + +                fd = open(tmp, O_CREAT|O_EXCL|O_RDWR|O_CLOEXEC|O_NOCTTY|O_NOFOLLOW, 0640); +                if (fd < 0) +                        return log_error_errno(errno, "Failed to create coredump file %s: %m", tmp); +        } + +        *ret_filename = tmp; +        tmp = NULL; + +        return fd; +} +  static int save_external_coredump(                  const char *context[_CONTEXT_MAX],                  int input_fd, @@ -335,15 +376,11 @@ static int save_external_coredump(          if (r < 0)                  return log_error_errno(r, "Failed to determine coredump file name: %m"); -        r = tempfn_random(fn, NULL, &tmp); -        if (r < 0) -                return log_error_errno(r, "Failed to determine temporary file name: %m"); -          mkdir_p_label("/var/lib/systemd/coredump", 0755); -        fd = open(tmp, O_CREAT|O_EXCL|O_RDWR|O_CLOEXEC|O_NOCTTY|O_NOFOLLOW, 0640); +        fd = open_coredump_tmpfile(fn, &tmp);          if (fd < 0) -                return log_error_errno(errno, "Failed to create coredump file %s: %m", tmp); +                return fd;          r = copy_bytes(input_fd, fd, max_size, false);          if (r == -EFBIG) { @@ -358,12 +395,12 @@ static int save_external_coredump(          }          if (fstat(fd, &st) < 0) { -                log_error_errno(errno, "Failed to fstat coredump %s: %m", tmp); +                log_error_errno(errno, "Failed to fstat coredump %s: %m", coredump_tmpfile_name(tmp));                  goto fail;          }          if (lseek(fd, 0, SEEK_SET) == (off_t) -1) { -                log_error_errno(errno, "Failed to seek on %s: %m", tmp); +                log_error_errno(errno, "Failed to seek on %s: %m", coredump_tmpfile_name(tmp));                  goto fail;          } @@ -381,21 +418,13 @@ static int save_external_coredump(                          goto uncompressed;                  } -                r = tempfn_random(fn_compressed, NULL, &tmp_compressed); -                if (r < 0) { -                        log_error_errno(r, "Failed to determine temporary file name for %s: %m", fn_compressed); +                fd_compressed = open_coredump_tmpfile(fn_compressed, &tmp_compressed); +                if (fd_compressed < 0)                          goto uncompressed; -                } - -                fd_compressed = open(tmp_compressed, O_CREAT|O_EXCL|O_RDWR|O_CLOEXEC|O_NOCTTY|O_NOFOLLOW, 0640); -                if (fd_compressed < 0) { -                        log_error_errno(errno, "Failed to create file %s: %m", tmp_compressed); -                        goto uncompressed; -                }                  r = compress_stream(fd, fd_compressed, -1);                  if (r < 0) { -                        log_error_errno(r, "Failed to compress %s: %m", tmp_compressed); +                        log_error_errno(r, "Failed to compress %s: %m", coredump_tmpfile_name(tmp_compressed));                          goto fail_compressed;                  } @@ -404,7 +433,8 @@ static int save_external_coredump(                          goto fail_compressed;                  /* OK, this worked, we can get rid of the uncompressed version now */ -                unlink_noerrno(tmp); +                if (tmp) +                        unlink_noerrno(tmp);                  *ret_filename = fn_compressed;     /* compressed */                  *ret_node_fd = fd_compressed;      /* compressed */ @@ -417,7 +447,8 @@ static int save_external_coredump(                  return 0;          fail_compressed: -                (void) unlink(tmp_compressed); +                if (tmp_compressed) +                        (void) unlink(tmp_compressed);          }  uncompressed: @@ -438,7 +469,8 @@ uncompressed:          return 0;  fail: -        (void) unlink(tmp); +        if (tmp) +                (void) unlink(tmp);          return r;  } diff --git a/src/libsystemd/sd-event/sd-event.c b/src/libsystemd/sd-event/sd-event.c index 9fd744768d..79b98c293c 100644 --- a/src/libsystemd/sd-event/sd-event.c +++ b/src/libsystemd/sd-event/sd-event.c @@ -2527,7 +2527,7 @@ _public_ int sd_event_wait(sd_event *e, uint64_t timeout) {          }          dual_timestamp_get(&e->timestamp); -        e->timestamp_boottime = now(CLOCK_BOOTTIME); +        e->timestamp_boottime = now(clock_boottime_or_monotonic());          for (i = 0; i < m; i++) { diff --git a/src/libsystemd/sd-netlink/netlink-types.c b/src/libsystemd/sd-netlink/netlink-types.c index a5758bb516..3a4bac2ced 100644 --- a/src/libsystemd/sd-netlink/netlink-types.c +++ b/src/libsystemd/sd-netlink/netlink-types.c @@ -95,12 +95,43 @@ static const NLType rtnl_link_info_data_macvlan_types[] = {  };  static const NLType rtnl_link_info_data_bridge_types[] = { -        [IFLA_BR_FORWARD_DELAY]  = { .type = NETLINK_TYPE_U32 }, -        [IFLA_BR_HELLO_TIME]     = { .type = NETLINK_TYPE_U32 }, -        [IFLA_BR_MAX_AGE]        = { .type = NETLINK_TYPE_U32 }, -        [IFLA_BR_AGEING_TIME]    = { .type = NETLINK_TYPE_U32 }, -        [IFLA_BR_STP_STATE]      = { .type = NETLINK_TYPE_U32 }, -        [IFLA_BR_PRIORITY]       = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_FORWARD_DELAY]              = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_HELLO_TIME]                 = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_MAX_AGE]                    = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_AGEING_TIME]                = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_STP_STATE]                  = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_PRIORITY]                   = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_VLAN_FILTERING]             = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_VLAN_PROTOCOL]              = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_GROUP_FWD_MASK]             = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_ROOT_PORT]                  = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_ROOT_PATH_COST]             = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_TOPOLOGY_CHANGE]            = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_TOPOLOGY_CHANGE_DETECTED]   = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_HELLO_TIMER]                = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_TCN_TIMER]                  = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_TOPOLOGY_CHANGE_TIMER]      = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_GC_TIMER]                   = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_GROUP_ADDR]                 = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_FDB_FLUSH]                  = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_MCAST_ROUTER]               = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_MCAST_SNOOPING]             = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_MCAST_QUERY_USE_IFADDR]     = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_MCAST_QUERIER]              = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_MCAST_HASH_ELASTICITY]      = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_MCAST_HASH_MAX]             = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_MCAST_LAST_MEMBER_CNT]      = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BR_MCAST_STARTUP_QUERY_CNT]    = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BR_MCAST_LAST_MEMBER_INTVL]    = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_MCAST_MEMBERSHIP_INTVL]     = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_MCAST_QUERIER_INTVL]        = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_MCAST_QUERY_INTVL]          = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_MCAST_QUERY_RESPONSE_INTVL] = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_MCAST_STARTUP_QUERY_INTVL]  = { .type = NETLINK_TYPE_U64 }, +        [IFLA_BR_NF_CALL_IPTABLES]           = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_NF_CALL_IP6TABLES]          = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_NF_CALL_ARPTABLES]          = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BR_VLAN_DEFAULT_PVID]          = { .type = NETLINK_TYPE_U16 },  };  static const NLType rtnl_link_info_data_vlan_types[] = { diff --git a/src/network/networkd-netdev-bridge.c b/src/network/networkd-netdev-bridge.c index cdcd08f057..3f91b2eaea 100644 --- a/src/network/networkd-netdev-bridge.c +++ b/src/network/networkd-netdev-bridge.c @@ -89,6 +89,12 @@ static int netdev_bridge_post_create(NetDev *netdev, Link *link, sd_netlink_mess                          return log_netdev_error_errno(netdev, r, "Could not append IFLA_BR_MAX_AGE attribute: %m");          } +        if (b->mcast_querier >= 0) { +                r = sd_netlink_message_append_u8(req, IFLA_BR_MCAST_QUERIER, b->mcast_querier); +                if (r < 0) +                        return log_netdev_error_errno(netdev, r, "Could not append IFLA_BR_MCAST_QUERIER attribute: %m"); +        } +          r = sd_netlink_message_close_container(req);          if (r < 0)                  return log_netdev_error_errno(netdev, r, "Could not append IFLA_LINKINFO attribute: %m"); @@ -106,8 +112,19 @@ static int netdev_bridge_post_create(NetDev *netdev, Link *link, sd_netlink_mess          return r;  } +static void bridge_init(NetDev *n) { +        Bridge *b; + +        b = BRIDGE(n); + +        assert(b); + +        b->mcast_querier = -1; +} +  const NetDevVTable bridge_vtable = {          .object_size = sizeof(Bridge), +        .init = bridge_init,          .sections = "Match\0NetDev\0Bridge\0",          .post_create = netdev_bridge_post_create,          .create_type = NETDEV_CREATE_MASTER, diff --git a/src/network/networkd-netdev-bridge.h b/src/network/networkd-netdev-bridge.h index 27f26f7870..3f6f1d0502 100644 --- a/src/network/networkd-netdev-bridge.h +++ b/src/network/networkd-netdev-bridge.h @@ -26,6 +26,8 @@ typedef struct Bridge Bridge;  struct Bridge {          NetDev meta; +        int mcast_querier; +          usec_t forward_delay;          usec_t hello_time;          usec_t max_age; diff --git a/src/network/networkd-netdev-gperf.gperf b/src/network/networkd-netdev-gperf.gperf index 8f506af092..15a787a9e3 100644 --- a/src/network/networkd-netdev-gperf.gperf +++ b/src/network/networkd-netdev-gperf.gperf @@ -92,3 +92,4 @@ Bond.LearnPacketIntervalSec, config_parse_sec,                   0,  Bridge.HelloTimeSec,         config_parse_sec,                   0,                             offsetof(Bridge, hello_time)  Bridge.MaxAgeSec,            config_parse_sec,                   0,                             offsetof(Bridge, max_age)  Bridge.ForwardDelaySec,      config_parse_sec,                   0,                             offsetof(Bridge, forward_delay) +Bridge.MulticastQuerier,     config_parse_tristate,              0,                             offsetof(Bridge, mcast_querier) diff --git a/src/shared/conf-parser.c b/src/shared/conf-parser.c index bd0a1f483b..1141f9964f 100644 --- a/src/shared/conf-parser.c +++ b/src/shared/conf-parser.c @@ -732,7 +732,7 @@ int config_parse_strv(const char *unit,          for (;;) {                  char *word = NULL;                  int r; -                r = extract_first_word(&rvalue, &word, WHITESPACE, EXTRACT_QUOTES); +                r = extract_first_word(&rvalue, &word, WHITESPACE, EXTRACT_QUOTES|EXTRACT_RETAIN_ESCAPE);                  if (r == 0)                          break;                  if (r == -ENOMEM) diff --git a/src/shared/sleep-config.c b/src/shared/sleep-config.c index 35aa60101f..f00624d0f2 100644 --- a/src/shared/sleep-config.c +++ b/src/shared/sleep-config.c @@ -28,6 +28,7 @@  #include "alloc-util.h"  #include "conf-parser.h"  #include "def.h" +#include "env-util.h"  #include "fd-util.h"  #include "fileio.h"  #include "log.h" @@ -231,6 +232,9 @@ static bool enough_memory_for_hibernation(void) {          size_t size = 0, used = 0;          int r; +        if (getenv_bool("SYSTEMD_BYPASS_HIBERNATION_MEMORY_CHECK") > 0) +                return true; +          r = hibernation_partition_size(&size, &used);          if (r < 0)                  return false; | 
