]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
7 years agotree-wide: use sd_id128_is_null() instead of sd_id128_equal where appropriate
Lennart Poettering [Thu, 21 Jul 2016 14:06:31 +0000 (16:06 +0200)] 
tree-wide: use sd_id128_is_null() instead of sd_id128_equal where appropriate

It's a bit easier to read because shorter. Also, most likely a tiny bit faster.

7 years agoMerge pull request #3762 from poettering/sigkill-log
Martin Pitt [Fri, 22 Jul 2016 07:18:30 +0000 (09:18 +0200)] 
Merge pull request #3762 from poettering/sigkill-log

log about all processes we forcibly kill

7 years agoMerge pull request #3764 from poettering/assorted-stuff-2
Martin Pitt [Fri, 22 Jul 2016 07:10:04 +0000 (09:10 +0200)] 
Merge pull request #3764 from poettering/assorted-stuff-2

Assorted fixes

7 years agonspawn: enable major=0/minor=0 devices inside the container (#3773)
Alessandro Puccetti [Thu, 21 Jul 2016 15:39:38 +0000 (17:39 +0200)] 
nspawn: enable major=0/minor=0 devices inside the container (#3773)

https://github.com/systemd/systemd/pull/3685 introduced
/run/systemd/inaccessible/{chr,blk} to map inacessible devices,
this patch allows systemd running inside a nspawn container to create
/run/systemd/inaccessible/{chr,blk}.

7 years agomissing_syscall: add __NR_copy_file_range for powerpc architecture (#3772)
Alessio Igor Bogani [Thu, 21 Jul 2016 09:40:35 +0000 (11:40 +0200)] 
missing_syscall: add __NR_copy_file_range for powerpc architecture (#3772)

7 years agoupdate TODO
Lennart Poettering [Thu, 21 Jul 2016 09:09:24 +0000 (11:09 +0200)] 
update TODO

7 years agohwdb: axis resolution override for the Lenovo Y700 (#3769)
Peter Hutterer [Thu, 21 Jul 2016 08:55:36 +0000 (18:55 +1000)] 
hwdb: axis resolution override for the Lenovo Y700 (#3769)

https://bugs.freedesktop.org/show_bug.cgi?id=97011

7 years agoMerge pull request #3770 from AlexanderKurtz/master
Lennart Poettering [Thu, 21 Jul 2016 08:55:05 +0000 (10:55 +0200)] 
Merge pull request #3770 from AlexanderKurtz/master

bootctl: Always use upper case for "/EFI/BOOT" and "/EFI/BOOT/BOOT*.EFI".

7 years agocore: remove duplicate includes (#3771)
Thomas H. P. Andersen [Thu, 21 Jul 2016 08:52:07 +0000 (10:52 +0200)] 
core: remove duplicate includes (#3771)

7 years agoMerge pull request #3760 from poettering/rfkill-fix
Zbigniew Jędrzejewski-Szmek [Thu, 21 Jul 2016 02:19:05 +0000 (22:19 -0400)] 
Merge pull request #3760 from poettering/rfkill-fix

rfkill dead-lock fix

7 years agodocumentation: add a short document describing how to test your systemd build tree...
Lennart Poettering [Thu, 21 Jul 2016 02:15:54 +0000 (04:15 +0200)] 
documentation: add a short document describing how to test your systemd build tree (#3763)

7 years agobootctl: Always use upper case for "/EFI/BOOT" and "/EFI/BOOT/BOOT*.EFI". 3770/head
Alexander Kurtz [Thu, 21 Jul 2016 00:29:54 +0000 (02:29 +0200)] 
bootctl: Always use upper case for "/EFI/BOOT" and "/EFI/BOOT/BOOT*.EFI".

If the ESP is not mounted with "iocharset=ascii", but with "iocharset=utf8"
(which is for example the default in Debian), the file system becomes case
sensitive. This means that a file created as "FooBarBaz" cannot be accessed as
"foobarbaz" since those are then considered different files.

Moreover, a file created as "FooBar" can then also not be accessed as "foobar",
and it also prevents such a file from being created, as both would use the same
8.3 short name "FOOBAR".

Even though the UEFI specification [0] does give the canonical spelling for
the files mentioned above, not all implementations completely conform to that,
so it's possible that those files would already exist, but with a different
spelling, causing subtle bugs when scanning or modifying the ESP.

While the proper fix would of course be that everybody conformed to the
standard, we can work around this problem by just referencing the files by
their 8.3 short names, i.e. using upper case.

Fixes: #3740
[0] <http://www.uefi.org/specifications>, version 2.6, section 3.5.1.1

7 years agobootctl: Use lower case string constants in case-insensitive comparisons.
Alexander Kurtz [Thu, 21 Jul 2016 00:20:12 +0000 (02:20 +0200)] 
bootctl: Use lower case string constants in case-insensitive comparisons.

7 years agonamespace: fix wrong return value from mount(2) (#3758)
Topi Miettinen [Wed, 20 Jul 2016 14:43:21 +0000 (14:43 +0000)] 
namespace: fix wrong return value from mount(2) (#3758)

Fix bug introduced by #3263: mount(2) return value is 0 or -1, not errno.

Thanks to Evgeny Vereshchagin (@evverx) for reporting.

7 years agobasic: fix macro definition in nss-util.h 3764/head
Lennart Poettering [Thu, 14 Jul 2016 17:16:19 +0000 (19:16 +0200)] 
basic: fix macro definition in nss-util.h

Fix a copy/paste mistake.

7 years agoexecute: make sure JoinsNamespaceOf= doesn't leak ns fds to executed processes
Lennart Poettering [Thu, 14 Jul 2016 11:12:01 +0000 (13:12 +0200)] 
execute: make sure JoinsNamespaceOf= doesn't leak ns fds to executed processes

7 years agonamespace: add a (void) cast
Lennart Poettering [Thu, 14 Jul 2016 10:28:54 +0000 (12:28 +0200)] 
namespace: add a (void) cast

7 years agonspawn: when netns is on, mount /proc/sys/net writable
Lennart Poettering [Thu, 14 Jul 2016 14:53:13 +0000 (16:53 +0200)] 
nspawn: when netns is on, mount /proc/sys/net writable

Normally we make all of /proc/sys read-only in a container, but if we do have
netns enabled we can make /proc/sys/net writable, as things are virtualized
then.

7 years agonspawn: document why the uid shift range is the way it is
Lennart Poettering [Thu, 14 Jul 2016 10:25:32 +0000 (12:25 +0200)] 
nspawn: document why the uid shift range is the way it is

7 years agoconf-parser: minor coding style improvements
Lennart Poettering [Thu, 14 Jul 2016 10:24:59 +0000 (12:24 +0200)] 
conf-parser: minor coding style improvements

7 years agounits: fix TasksMax=16384 for systemd-nspawn@.service
Lennart Poettering [Thu, 14 Jul 2016 10:20:29 +0000 (12:20 +0200)] 
units: fix TasksMax=16384 for systemd-nspawn@.service

When a container scope is allocated via machined it gets 16K set already since
cf7d1a30e44bf380027a2e73f9bf13f423a33cc1. Make sure when a container is run as
system service it gets the same values.

7 years agocore: normalize header inclusion in execute.h a bit
Lennart Poettering [Sat, 2 Jul 2016 02:58:14 +0000 (19:58 -0700)] 
core: normalize header inclusion in execute.h a bit

We don't actually need any functionality from cgroup.h in execute.h, hence
don't include that. However, we do need the Unit structure from unit.h, hence
include that, and move it as late as possible, since it needs the definitions
from execute.h.

7 years agoexecute: normalize connect_logger_as() parameters slightly
Lennart Poettering [Sat, 2 Jul 2016 02:57:21 +0000 (19:57 -0700)] 
execute: normalize connect_logger_as() parameters slightly

All other functions in execute.c that need the unit id take a Unit* parameter
as first argument. Let's change connect_logger_as() to follow a similar logic.

7 years agologind: always abandon session scopes before killing them 3762/head
Lennart Poettering [Wed, 20 Jul 2016 11:42:36 +0000 (13:42 +0200)] 
logind: always abandon session scopes before killing them

This way systemd is informed that we consider everything inside the scope as
"left-over", and systemd can log about killing it.

With this change systemd will log about all processes killed due to the session
clean-up on KillUserProcesses=yes.

7 years agocore: when a scope was abandoned, always log about processes we kill
Lennart Poettering [Wed, 20 Jul 2016 11:41:32 +0000 (13:41 +0200)] 
core: when a scope was abandoned, always log about processes we kill

After all, if a unit is abandoned, all processes inside of it may be considered
"left over" and are something we should better log about.

7 years agocore: make sure RequestStop signal is send directed
Lennart Poettering [Wed, 20 Jul 2016 11:39:23 +0000 (13:39 +0200)] 
core: make sure RequestStop signal is send directed

This was accidentally left commented out for debugging purposes, let's fix that
and make the signal directed again.

7 years agocgroup: suppress sending follow-up SIGCONT after sending SIGCONT/SIGKILL anyway
Lennart Poettering [Wed, 20 Jul 2016 09:16:53 +0000 (11:16 +0200)] 
cgroup: suppress sending follow-up SIGCONT after sending SIGCONT/SIGKILL anyway

7 years agocore: when forcibly killing/aborting left-over unit processes log about it
Lennart Poettering [Wed, 20 Jul 2016 09:16:05 +0000 (11:16 +0200)] 
core: when forcibly killing/aborting left-over unit processes log about it

Let's lot at LOG_NOTICE about any processes that we are going to
SIGKILL/SIGABRT because clean termination of them didn't work.

This turns the various boolean flag parameters to cg_kill(), cg_migrate() and
related calls into a single binary flags parameter, simply because the function
now gained even more parameters and the parameter listed shouldn't get too
long.

Logging for killing processes is done either when the kill signal is SIGABRT or
SIGKILL, or on explicit request if KILL_TERMINATE_AND_LOG instead of LOG_TERMINATE
is passed. This isn't used yet in this patch, but is made use of in a later
patch.

7 years agoPO: italian updates (#3761)
Daniele Medri [Wed, 20 Jul 2016 11:02:28 +0000 (13:02 +0200)] 
PO: italian updates (#3761)

7 years agoutil: don't send SIGCONT following a SIGCONT or SIGKILL in kill_and_sigcont()
Lennart Poettering [Wed, 20 Jul 2016 09:14:48 +0000 (11:14 +0200)] 
util: don't send SIGCONT following a SIGCONT or SIGKILL in kill_and_sigcont()

7 years agologind: minor coding style improvements
Lennart Poettering [Wed, 20 Jul 2016 09:14:18 +0000 (11:14 +0200)] 
logind: minor coding style improvements

7 years agoMerge pull request #3759 from poettering/namespace-fixup
Lennart Poettering [Wed, 20 Jul 2016 07:22:40 +0000 (09:22 +0200)] 
Merge pull request #3759 from poettering/namespace-fixup

minor follow-up fixes for #3685

7 years agorules: make sure always set at least one property on rfkill devices 3760/head
Lennart Poettering [Wed, 20 Jul 2016 07:17:57 +0000 (09:17 +0200)] 
rules: make sure always set at least one property on rfkill devices

The rfkill service waits for rfkill device initialization as reported by
udev_device_is_initialized(), and if that is never reported it might dead-lock.

However, udev never reports completed initialization for devices that have no
properties or tags set. For some rfkill devices this might be the case, in
particular those which are connected to exotic busses, where path_id returns
nothing.

This patch simply sets the SYSTEM_RFKILL property on all rfkill devices, to
ensure that udev_device_is_initialized() always reports something useful and we
don't dead-lock.

Fixes: #2745
7 years agoman: document a tiny bit better what udev_device_get_is_initialized() actually returns
Lennart Poettering [Wed, 20 Jul 2016 07:17:33 +0000 (09:17 +0200)] 
man: document a tiny bit better what udev_device_get_is_initialized() actually returns

7 years agonamespace: minor improvements 3759/head
Lennart Poettering [Wed, 20 Jul 2016 06:57:25 +0000 (08:57 +0200)] 
namespace: minor improvements

We generally try to avoid strerror(), due to its threads-unsafety, let's do
this here, too.

Also, let's be tiny bit more explanatory with the log messages, and let's
shorten a few things.

7 years agocore: hide legacy bus properties
Lennart Poettering [Wed, 20 Jul 2016 06:55:50 +0000 (08:55 +0200)] 
core: hide legacy bus properties

We usually hide legacy bus properties from introspection. Let's do that for the
InaccessibleDirectories= properties too.

The properties stay accessible if requested, but they won't be listed anymore
if people introspect the unit.

7 years agoman: revise entry about specifying a file path (#3739)
mulkieran [Wed, 20 Jul 2016 03:15:22 +0000 (23:15 -0400)] 
man: revise entry about specifying a file path (#3739)

* Specifying a device node has an effect much larger than a simple shortcut
for a field/value match, so the original sentence is no longer a good way
to start the paragraph.
* Specifying a device node causes matches to be generated for all ancestor
devices of the device specified, not just its parents.
* Indicates that the path must be absolute, but that it may be a link.
* Eliminates a few typos.

7 years agoman: mention that locale changes might require initramfs to be rebuilt (#3754)
Zbigniew Jędrzejewski-Szmek [Tue, 19 Jul 2016 19:24:23 +0000 (15:24 -0400)] 
man: mention that locale changes might require initramfs to be rebuilt (#3754)

https://bugzilla.redhat.com/show_bug.cgi?id=1151651

Also explain what localectl does a bit better:
https://bugzilla.redhat.com/show_bug.cgi?id=1357861

7 years agoMerge pull request #3685 from kinvolk/alessandro/inaccessible-paths
Lennart Poettering [Tue, 19 Jul 2016 19:17:49 +0000 (21:17 +0200)] 
Merge pull request #3685 from kinvolk/alessandro/inaccessible-paths

namespace: unify limit behavior on non-directory paths

7 years agoMerge pull request #3636 from poettering/logs-show-utf8
Evgeny Vereshchagin [Tue, 19 Jul 2016 18:11:41 +0000 (21:11 +0300)] 
Merge pull request #3636 from poettering/logs-show-utf8

improve handling of trailing newline in journal logging

7 years agosd-journal: suppress empty lines 3636/head
Lennart Poettering [Tue, 19 Jul 2016 12:27:05 +0000 (14:27 +0200)] 
sd-journal: suppress empty lines

Let's make sure our logging APIs is in sync with how stdout/stderr logging
works.

7 years agodoc,core: Read{Write,Only}Paths= and InaccessiblePaths= 3685/head
Alessandro Puccetti [Thu, 7 Jul 2016 09:17:00 +0000 (11:17 +0200)] 
doc,core: Read{Write,Only}Paths= and InaccessiblePaths=

This patch renames Read{Write,Only}Directories= and InaccessibleDirectories=
to Read{Write,Only}Paths= and InaccessiblePaths=, previous names are kept
as aliases but they are not advertised in the documentation.

Renamed variables:
`read_write_dirs` --> `read_write_paths`
`read_only_dirs` --> `read_only_paths`
`inaccessible_dirs` --> `inaccessible_paths`

7 years agonamespace: unify limit behavior on non-directory paths
Alessandro Puccetti [Wed, 6 Jul 2016 07:48:58 +0000 (09:48 +0200)] 
namespace: unify limit behavior on non-directory paths

Despite the name, `Read{Write,Only}Directories=` already allows for
regular file paths to be masked. This commit adds the same behavior
to `InaccessibleDirectories=` and makes it explicit in the doc.
This patch introduces `/run/systemd/inaccessible/{reg,dir,chr,blk,fifo,sock}`
{dile,device}nodes and mounts on the appropriate one the paths specified
in `InacessibleDirectories=`.

Based on Luca's patch from https://github.com/systemd/systemd/pull/3327

7 years agoman: document that sd_journal_print() strips trailing whitespace
Lennart Poettering [Sat, 2 Jul 2016 00:10:26 +0000 (17:10 -0700)] 
man: document that sd_journal_print() strips trailing whitespace

7 years agojournalctl: make sure that journalctl's --all switch also has an effect on json output
Lennart Poettering [Fri, 1 Jul 2016 00:41:19 +0000 (17:41 -0700)] 
journalctl: make sure that journalctl's --all switch also has an effect on json output

With this change, binary record data is formatted as string if --all is
specified when using json output. This is inline with the effect of --all on
the other available output modes.

Fixes: #3416
7 years agosd-journal: when formatting log messages, implicitly strip trailing whitespace
Lennart Poettering [Fri, 1 Jul 2016 00:37:21 +0000 (17:37 -0700)] 
sd-journal: when formatting log messages, implicitly strip trailing whitespace

When converting log messages from human readable text into binary records to
send off to journald in sd_journal_print(), strip trailing whitespace in the
log message. This way, handling of logs made via syslog(), stdout/stderr and
sd_journal_print() are treated the same way: trailing (but not leading)
whitespace is automatically removed, in particular \n and \r. Note that in case
of syslog() and stdout/stderr based logging the stripping takes place
server-side though, while for the native protocol based transport this takes
place client-side. This is because in the former cases conversion from
free-form human-readable strings into structured, binary log records takes
place on the server-side while for journal-native logging it happens on the
client side, and after conversion into binary records we probably shouldn't
alter the data anymore.

See: #3416

7 years agomkosi: make sure we fail on error
Lennart Poettering [Tue, 19 Jul 2016 10:30:34 +0000 (12:30 +0200)] 
mkosi: make sure we fail on error

7 years agokernel-install: recognize /boot/efi mountpoint (#3751)
Harald Hoyer [Tue, 19 Jul 2016 10:10:09 +0000 (12:10 +0200)] 
kernel-install: recognize /boot/efi mountpoint (#3751)

install everything in /boot/efi, if this is a mountpoint

7 years agoupdate 60-evdev to include rules for ASUS UX305 touchpad (#3698)
Atrotors [Tue, 19 Jul 2016 09:43:15 +0000 (19:43 +1000)] 
update 60-evdev to include rules for ASUS UX305 touchpad (#3698)

7 years agoMerge pull request #3749 from phomes/trivial-fixes3
Zbigniew Jędrzejewski-Szmek [Mon, 18 Jul 2016 23:03:08 +0000 (19:03 -0400)] 
Merge pull request #3749 from phomes/trivial-fixes3

Trivial fixes3

7 years agoresolved: replace bitwise and with logical and 3749/head
Thomas Hindoe Paaboel Andersen [Mon, 18 Jul 2016 20:42:09 +0000 (22:42 +0200)] 
resolved: replace bitwise and with logical and

7 years agotreewide: remove unused variables
Thomas Hindoe Paaboel Andersen [Mon, 18 Jul 2016 20:31:34 +0000 (22:31 +0200)] 
treewide: remove unused variables

7 years agobasic: fix whitespace
Thomas Hindoe Paaboel Andersen [Mon, 18 Jul 2016 20:14:23 +0000 (22:14 +0200)] 
basic: fix whitespace

7 years agonetwork: fix indentation
Thomas Hindoe Paaboel Andersen [Mon, 18 Jul 2016 20:09:57 +0000 (22:09 +0200)] 
network: fix indentation

7 years agosd-boot: Fix waiting for keyboard input (#3735)
Jan Janssen [Mon, 18 Jul 2016 19:19:32 +0000 (21:19 +0200)] 
sd-boot: Fix waiting for keyboard input (#3735)

WaitForKeyEx may never return on some UEFI systems depending
on firmware, hardware configuration and the phase of the moon.
Use ConIn->WaitForKey unconditionally instead.

Fixes #3632

7 years agohwdb: Update database of Bluetooth company identifiers
Marcel Holtmann [Mon, 18 Jul 2016 12:56:46 +0000 (14:56 +0200)] 
hwdb: Update database of Bluetooth company identifiers

7 years agonspawn: decrease mkdir error logging in /sys to debug priority (#3748)
tblume [Mon, 18 Jul 2016 10:23:08 +0000 (12:23 +0200)] 
nspawn: decrease mkdir error logging in /sys to debug priority (#3748)

Such mkdir errors happen for example when trying to mkdir /sys/fs/selinux.

/sys is documented to be readonly in the container, so mkdir errors below /sys
can be expected.
They shouldn't be logged as warnings since they lead users to think that
there is something wrong.

7 years agoMerge pull request #3745 from keszybz/fix-make-nulstr-confusion
Lennart Poettering [Mon, 18 Jul 2016 09:12:47 +0000 (11:12 +0200)] 
Merge pull request #3745 from keszybz/fix-make-nulstr-confusion

Fix make nulstr confusion

7 years agoMerge pull request #3746 from keszybz/trivial-fixes
Daniel Mack [Mon, 18 Jul 2016 07:54:06 +0000 (09:54 +0200)] 
Merge pull request #3746 from keszybz/trivial-fixes

Trivial fixes

7 years agoDrop parentheses in two places 3746/head
Zbigniew Jędrzejewski-Szmek [Tue, 28 Jun 2016 19:12:01 +0000 (15:12 -0400)] 
Drop parentheses in two places

7 years agosystemd-resolve: remove spurious newline with no global settings
Zbigniew Jędrzejewski-Szmek [Tue, 28 Jun 2016 17:55:58 +0000 (13:55 -0400)] 
systemd-resolve: remove spurious newline with no global settings

7 years agosystemd-resolve: use plural "DNS Servers"
Zbigniew Jędrzejewski-Szmek [Tue, 28 Jun 2016 17:51:30 +0000 (13:51 -0400)] 
systemd-resolve: use plural "DNS Servers"

Usually multiple DNS servers are configured, and it looks strange to have
singular in the heading.

7 years agobasic/strv: add an extra NUL after strings in strv_make_nulstr 3745/head
Zbigniew Jędrzejewski-Szmek [Sun, 17 Jul 2016 19:25:01 +0000 (15:25 -0400)] 
basic/strv: add an extra NUL after strings in strv_make_nulstr

strv_make_nulstr was creating a nulstr which was not a valid nulstr,
because it was missing the terminating NUL. This didn't cause any issues,
because strv_parse_nulstr correctly parsed the result, using the
separately specified length.

But it's confusing to have something called nulstr which really isn't.
It is likely that somebody will try to use strv_make_nulstr() in
some other place, incorrectly.

This patch changes strv_parse_nulstr() to produce a valid nulstr, and
changes the output length parameter to be the minimum number of bytes
which can be later on parsed by strv_parse_nulstr(). This allows the
only user in ask-password-api to be slightly simplified.

Based-on-patch-by: Jean-Sébastien Bour <jean-sebastien@bour.name>
Fixes #3689.

7 years agobasic/strv: exhibit strv_make_nulstr missing final NUL char (systemd/systemd#3689)
Jean-Sébastien Bour [Sat, 9 Jul 2016 00:38:00 +0000 (02:38 +0200)] 
basic/strv: exhibit strv_make_nulstr missing final NUL char (systemd/systemd#3689)

7 years agomanager: don't skip sigchld handler for main and control pid for services (#3738)
Lukáš Nykrýn [Sat, 16 Jul 2016 19:04:13 +0000 (21:04 +0200)] 
manager: don't skip sigchld handler for main and control pid for services (#3738)

During stop when service has one "regular" pid one main pid and one
control pid and the sighld for the regular one is processed first the
unit_tidy_watch_pids will skip the main and control pid and does not
remove them from u->pids(). But then we skip the sigchld event because we
already did one in the iteration and there are two pids in u->pids.

v2: Use general unit_main_pid() and unit_control_pid() instead of
reaching directly to service structure.

7 years agoman: mention system-shutdown hook directory in synopsis (#3741)
Michael Biebl [Sat, 16 Jul 2016 16:51:45 +0000 (18:51 +0200)] 
man: mention system-shutdown hook directory in synopsis (#3741)

The distinction between systemd-shutdown the binary vs system-shutdown
the hook directory (without the 'd') is not immediately obvious and can
be quite confusing if you are looking for a directory which doesn't exist.

Therefore explicitly mention the hook directory in the synopsis with a
trailing slash to make it clearer which is which.

7 years agoman: replace dash with mdash where appropriate
Zbigniew Jędrzejewski-Szmek [Sat, 16 Jul 2016 15:09:25 +0000 (11:09 -0400)] 
man: replace dash with mdash where appropriate

7 years agobuild-sys: add mkosi hookup (#3731)
Lennart Poettering [Sat, 16 Jul 2016 00:00:44 +0000 (02:00 +0200)] 
build-sys: add mkosi hookup (#3731)

This adds a build script and a settings file for "mkosi", a tool for putting
together full, bootable disk images for container managers of EFI systems and
VMs.

With these files it's enough to type "mkosi" in the project directory to
generate a bootable Fedora 24 OS image with a version of systemd compiled fresh
from the working tree.

See https://github.com/systemd/mkosi

7 years agonetworkd: fix for 3692 (#3699)
Susant Sahani [Fri, 15 Jul 2016 16:50:51 +0000 (22:20 +0530)] 
networkd: fix for 3692 (#3699)

We should look that the kind is invalid rather than pointer is NULL.

7 years agorules: UDEV_DISABLE_PERSISTENT_STORAGE_RULES_FLAG property (#3714)
Rusty Bird [Fri, 15 Jul 2016 16:47:42 +0000 (16:47 +0000)] 
rules: UDEV_DISABLE_PERSISTENT_STORAGE_RULES_FLAG property (#3714)

Sometimes, the persistent storage rules should be skipped for a subset
of devices. For example, the Qubes operating system prevents dom0 from
parsing untrusted block device content (such as filesystem metadata) by
shipping a custom 60-persistent-storage.rules, patched to bail out early
if the device name matches a hardcoded pattern.

As a less brittle and more flexible alternative, this commit adds a line
to the two relevant .rules files which makes them test the value of the
UDEV_DISABLE_PERSISTENT_STORAGE_RULES_FLAG device property, modeled
after the various DM_UDEV_DISABLE_*_RULES_FLAG properties.

7 years agotree-wide: get rid of selinux_context_t (#3732)
Zbigniew Jędrzejewski-Szmek [Fri, 15 Jul 2016 16:44:02 +0000 (12:44 -0400)] 
tree-wide: get rid of selinux_context_t (#3732)

https://github.com/SELinuxProject/selinux/commit/9eb9c9327563014ad6a807814e7975424642d5b9
deprecated selinux_context_t. Replace with a simple char* everywhere.

Alternative fix for #3719.

7 years agoudev: Line buffer 'udev monitor' output (#3733)
Stef Walter [Fri, 15 Jul 2016 10:24:34 +0000 (12:24 +0200)] 
udev: Line buffer 'udev monitor' output (#3733)

Callers of the 'udev monitor' tool expect to see output when
an event occurs. The stdio buffering defeats that. This patch
switches it to line buffering.

7 years agozsh-completion: fix option ordering in set-x11-keymap (#3646)
ntzrmtthihu777 [Fri, 15 Jul 2016 08:59:45 +0000 (03:59 -0500)] 
zsh-completion: fix option ordering in set-x11-keymap (#3646)

7 years agomacros: provide %_systemdgeneratordir and %_systemdusergeneratordir (#3672)
Zbigniew Jędrzejewski-Szmek [Fri, 15 Jul 2016 07:35:49 +0000 (03:35 -0400)] 
macros: provide %_systemdgeneratordir and %_systemdusergeneratordir (#3672)

... as requested in
https://lists.fedoraproject.org/archives/list/devel@lists.fedoraproject.org/message/DJ7HDNRM5JGBSA4HL3UWW5ZGLQDJ6Y7M/.
Adding the macro makes it marginally easier to create generators
for outside projects.

I opted for "generatordir" and "usergeneratordir" to match
%unitdir and %userunitdir. OTOH, "_systemd" prefix makes it obvious
that this is related to systemd. "%_generatordir" would be to generic
of a name.

7 years agonetwork-ndisc: avoid VLAs (#3725)
Daniel Mack [Fri, 15 Jul 2016 02:56:11 +0000 (04:56 +0200)] 
network-ndisc: avoid VLAs (#3725)

Do not allocate objects of dynamic and potentially large size on the stack
to avoid both clang compilation errors and unpredictable runtime behavior
on exotic platforms. Use the heap for that instead.

While at it, refactor the code a bit. Access 's->domain' via
NDISC_DNSSL_DOMAIN(), and refrain from allocating 'x' independently, but
rather reuse 's' if we're dealing with a new entry to the set.

Fixes #3717

7 years agocorrect information about implicit dependencies (#3730)
Michal Soltys [Fri, 15 Jul 2016 02:20:45 +0000 (04:20 +0200)] 
correct information about implicit dependencies (#3730)

systemd.special.xml: corrections about implicit
dependencies for basic.target, sysinit.target and shutdown.target.

systemd.target.xml: corrections about implicit dependencies for
target units in general.

7 years agoMerge pull request #3709 from poettering/journald-shutdown-sync
Zbigniew Jędrzejewski-Szmek [Fri, 15 Jul 2016 01:47:49 +0000 (21:47 -0400)] 
Merge pull request #3709 from poettering/journald-shutdown-sync

journald-related shutdown fixes for slow I/O

7 years agoFix tablet detection, by replicating decision tree of non-multi-touch axes (#3724)
Andreas Pokorny [Thu, 14 Jul 2016 20:42:10 +0000 (22:42 +0200)] 
Fix tablet detection, by replicating decision tree of non-multi-touch axes (#3724)

Signed-off-by: Andreas Pokorny <andreas.pokorny@canonical.com>
7 years agohwdb: add axis corrections for the Lenovo V360 touchpad (#3712)
Peter Hutterer [Thu, 14 Jul 2016 07:28:53 +0000 (17:28 +1000)] 
hwdb: add axis corrections for the Lenovo V360 touchpad (#3712)

https://bugs.freedesktop.org/show_bug.cgi?id=96875

7 years agobasic/mount-util: recognize ocfs2 as network fs (#3713)
Valentin Vidić [Thu, 14 Jul 2016 05:34:36 +0000 (07:34 +0200)] 
basic/mount-util: recognize ocfs2 as network fs (#3713)

7 years agoshutdown: already sync IO before we enter the final killing spree 3709/head
Lennart Poettering [Tue, 12 Jul 2016 15:26:52 +0000 (17:26 +0200)] 
shutdown: already sync IO before we enter the final killing spree

This way, slow IO journald has to wait for can't cause it to reach the killing
spree timeout and is hit by SIGKILL in addition to SIGTERM.

7 years agoshutdown: use 90s SIGKILL timeout
Lennart Poettering [Tue, 12 Jul 2016 15:18:43 +0000 (17:18 +0200)] 
shutdown: use 90s SIGKILL timeout

There's really no reason to use 10s here, let's instead default to 90s like we
do for everything else.

The SIGKILL during the final killing spree is in most regards the fourth level
of a safety net, after all: any normal service should have already been stopped
during the normal service shutdown logic, first via SIGTERM and then SIGKILL,
and then also via SIGTERM during the finall killing spree before we send
SIGKILL. And as a fourth level safety net it should only be required in
exceptional cases, which means it's safe to rais the default timeout, as normal
shutdowns should never be delayed by it.

Note that journald excludes itself from the normal service shutdown, and relies
on the final killing spree to terminate it (this is because it wants to cover
the normal shutdown phase's complete logging). If the system's IO is
excessively slow, then the 10s might not be enough for journald to sync
everything to disk and logs might get lost during shutdown.

7 years agoVarious fixes for typos found by lintian (#3705)
Michael Biebl [Tue, 12 Jul 2016 10:52:11 +0000 (12:52 +0200)] 
Various fixes for typos found by lintian (#3705)

7 years agoman: fix indefinite articles (#3694)
Jakub Wilk [Tue, 12 Jul 2016 09:58:14 +0000 (11:58 +0200)] 
man: fix indefinite articles (#3694)

7 years agoseccomp: only abort on syscall name resolution failures (#3701)
Luca Bruno [Tue, 12 Jul 2016 09:55:26 +0000 (11:55 +0200)] 
seccomp: only abort on syscall name resolution failures (#3701)

seccomp_syscall_resolve_name() can return a mix of positive and negative
(pseudo-) syscall numbers, while errors are signaled via __NR_SCMP_ERROR.
This commit lets the syscall filter parser only abort on real parsing
failures, letting libseccomp handle pseudo-syscall number on its own
and allowing proper multiplexed syscalls filtering.

7 years agoMerge pull request #3702 from torstehu/fix-typo
Michael Biebl [Tue, 12 Jul 2016 00:47:25 +0000 (02:47 +0200)] 
Merge pull request #3702 from torstehu/fix-typo

treewide: fix typos and remove accidental repetition of words

7 years agotreewide: fix typos and remove accidental repetition of words 3702/head
Torstein Husebø [Sun, 10 Jul 2016 12:48:23 +0000 (14:48 +0200)] 
treewide: fix typos and remove accidental repetition of words

7 years agoman: improve wording for calendar spec's repetition values (#3687) 3501/head
Ivan Shapovalov [Fri, 8 Jul 2016 19:08:07 +0000 (23:08 +0400)] 
man: improve wording for calendar spec's repetition values (#3687)

7 years agonspawn-completion: implementation of shell completion of --notify-ready (#3679)
Alessandro Puccetti [Fri, 8 Jul 2016 15:44:20 +0000 (17:44 +0200)] 
nspawn-completion: implementation of shell completion of --notify-ready (#3679)

Relative to: https://github.com/systemd/systemd/pull/3474

7 years agorules: block: add support for pmem devices (#3683)
bgbhpe [Fri, 8 Jul 2016 15:43:56 +0000 (11:43 -0400)] 
rules: block: add support for pmem devices (#3683)

Persistent memory devices can be exposed as block devices as /dev/pmemN
and /dev/pmemNs.  pmemN is the raw device and is byte-addressable from
within the kernel and when mmapped by applications from a DAX-mounted
file system.  pmemNs has the block translation table (BTT) layered on top,
offering atomic sector/block access.  Both pmemN and pmemNs are expected
to contain file systems.

blkid(8) and lsblk(8) seem to correctly report on pmemN and pmemNs.
systemd v219 will populate /dev/disk/by-uuid/ when, for example, mkfs is
used on pmem, but systemd v228 does not.

Add pmem to the whitelist.

7 years agoudevadm: explicitly relabel /etc/udev/hwdb.bin after rename (#3686)
Michal Sekletar [Fri, 8 Jul 2016 15:43:05 +0000 (17:43 +0200)] 
udevadm: explicitly relabel /etc/udev/hwdb.bin after rename (#3686)

This is basically the same change as ea68351.

7 years agoMerge pull request #3680 from joukewitteveen/pam-env
Evgeny Vereshchagin [Fri, 8 Jul 2016 14:33:12 +0000 (17:33 +0300)] 
Merge pull request #3680 from joukewitteveen/pam-env

Follow up on #3503 (pass service env vars to PAM sessions)

7 years agoexecute: Do not alter call-by-ref parameter on failure 3680/head
Jouke Witteveen [Thu, 7 Jul 2016 10:41:52 +0000 (12:41 +0200)] 
execute: Do not alter call-by-ref parameter on failure

Prevent free from being called on (a part of) the call-by-reference
variable env when setup_pam fails.

7 years agocore: queue loading transient units after setting their properties (#3676)
David Michael [Fri, 8 Jul 2016 03:43:01 +0000 (20:43 -0700)] 
core: queue loading transient units after setting their properties (#3676)

The unit load queue can be processed in the middle of setting the
unit's properties, so its load_state would no longer be UNIT_STUB
for the check in bus_unit_set_properties(), which would cause it to
incorrectly return an error.

7 years agocgroup: fix memory cgroup limit regression on kernel 3.10 (#3673)
Daniel Mack [Fri, 8 Jul 2016 02:29:35 +0000 (04:29 +0200)] 
cgroup: fix memory cgroup limit regression on kernel 3.10 (#3673)

Commit da4d897e ("core: add cgroup memory controller support on the unified
hierarchy (#3315)") changed the code in src/core/cgroup.c to always write
the real numeric value from the cgroup parameters to the
"memory.limit_in_bytes" attribute file.

For parameters set to CGROUP_LIMIT_MAX, this results in the string
"18446744073709551615" being written into that file, which is UINT64_MAX.
Before that commit, CGROUP_LIMIT_MAX was special-cased to the string "-1".

This causes a regression on CentOS 7, which is based on kernel 3.10, as the
value is interpreted as *signed* 64 bit, and clamped to 0:

[root@n54 ~]# echo 18446744073709551615 >/sys/fs/cgroup/memory/user.slice/memory.limit_in_bytes
[root@n54 ~]# cat /sys/fs/cgroup/memory/user.slice/memory.limit_in_bytes
0

[root@n54 ~]# echo -1 >/sys/fs/cgroup/memory/user.slice/memory.limit_in_bytes
[root@n54 ~]# cat /sys/fs/cgroup/memory/user.slice/memory.limit_in_bytes
9223372036854775807

Hence, all units that are subject to the limits enforced by the memory
controller will crash immediately, even though they have no actual limit
set. This happens to for the user.slice, for instance:

[  453.577153] Hardware name: SeaMicro SM15000-64-CC-AA-1Ox1/AMD Server CRB, BIOS Estoc.3.72.19.0018 08/19/2014
[  453.587024]  ffff880810c56780 00000000aae9501f ffff880813d7fcd0 ffffffff816360fc
[  453.594544]  ffff880813d7fd60 ffffffff8163109c ffff88080ffc5000 ffff880813d7fd28
[  453.602120]  ffffffff00000202 fffeefff00000000 0000000000000001 ffff880810c56c03
[  453.609680] Call Trace:
[  453.612156]  [<ffffffff816360fc>] dump_stack+0x19/0x1b
[  453.617324]  [<ffffffff8163109c>] dump_header+0x8e/0x214
[  453.622671]  [<ffffffff8116d20e>] oom_kill_process+0x24e/0x3b0
[  453.628559]  [<ffffffff81088dae>] ? has_capability_noaudit+0x1e/0x30
[  453.634969]  [<ffffffff811d4155>] mem_cgroup_oom_synchronize+0x575/0x5a0
[  453.641721]  [<ffffffff811d3520>] ? mem_cgroup_charge_common+0xc0/0xc0
[  453.648299]  [<ffffffff8116da84>] pagefault_out_of_memory+0x14/0x90
[  453.654621]  [<ffffffff8162f4cc>] mm_fault_error+0x68/0x12b
[  453.660233]  [<ffffffff81642012>] __do_page_fault+0x3e2/0x450
[  453.666017]  [<ffffffff816420a3>] do_page_fault+0x23/0x80
[  453.671467]  [<ffffffff8163e308>] page_fault+0x28/0x30
[  453.676656] Task in /user.slice/user-0.slice/user@0.service killed as a result of limit of /user.slice/user-0.slice/user@0.service
[  453.688477] memory: usage 0kB, limit 0kB, failcnt 7
[  453.693391] memory+swap: usage 0kB, limit 9007199254740991kB, failcnt 0
[  453.700039] kmem: usage 0kB, limit 9007199254740991kB, failcnt 0
[  453.706076] Memory cgroup stats for /user.slice/user-0.slice/user@0.service: cache:0KB rss:0KB rss_huge:0KB mapped_file:0KB swap:0KB inactive_anon:0KB active_anon:0KB inactive_file:0KB active_file:0KB unevictable:0KB
[  453.725702] [ pid ]   uid  tgid total_vm      rss nr_ptes swapents oom_score_adj name
[  453.733614] [ 2837]     0  2837    11950      899      23        0             0 (systemd)
[  453.741919] Memory cgroup out of memory: Kill process 2837 ((systemd)) score 1 or sacrifice child
[  453.750831] Killed process 2837 ((systemd)) total-vm:47800kB, anon-rss:3188kB, file-rss:408kB

Fix this issue by special-casing the UINT64_MAX case again.

7 years agoexecute: Cleanup the environment early
Jouke Witteveen [Thu, 7 Jul 2016 10:36:33 +0000 (12:36 +0200)] 
execute: Cleanup the environment early

By cleaning up before setting up PAM we maintain control of overriding
behavior in setting variables. Otherwise, pam_putenv is in control.
This also makes sure we use a cleaned up environment in replacing
variables in argv.

7 years agobasic: log: Increase static buffer for source file location (#3674)
Daniel Mack [Thu, 7 Jul 2016 04:30:34 +0000 (06:30 +0200)] 
basic: log: Increase static buffer for source file location (#3674)

Commit d054f0a4 ("tree-wide: use xsprintf() where applicable") used a
semantic patch approach to change a number of locations from

  snprintf(buf, sizeof(buf), FMT, ...)

to

  xsprintf(buf, FMT, ...)

The problem is that xsprintf() wraps the snprintf() in an
assert_message_se(), so if snprintf() reports an overflow of the
destination buffer, the binary will now terminate.

This hit a user running a version of systemd that was built from a
deeply nested system path.

Fix this by

a) Switching back to snprintf() for this particular case. We should really
rather truncate the location string than crash in such situations.

b) Increasing the size of that static string buffer, to make the event more
unlikely.

7 years agoman: networkd bonding remove 802.3ad from transmit hash policy (#3666)
Susant Sahani [Wed, 6 Jul 2016 05:42:03 +0000 (11:12 +0530)] 
man: networkd bonding remove 802.3ad from transmit hash policy (#3666)

The xmit_hash_policy does not have 802.3ad value. Remove this
from man.

7 years agohwdb: Update database of Bluetooth company identifiers
Marcel Holtmann [Tue, 5 Jul 2016 19:13:32 +0000 (21:13 +0200)] 
hwdb: Update database of Bluetooth company identifiers

7 years agoMerge pull request #3638 from whot/udev-prop-touchpad-integration
Lennart Poettering [Tue, 5 Jul 2016 17:25:59 +0000 (10:25 -0700)] 
Merge pull request #3638 from whot/udev-prop-touchpad-integration

tag touchpads as internal/external