diff options
| -rw-r--r-- | hwdb/20-bluetooth-vendor-product.hwdb | 93 | ||||
| -rw-r--r-- | man/machinectl.xml | 19 | ||||
| -rw-r--r-- | man/sd_bus_message_append.xml | 5 | ||||
| -rw-r--r-- | man/systemd.exec.xml | 9 | ||||
| -rw-r--r-- | src/core/main.c | 6 | ||||
| -rw-r--r-- | src/core/manager.c | 2 | ||||
| -rw-r--r-- | src/core/show-status.c | 5 | ||||
| -rw-r--r-- | src/journal/journald-console.c | 5 | 
8 files changed, 126 insertions, 18 deletions
| diff --git a/hwdb/20-bluetooth-vendor-product.hwdb b/hwdb/20-bluetooth-vendor-product.hwdb index ab6e321ff6..9cba3bfc05 100644 --- a/hwdb/20-bluetooth-vendor-product.hwdb +++ b/hwdb/20-bluetooth-vendor-product.hwdb @@ -3026,3 +3026,96 @@ bluetooth:v03ED*  bluetooth:v03EE*   ID_VENDOR_FROM_DATABASE=CUBE TECHNOLOGIES + +bluetooth:v03EF* + ID_VENDOR_FROM_DATABASE=foolography GmbH + +bluetooth:v03F0* + ID_VENDOR_FROM_DATABASE=CLINK + +bluetooth:v03F1* + ID_VENDOR_FROM_DATABASE=Hestan Smart Cooking Inc. + +bluetooth:v03F2* + ID_VENDOR_FROM_DATABASE=WindowMaster A/S + +bluetooth:v03F3* + ID_VENDOR_FROM_DATABASE=Flowscape AB + +bluetooth:v03F4* + ID_VENDOR_FROM_DATABASE=PAL Technologies Ltd + +bluetooth:v03F5* + ID_VENDOR_FROM_DATABASE=WHERE, Inc. + +bluetooth:v03F6* + ID_VENDOR_FROM_DATABASE=Iton Technology Corp. + +bluetooth:v03F7* + ID_VENDOR_FROM_DATABASE=Owl Labs Inc. + +bluetooth:v03F8* + ID_VENDOR_FROM_DATABASE=Rockford Corp. + +bluetooth:v03F9* + ID_VENDOR_FROM_DATABASE=Becon Technologies Co.,Ltd. + +bluetooth:v03FA* + ID_VENDOR_FROM_DATABASE=Vyassoft Technologies Inc + +bluetooth:v03FB* + ID_VENDOR_FROM_DATABASE=Nox Medical + +bluetooth:v03FC* + ID_VENDOR_FROM_DATABASE=Kimberly-Clark + +bluetooth:v03FD* + ID_VENDOR_FROM_DATABASE=Trimble Navigation Ltd. + +bluetooth:v03FE* + ID_VENDOR_FROM_DATABASE=Littelfuse + +bluetooth:v03FF* + ID_VENDOR_FROM_DATABASE=Withings + +bluetooth:v0400* + ID_VENDOR_FROM_DATABASE=i-developer IT Beratung UG + +bluetooth:v0401* + ID_VENDOR_FROM_DATABASE=リレーションズ株式会社 + +bluetooth:v0402* + ID_VENDOR_FROM_DATABASE=Sears Holdings Corporation + +bluetooth:v0403* + ID_VENDOR_FROM_DATABASE=Gantner Electronic GmbH + +bluetooth:v0404* + ID_VENDOR_FROM_DATABASE=Authomate Inc + +bluetooth:v0405* + ID_VENDOR_FROM_DATABASE=Vertex International, Inc. + +bluetooth:v0406* + ID_VENDOR_FROM_DATABASE=Airtago + +bluetooth:v0407* + ID_VENDOR_FROM_DATABASE=Swiss Audio SA + +bluetooth:v0408* + ID_VENDOR_FROM_DATABASE=ToGetHome Inc. + +bluetooth:v0409* + ID_VENDOR_FROM_DATABASE=AXIS + +bluetooth:v040A* + ID_VENDOR_FROM_DATABASE=Openmatics + +bluetooth:v040B* + ID_VENDOR_FROM_DATABASE=Jana Care Inc. + +bluetooth:v040C* + ID_VENDOR_FROM_DATABASE=Senix Corporation + +bluetooth:v040D* + ID_VENDOR_FROM_DATABASE=NorthStar Battery Company, LLC diff --git a/man/machinectl.xml b/man/machinectl.xml index eaa247714b..0d57c01765 100644 --- a/man/machinectl.xml +++ b/man/machinectl.xml @@ -343,18 +343,13 @@        <varlistentry>          <term><command>show</command> [<replaceable>NAME</replaceable>...]</term> -        <listitem><para>Show properties of one or more registered -        virtual machines or containers or the manager itself. If no -        argument is specified, properties of the manager will be -        shown. If a NAME is specified, properties of this virtual -        machine or container are shown. By default, empty properties -        are suppressed. Use <option>--all</option> to show those too. -        To select specific properties to show, use -        <option>--property=</option>. This command is intended to be -        used whenever computer-parsable output is required, and does -        not print the cgroup tree or journal entries. Use -        <command>status</command> if you are looking for formatted -        human-readable output.</para></listitem> +        <listitem><para>Show properties of one or more registered virtual machines or containers or the manager +        itself. If no argument is specified, properties of the manager will be shown. If a NAME is specified, +        properties of this virtual machine or container are shown. By default, empty properties are suppressed. Use +        <option>--all</option> to show those too.  To select specific properties to show, use +        <option>--property=</option>. This command is intended to be used whenever computer-parsable output is +        required, and does not print the control group tree or journal entries. Use <command>status</command> if you +        are looking for formatted human-readable output.</para></listitem>        </varlistentry>        <varlistentry> diff --git a/man/sd_bus_message_append.xml b/man/sd_bus_message_append.xml index 77fce02eae..c222d0fd0e 100644 --- a/man/sd_bus_message_append.xml +++ b/man/sd_bus_message_append.xml @@ -169,6 +169,11 @@        </tgroup>      </table> +    <para>For types "s" and "g" (unicode string or signature), the pointer may be +    <constant>NULL</constant>, which is equivalent to an empty string. See +    <citerefentry><refentrytitle>sd_bus_message_append_basic</refentrytitle><manvolnum>3</manvolnum></citerefentry> +    for the precise interpretation of those and other types.</para> +    </refsect1>    <refsect1> diff --git a/man/systemd.exec.xml b/man/systemd.exec.xml index 7453aa7bee..dbe4594730 100644 --- a/man/systemd.exec.xml +++ b/man/systemd.exec.xml @@ -141,8 +141,13 @@          <term><varname>Group=</varname></term>          <listitem><para>Set the UNIX user or group that the processes are executed as, respectively. Takes a single -        user or group name, or numeric ID as argument. If no group is set, the default group of the user is used. This -        setting does not affect commands whose command line is prefixed with <literal>+</literal>.</para></listitem> +        user or group name, or numeric ID as argument. For system services (services run by the system service manager, +        i.e. managed by PID 1) and for user services of the root user (services managed by root's instance of +        <command>systemd --user</command>), the default is <literal>root</literal>, but <varname>User=</varname> may be +        used to specify a different user. For user services of any other user, switching user identity is not +        permitted, hence the only valid setting is the same user the user's service manager is running as. If no group +        is set, the default group of the user is used. This setting does not affect commands whose command line is +        prefixed with <literal>+</literal>.</para></listitem>        </varlistentry>        <varlistentry> diff --git a/src/core/main.c b/src/core/main.c index 61f3828a36..cf3c640a73 100644 --- a/src/core/main.c +++ b/src/core/main.c @@ -1124,7 +1124,7 @@ static int bump_rlimit_nofile(struct rlimit *saved_rlimit) {           * later when transitioning from the initrd to the main           * systemd or suchlike. */          if (getrlimit(RLIMIT_NOFILE, saved_rlimit) < 0) -                return log_error_errno(errno, "Reading RLIMIT_NOFILE failed: %m"); +                return log_warning_errno(errno, "Reading RLIMIT_NOFILE failed, ignoring: %m");          /* Make sure forked processes get the default kernel setting */          if (!arg_default_rlimit[RLIMIT_NOFILE]) { @@ -1141,7 +1141,7 @@ static int bump_rlimit_nofile(struct rlimit *saved_rlimit) {          nl.rlim_cur = nl.rlim_max = 64*1024;          r = setrlimit_closest(RLIMIT_NOFILE, &nl);          if (r < 0) -                return log_error_errno(r, "Setting RLIMIT_NOFILE failed: %m"); +                return log_warning_errno(r, "Setting RLIMIT_NOFILE failed, ignoring: %m");          return 0;  } @@ -1775,7 +1775,7 @@ int main(int argc, char *argv[]) {                          log_warning_errno(errno, "Failed to make us a subreaper: %m");          if (arg_system) { -                bump_rlimit_nofile(&saved_rlimit_nofile); +                (void) bump_rlimit_nofile(&saved_rlimit_nofile);                  if (empty_etc) {                          r = unit_file_preset_all(UNIT_FILE_SYSTEM, false, NULL, UNIT_FILE_PRESET_ENABLE_ONLY, false, NULL, 0); diff --git a/src/core/manager.c b/src/core/manager.c index 50aae0d1ba..65f163de31 100644 --- a/src/core/manager.c +++ b/src/core/manager.c @@ -3098,7 +3098,7 @@ int manager_set_default_rlimits(Manager *m, struct rlimit **default_rlimit) {                  m->rlimit[i] = newdup(struct rlimit, default_rlimit[i], 1);                  if (!m->rlimit[i]) -                        return -ENOMEM; +                        return log_oom();          }          return 0; diff --git a/src/core/show-status.c b/src/core/show-status.c index 59ebdc7219..65f9cb888a 100644 --- a/src/core/show-status.c +++ b/src/core/show-status.c @@ -61,6 +61,11 @@ int status_vprintf(const char *status, bool ellipse, bool ephemeral, const char          if (vasprintf(&s, format, ap) < 0)                  return log_oom(); +        /* Before you ask: yes, on purpose we open/close the console for each status line we write individually. This +         * is a good strategy to avoid PID 1 getting killed by the kernel's SAK concept (it doesn't fix this entirely, +         * but minimizes the time window the kernel might end up killing PID 1 due to SAK). It also makes things easier +         * for us so that we don't have to recover from hangups and suchlike triggered on the console. */ +          fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);          if (fd < 0)                  return fd; diff --git a/src/journal/journald-console.c b/src/journal/journald-console.c index fcc9f25814..3a9fba42a3 100644 --- a/src/journal/journald-console.c +++ b/src/journal/journald-console.c @@ -102,6 +102,11 @@ void server_forward_console(          tty = s->tty_path ? s->tty_path : "/dev/console"; +        /* Before you ask: yes, on purpose we open/close the console for each log line we write individually. This is a +         * good strategy to avoid journald getting killed by the kernel's SAK concept (it doesn't fix this entirely, +         * but minimizes the time window the kernel might end up killing journald due to SAK). It also makes things +         * easier for us so that we don't have to recover from hangups and suchlike triggered on the console. */ +          fd = open_terminal(tty, O_WRONLY|O_NOCTTY|O_CLOEXEC);          if (fd < 0) {                  log_debug_errno(fd, "Failed to open %s for logging: %m", tty); | 
