diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/basic/missing.h | 2 | ||||
| -rw-r--r-- | src/core/dbus-execute.c | 27 | ||||
| -rw-r--r-- | src/shared/bus-util.c | 3 | 
3 files changed, 22 insertions, 10 deletions
| diff --git a/src/basic/missing.h b/src/basic/missing.h index dc1f244d4c..93a7cb9aa0 100644 --- a/src/basic/missing.h +++ b/src/basic/missing.h @@ -139,6 +139,8 @@ static inline int pivot_root(const char *new_root, const char *put_old) {  #    define __NR_memfd_create 385  #  elif defined __aarch64__  #    define __NR_memfd_create 279 +#  elif defined __s390__ +#    define __NR_memfd_create 350  #  elif defined _MIPS_SIM  #    if _MIPS_SIM == _MIPS_SIM_ABI32  #      define __NR_memfd_create 4354 diff --git a/src/core/dbus-execute.c b/src/core/dbus-execute.c index fd13c6d019..868c8cc05a 100644 --- a/src/core/dbus-execute.c +++ b/src/core/dbus-execute.c @@ -847,27 +847,36 @@ int bus_exec_context_set_transient_property(                  return 1; -        } else if (streq(name, "TTYPath")) { -                const char *tty; +        } else if (STR_IN_SET(name, +                              "TTYPath", "WorkingDirectory", "RootDirectory")) { +                const char *s; -                r = sd_bus_message_read(message, "s", &tty); +                r = sd_bus_message_read(message, "s", &s);                  if (r < 0)                          return r; -                if (!path_is_absolute(tty)) -                        return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "TTY device not absolute path"); +                if (!path_is_absolute(s)) +                        return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "%s takes an absolute path", name);                  if (mode != UNIT_CHECK) {                          char *t; -                        t = strdup(tty); +                        t = strdup(s);                          if (!t)                                  return -ENOMEM; -                        free(c->tty_path); -                        c->tty_path = t; +                        if (streq(name, "TTYPath")) { +                                free(c->tty_path); +                                c->tty_path = t; +                        } else if (streq(name, "WorkingDirectory")) { +                                free(c->working_directory); +                                c->working_directory = t; +                        } else if (streq(name, "RootDirectory")) { +                                free(c->root_directory); +                                c->root_directory = t; +                        } -                        unit_write_drop_in_private_format(u, mode, name, "TTYPath=%s\n", tty); +                        unit_write_drop_in_private_format(u, mode, name, "%s=%s\n", name, s);                  }                  return 1; diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index fdf41cec19..16b17c2c82 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -1492,7 +1492,8 @@ int bus_append_unit_property_assignment(sd_bus_message *m, const char *assignmen                                "User", "Group", "DevicePolicy", "KillMode",                                "UtmpIdentifier", "UtmpMode", "PAMName", "TTYPath",                                "StandardInput", "StandardOutput", "StandardError", -                              "Description", "Slice", "Type")) +                              "Description", "Slice", "Type", "WorkingDirectory", +                              "RootDirectory"))                  r = sd_bus_message_append(m, "v", "s", eq);          else if (streq(field, "DeviceAllow")) { | 
