diff options
| -rw-r--r-- | man/nss-myhostname.xml | 7 | ||||
| -rw-r--r-- | man/systemd-resolved.service.xml | 7 | ||||
| -rw-r--r-- | man/systemd.resource-control.xml | 24 | ||||
| -rw-r--r-- | src/basic/hostname-util.c | 10 | ||||
| -rw-r--r-- | src/libsystemd/sd-device/sd-device.c | 37 | ||||
| -rw-r--r-- | src/shared/spawn-polkit-agent.c | 4 | ||||
| -rw-r--r-- | src/test/test-udev.c | 10 | ||||
| -rwxr-xr-x | test/udev-test.pl | 9 | 
8 files changed, 67 insertions, 41 deletions
| diff --git a/man/nss-myhostname.xml b/man/nss-myhostname.xml index f8837745ae..a920ec334f 100644 --- a/man/nss-myhostname.xml +++ b/man/nss-myhostname.xml @@ -70,9 +70,10 @@        is on the local loopback) and the IPv6 address ::1 (which is the        local host).</para></listitem> -      <listitem><para>The hostname <literal>localhost</literal> (as well as any hostname ending in -      <literal>.localhost</literal>, <literal>.localdomain</literal> or equal to <literal>localdomain</literal>) is -      resolved to the IP addresses 127.0.0.1 and ::1.</para></listitem> +      <listitem><para>The hostnames <literal>localhost</literal> and +      <literal>localhost.localdomain</literal> (as well as any hostname +      ending in <literal>.localhost</literal> or <literal>.localhost.localdomain</literal>) +      are resolved to the IP addresses 127.0.0.1 and ::1.</para></listitem>        <listitem><para>The hostname <literal>gateway</literal> is        resolved to all current default routing gateway addresses, diff --git a/man/systemd-resolved.service.xml b/man/systemd-resolved.service.xml index 7a9e23a2c6..829729ca09 100644 --- a/man/systemd-resolved.service.xml +++ b/man/systemd-resolved.service.xml @@ -87,9 +87,10 @@        is on the local loopback) and the IPv6 address ::1 (which is the        local host).</para></listitem> -      <listitem><para>The hostname <literal>localhost</literal> (as well as any hostname ending in -      <literal>.localhost</literal>, <literal>.localdomain</literal> or equal to <literal>localdomain</literal>) is -      resolved to the IP addresses 127.0.0.1 and ::1.</para></listitem> +      <listitem><para>The hostnames <literal>localhost</literal> and +      <literal>localhost.localdomain</literal> (as well as any hostname +      ending in <literal>.localhost</literal> or <literal>.localhost.localdomain</literal>) +      are resolved to the IP addresses 127.0.0.1 and ::1.</para></listitem>        <listitem><para>The hostname <literal>gateway</literal> is        resolved to all current default routing gateway addresses, diff --git a/man/systemd.resource-control.xml b/man/systemd.resource-control.xml index 08cdf06e23..fd6f7a1b69 100644 --- a/man/systemd.resource-control.xml +++ b/man/systemd.resource-control.xml @@ -202,7 +202,7 @@            controls the <literal>memory.limit_in_bytes</literal>            control group attribute. For details about this control            group attribute, see <ulink -          url="https://www.kernel.org/doc/Documentation/cgroups/memory.txt">memory.txt</ulink>.</para> +          url="https://www.kernel.org/doc/Documentation/cgroup-v1/memory.txt">memory.txt</ulink>.</para>            <para>Implies <literal>MemoryAccounting=true</literal>.</para>          </listitem> @@ -239,7 +239,7 @@            controls the <literal>pids.max</literal> control group            attribute. For details about this control group attribute,            see <ulink -          url="https://www.kernel.org/doc/Documentation/cgroups/pids.txt">pids.txt</ulink>.</para> +          url="https://www.kernel.org/doc/Documentation/cgroup-v1/pids.txt">pids.txt</ulink>.</para>            <para>Implies <literal>TasksAccounting=true</literal>. The            system default for this setting may be controlled with @@ -273,7 +273,7 @@          the <literal>blkio.weight</literal> control group attribute,          which defaults to 500. For details about this control group          attribute, see <ulink -        url="https://www.kernel.org/doc/Documentation/cgroups/blkio-controller.txt">blkio-controller.txt</ulink>. +        url="https://www.kernel.org/doc/Documentation/cgroup-v1/blkio-controller.txt">blkio-controller.txt</ulink>.          The available I/O bandwidth is split up among all units within          one slice relative to their block I/O weight.</para> @@ -305,7 +305,7 @@            attribute, which defaults to 1000. Use this option multiple            times to set weights for multiple devices. For details about            this control group attribute, see <ulink -          url="https://www.kernel.org/doc/Documentation/cgroups/blkio-controller.txt">blkio-controller.txt</ulink>.</para> +          url="https://www.kernel.org/doc/Documentation/cgroup-v1/blkio-controller.txt">blkio-controller.txt</ulink>.</para>            <para>Implies            <literal>BlockIOAccounting=true</literal>.</para> @@ -328,12 +328,12 @@            Gigabytes, or Terabytes, respectively, to the base of            1000. (Example:            "/dev/disk/by-path/pci-0000:00:1f.2-scsi-0:0:0:0 5M"). This -          controls the <literal>blkio.read_bps_device</literal> and -          <literal>blkio.write_bps_device</literal> control group +          controls the <literal>blkio.throttle.read_bps_device</literal> and +          <literal>blkio.throttle.write_bps_device</literal> control group            attributes. Use this option multiple times to set bandwidth            limits for multiple devices. For details about these control            group attributes, see <ulink -          url="https://www.kernel.org/doc/Documentation/cgroups/blkio-controller.txt">blkio-controller.txt</ulink>. +          url="https://www.kernel.org/doc/Documentation/cgroup-v1/blkio-controller.txt">blkio-controller.txt</ulink>.            </para>            <para>Implies @@ -357,7 +357,7 @@            <literal>devices.deny</literal> control group            attributes. For details about these control group            attributes, see <ulink -          url="https://www.kernel.org/doc/Documentation/cgroups/devices.txt">devices.txt</ulink>.</para> +          url="https://www.kernel.org/doc/Documentation/cgroup-v1/devices.txt">devices.txt</ulink>.</para>            <para>The device node specifier is either a path to a device            node in the file system, starting with @@ -482,10 +482,10 @@        <citerefentry><refentrytitle>systemd.directives</refentrytitle><manvolnum>7</manvolnum></citerefentry>,        <citerefentry><refentrytitle>systemd.special</refentrytitle><manvolnum>7</manvolnum></citerefentry>,        The documentation for control groups and specific controllers in the Linux kernel: -      <ulink url="https://www.kernel.org/doc/Documentation/cgroups/cgroups.txt">cgroups.txt</ulink>, -      <ulink url="https://www.kernel.org/doc/Documentation/cgroups/cpuacct.txt">cpuacct.txt</ulink>, -      <ulink url="https://www.kernel.org/doc/Documentation/cgroups/memory.txt">memory.txt</ulink>, -      <ulink url="https://www.kernel.org/doc/Documentation/cgroups/blkio-controller.txt">blkio-controller.txt</ulink>. +      <ulink url="https://www.kernel.org/doc/Documentation/cgroup-v1/cgroups.txt">cgroups.txt</ulink>, +      <ulink url="https://www.kernel.org/doc/Documentation/cgroup-v1/cpuacct.txt">cpuacct.txt</ulink>, +      <ulink url="https://www.kernel.org/doc/Documentation/cgroup-v1/memory.txt">memory.txt</ulink>, +      <ulink url="https://www.kernel.org/doc/Documentation/cgroup-v1/blkio-controller.txt">blkio-controller.txt</ulink>.      </para>    </refsect1>  </refentry> diff --git a/src/basic/hostname-util.c b/src/basic/hostname-util.c index 5a7ee87a20..13c3bb6446 100644 --- a/src/basic/hostname-util.c +++ b/src/basic/hostname-util.c @@ -178,16 +178,16 @@ bool is_localhost(const char *hostname) {          assert(hostname);          /* This tries to identify local host and domain names -         * described in RFC6761 plus the redhatism of .localdomain */ +         * described in RFC6761 plus the redhatism of localdomain */          return strcaseeq(hostname, "localhost") ||                 strcaseeq(hostname, "localhost.") || -               strcaseeq(hostname, "localdomain.") || -               strcaseeq(hostname, "localdomain") || +               strcaseeq(hostname, "localhost.localdomain") || +               strcaseeq(hostname, "localhost.localdomain.") ||                 endswith_no_case(hostname, ".localhost") ||                 endswith_no_case(hostname, ".localhost.") || -               endswith_no_case(hostname, ".localdomain") || -               endswith_no_case(hostname, ".localdomain."); +               endswith_no_case(hostname, ".localhost.localdomain") || +               endswith_no_case(hostname, ".localhost.localdomain.");  }  bool is_gateway_hostname(const char *hostname) { diff --git a/src/libsystemd/sd-device/sd-device.c b/src/libsystemd/sd-device/sd-device.c index 8657e61cd9..e9f8970d2c 100644 --- a/src/libsystemd/sd-device/sd-device.c +++ b/src/libsystemd/sd-device/sd-device.c @@ -1457,15 +1457,20 @@ static int device_properties_prepare(sd_device *device) {                  return r;          if (device->property_devlinks_outdated) { -                char *devlinks = NULL; +                _cleanup_free_ char *devlinks = NULL; +                size_t devlinks_allocated = 0, devlinks_len = 0;                  const char *devlink; -                devlink = sd_device_get_devlink_first(device); -                if (devlink) -                        devlinks = strdupa(devlink); +                for (devlink = sd_device_get_devlink_first(device); devlink; devlink = sd_device_get_devlink_next(device)) { +                        char *e; -                while ((devlink = sd_device_get_devlink_next(device))) -                        devlinks = strjoina(devlinks, " ", devlink); +                        if (!GREEDY_REALLOC(devlinks, devlinks_allocated, devlinks_len + strlen(devlink) + 2)) +                                return -ENOMEM; +                        if (devlinks_len > 0) +                                stpcpy(devlinks + devlinks_len++, " "); +                        e = stpcpy(devlinks + devlinks_len, devlink); +                        devlinks_len = e - devlinks; +                }                  r = device_add_property_internal(device, "DEVLINKS", devlinks);                  if (r < 0) @@ -1475,17 +1480,23 @@ static int device_properties_prepare(sd_device *device) {          }          if (device->property_tags_outdated) { -                char *tags = NULL; +                _cleanup_free_ char *tags = NULL; +                size_t tags_allocated = 0, tags_len = 0;                  const char *tag; -                tag = sd_device_get_tag_first(device); -                if (tag) -                        tags = strjoina(":", tag); +                if (!GREEDY_REALLOC(tags, tags_allocated, 2)) +                        return -ENOMEM; +                stpcpy(tags, ":"); +                tags_len++; -                while ((tag = sd_device_get_tag_next(device))) -                        tags = strjoina(tags, ":", tag); +                for (tag = sd_device_get_tag_first(device); tag; tag = sd_device_get_tag_next(device)) { +                        char *e; -                tags = strjoina(tags, ":"); +                        if (!GREEDY_REALLOC(tags, tags_allocated, tags_len + strlen(tag) + 1)) +                                return -ENOMEM; +                        e = stpcpy(stpcpy(tags + tags_len, tag), ":"); +                        tags_len = e - tags; +                }                  r = device_add_property_internal(device, "TAGS", tags);                  if (r < 0) diff --git a/src/shared/spawn-polkit-agent.c b/src/shared/spawn-polkit-agent.c index cf3c8ad5a3..7dae4d14fe 100644 --- a/src/shared/spawn-polkit-agent.c +++ b/src/shared/spawn-polkit-agent.c @@ -44,6 +44,10 @@ int polkit_agent_open(void) {          if (agent_pid > 0)                  return 0; +        /* Clients that run as root don't need to activate/query polkit */ +        if (geteuid() == 0) +                return 0; +          /* We check STDIN here, not STDOUT, since this is about input,           * not output */          if (!isatty(STDIN_FILENO)) diff --git a/src/test/test-udev.c b/src/test/test-udev.c index d01789fe08..64ef08652c 100644 --- a/src/test/test-udev.c +++ b/src/test/test-udev.c @@ -40,11 +40,11 @@ static int fake_filesystems(void) {                  const char *target;                  const char *error;          } fakefss[] = { -                { "test/sys", "/sys",                   "failed to mount test /sys" }, -                { "test/dev", "/dev",                   "failed to mount test /dev" }, -                { "test/run", "/run",                   "failed to mount test /run" }, -                { "test/run", "/etc/udev/rules.d",      "failed to mount empty /etc/udev/rules.d" }, -                { "test/run", UDEVLIBEXECDIR "/rules.d","failed to mount empty " UDEVLIBEXECDIR "/rules.d" }, +                { "test/tmpfs/sys", "/sys",                   "failed to mount test /sys" }, +                { "test/dev",       "/dev",                   "failed to mount test /dev" }, +                { "test/run",       "/run",                   "failed to mount test /run" }, +                { "test/run",       "/etc/udev/rules.d",      "failed to mount empty /etc/udev/rules.d" }, +                { "test/run",       UDEVLIBEXECDIR "/rules.d","failed to mount empty " UDEVLIBEXECDIR "/rules.d" },          };          unsigned int i;          int err; diff --git a/test/udev-test.pl b/test/udev-test.pl index b047493f6b..3c8a480d0f 100755 --- a/test/udev-test.pl +++ b/test/udev-test.pl @@ -29,6 +29,7 @@ my $udev_bin_gdb        = "gdb --args $udev_bin";  my $udev_bin_strace     = "strace -efile $udev_bin";  my $udev_dev            = "test/dev";  my $udev_run            = "test/run"; +my $udev_tmpfs          = "test/tmpfs";  my $udev_rules_dir      = "$udev_run/udev/rules.d";  my $udev_rules          = "$udev_rules_dir/udev-test.rules";  my $EXIT_TEST_SKIP      = 77; @@ -1412,6 +1413,12 @@ sub udev_setup {          chown (0, 0, $udev_dev) || die "unable to chown $udev_dev\n";          chmod (0755, $udev_dev) || die "unable to chmod $udev_dev\n"; +        system("umount", "$udev_tmpfs"); +        system("rm", "-rf", "$udev_tmpfs"); +        mkdir($udev_tmpfs) || die "unable to create udev_tmpfs: $udev_tmpfs\n"; +        system("mount", "-o", "rw,mode=755,nosuid,noexec,nodev", "-t", "tmpfs", "tmpfs", "$udev_tmpfs") && die "unable to mount tmpfs"; +        system("cp", "-r", "test/sys/", "$udev_tmpfs") && die "unable to copy test/sys"; +          system("rm", "-rf", "$udev_run");  } @@ -1545,6 +1552,8 @@ print "$error errors occurred\n\n";  # cleanup  system("rm", "-rf", "$udev_dev");  system("rm", "-rf", "$udev_run"); +system("umount", "$udev_tmpfs"); +system("rm", "-rf", "$udev_tmpfs");  if ($error > 0) {      exit(1); | 
