Evgeny Vereshchagin [Fri, 14 Jun 2019 22:09:15 +0000 (00:09 +0200)]
travis: turn on UBSan on Fuzzit
Evgeny Vereshchagin [Fri, 14 Jun 2019 20:28:56 +0000 (23:28 +0300)]
Merge pull request #12799 from evverx/fuzzit-follow-up
travis: run Coverity after Fuzzit-Fuzzing
Evgeny Vereshchagin [Fri, 14 Jun 2019 19:47:31 +0000 (21:47 +0200)]
travis: add 5 more fuzz targets
Evgeny Vereshchagin [Fri, 14 Jun 2019 19:16:41 +0000 (21:16 +0200)]
travis: always run the "Build & test" stage first
Now that the other stages are explicitly listed in the "stages"
section, we should include "Built & test" there to make sure
it's run first.
Evgeny Vereshchagin [Fri, 14 Jun 2019 18:56:10 +0000 (20:56 +0200)]
travis: skip the Fuzzit-Sanity stage when it's run by cron
Evgeny Vereshchagin [Fri, 14 Jun 2019 18:42:19 +0000 (20:42 +0200)]
travis: run Coverity after Fuzzit-Fuzzing
Coverity is unpredictable and, according to a notification I received
yeserday, it will be upgraded on June 17. During the upgrade
it might be offline for 3 days, af far as I understand. Anyway, Travis
stops as soon as a stage fails so it makes sense to put stages that
are likely to fail at the end so that the others have a chance to
do what they are supposed to do.
https://community.synopsys.com/s/topic/0TO2H0000001CN7WAM/coverity-scan-status
Jeka Pats [Tue, 11 Jun 2019 06:25:45 +0000 (09:25 +0300)]
Continuous Fuzzing Integration with Fuzzit
includes two travis ci steps:
1) Every pull-request/push all fuzzing targets will do a quick
sanity run on the generated corpus and crashes (via Fuzzit)
2) On a daily basis the fuzzing targets will be compiled (from
master) and will and their respectible fuzzing job on Fuzzit
will be updated to the new binary.
Yu Watanabe [Fri, 14 Jun 2019 14:15:55 +0000 (23:15 +0900)]
NEWS: add more hint about MACAddressPolicy= change
C.f. https://bugzilla.suse.com/show_bug.cgi?id=1136600
Arian van Putten [Wed, 12 Jun 2019 17:18:04 +0000 (19:18 +0200)]
Document that gpt-auto-generator supports decrypting rootfs
When systemd is running in initrd, we actually support decrypting a LUKS rootfs.
Fixes #12786
Yu Watanabe [Thu, 13 Jun 2019 04:27:42 +0000 (13:27 +0900)]
networkctl: fix use of uninitialized value
Yu Watanabe [Wed, 12 Jun 2019 22:45:01 +0000 (07:45 +0900)]
Merge pull request #12777 from yuwata/libudev-enumerate-issue-12776
libudev: rescan devices when filter is updated
Frantisek Sumsal [Wed, 12 Jun 2019 17:52:48 +0000 (17:52 +0000)]
Merge pull request #12783 from keszybz/a-few-unrelated-fixes
A few unrelated fixes
Zbigniew Jędrzejewski-Szmek [Wed, 12 Jun 2019 15:24:22 +0000 (17:24 +0200)]
journal: also disable memory tricks when hashing under msan
Might help with #11738.
Zbigniew Jędrzejewski-Szmek [Wed, 12 Jun 2019 15:23:32 +0000 (17:23 +0200)]
test-bus-marshall: add a hopefully helpful comment
Zbigniew Jędrzejewski-Szmek [Tue, 11 Jun 2019 06:52:42 +0000 (08:52 +0200)]
zsh: add completion for systemctl preset-all
Zbigniew Jędrzejewski-Szmek [Fri, 7 Jun 2019 09:49:03 +0000 (11:49 +0200)]
system-update-generator: do not emit bogus warning if no /system-update symlink
We only need to check for the kernel cmdline override our symlink is there.
Yu Watanabe [Wed, 12 Jun 2019 06:15:06 +0000 (15:15 +0900)]
libudev: hide definition of struct udev_device
Yu Watanabe [Wed, 12 Jun 2019 02:10:52 +0000 (11:10 +0900)]
libudev: rescan devices when filter is updated
Fixes #12776.
Yu Watanabe [Wed, 12 Jun 2019 06:06:24 +0000 (15:06 +0900)]
libudev: re-implement libudev-list with LIST and hashmap
Yu Watanabe [Wed, 12 Jun 2019 04:03:19 +0000 (13:03 +0900)]
libudev: hide definition of struct udev_list from other libudev components
In the later commit, udev_list will be just a wrapper of hashmap or LIST.
So, allocating udev_list does not increase much cost.
Zbigniew Jędrzejewski-Szmek [Wed, 12 Jun 2019 12:28:09 +0000 (14:28 +0200)]
Merge pull request #12424 from poettering/logind-brightness
logind: add SetBrightness() bus call as minimal API for setting "leds" and "backlight" kernel class device brightness
Zbigniew Jędrzejewski-Szmek [Wed, 12 Jun 2019 12:20:32 +0000 (14:20 +0200)]
Merge pull request #12779 from pwithnall/minor-fixes
Minor fixes
Philip Withnall [Wed, 12 Jun 2019 07:24:45 +0000 (08:24 +0100)]
service: Fix typo in warning message
The directive is `RuntimeMaxSec=`, not `MaxRuntimeSec=`.
Signed-off-by: Philip Withnall <withnall@endlessm.com>
Philip Withnall [Wed, 12 Jun 2019 08:43:47 +0000 (09:43 +0100)]
pam_systemd: Fix some option names in error messages
Signed-off-by: Philip Withnall <withnall@endlessm.com>
Philip Withnall [Wed, 12 Jun 2019 08:08:53 +0000 (09:08 +0100)]
man: Add missing <literal> tags in various man pages
A minor formatting improvement brought to you by the wonders of `git
grep`.
Signed-off-by: Philip Withnall <withnall@endlessm.com>
Philip Withnall [Wed, 12 Jun 2019 07:03:35 +0000 (08:03 +0100)]
man: Fix typo in sd_notify man page
Signed-off-by: Philip Withnall <withnall@endlessm.com>
Yu Watanabe [Wed, 12 Jun 2019 03:30:05 +0000 (12:30 +0900)]
libudev: drop unused variable
Yu Watanabe [Wed, 12 Jun 2019 05:46:00 +0000 (14:46 +0900)]
Merge pull request #12774 from yuwata/network-ignore-ipv6-settings-when-sysctl-disable-ipv6
network: ignore ipv6 settings when sysctl disable ipv6
Tomas Mraz [Tue, 11 Jun 2019 13:10:21 +0000 (15:10 +0200)]
resolved: Fix incorrect use of OpenSSL BUF_MEM
Fixes: #12763
Yu Watanabe [Wed, 12 Jun 2019 02:01:32 +0000 (11:01 +0900)]
test-network: add more test cases when ipv6 is disabled
Yu Watanabe [Tue, 11 Jun 2019 14:33:22 +0000 (23:33 +0900)]
network: ignore requested ipv6 fdb entry when ipv6 is disabled by sysctl
Yu Watanabe [Tue, 11 Jun 2019 14:29:57 +0000 (23:29 +0900)]
network: ignore requested ipv6 routing policy rule when ipv6 is disabled by sysctl
Yu Watanabe [Tue, 11 Jun 2019 14:26:11 +0000 (23:26 +0900)]
network: ignore requested ipv6 route when ipv6 is disabled by sysctl
Yu Watanabe [Tue, 11 Jun 2019 14:20:56 +0000 (23:20 +0900)]
network: ignore requested ipv6 addresses when ipv6 is disabled by sysctl
Peter A. Bigot [Sun, 9 Jun 2019 17:15:09 +0000 (12:15 -0500)]
man: fix reference to sd_bus_add_fallback_vtable
Zbigniew Jędrzejewski-Szmek [Tue, 11 Jun 2019 07:52:26 +0000 (09:52 +0200)]
Merge pull request #12685 from yuwata/network-dhcp-assign-adn-remove-12676
network: assign new DHCP address before removing old lease address
Karel Zak [Mon, 10 Jun 2019 13:18:47 +0000 (15:18 +0200)]
systemd-mount: don't check for non-normalized WHAT for network FS
The WHAT string could be whatever for many filesystems. The common
example are network filesystems.
Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=1708996
Theo Ouzhinski [Sat, 8 Jun 2019 21:43:59 +0000 (17:43 -0400)]
man/systemd-veritysetup-generator: Fix grammar
Yu Watanabe [Fri, 7 Jun 2019 06:31:07 +0000 (15:31 +0900)]
network: assign new DHCP address before removing old lease address
Closes #12676.
Yu Watanabe [Fri, 7 Jun 2019 06:04:11 +0000 (15:04 +0900)]
network: ignore callback calls when link is in failed state
Yu Watanabe [Fri, 7 Jun 2019 05:28:09 +0000 (14:28 +0900)]
network: drop unnecessary link_enter_failed() calls
As the function called soon later anyway.
Yu Watanabe [Fri, 7 Jun 2019 05:22:13 +0000 (14:22 +0900)]
network: check earlier the existence of lifetime in lease
Yu Watanabe [Fri, 7 Jun 2019 05:18:55 +0000 (14:18 +0900)]
network: make all failures in route configuration fatal
Yu Watanabe [Fri, 7 Jun 2019 06:58:30 +0000 (15:58 +0900)]
Merge pull request #12756 from cdown/uninit
a couple of correctness fixups
Chris Down [Fri, 7 Jun 2019 05:28:10 +0000 (06:28 +0100)]
cgroup: Prevent theoretical nullptr deref in unit mask calculation
Chris Down [Fri, 7 Jun 2019 05:22:41 +0000 (06:22 +0100)]
systemctl: Prevent state_missing from being used uninit
Zbigniew Jędrzejewski-Szmek [Thu, 6 Jun 2019 16:53:20 +0000 (18:53 +0200)]
Merge pull request #12738 from yuwata/network-routing-policy-cleanup
network: several cleanups for routing policy rule
Zbigniew Jędrzejewski-Szmek [Thu, 6 Jun 2019 16:51:46 +0000 (18:51 +0200)]
Merge pull request #12511 from ssahani/high-avilability-12050
networkd: add new KeepConfiguration= setting
Yu Watanabe [Mon, 3 Jun 2019 04:21:13 +0000 (13:21 +0900)]
test-network: add tests for KeepConfiguration=
Yu Watanabe [Mon, 3 Jun 2019 06:37:25 +0000 (15:37 +0900)]
man: add documentation about KeepConfiguration
Yu Watanabe [Mon, 3 Jun 2019 03:33:13 +0000 (12:33 +0900)]
network: make KeepConfiguration=static drop DHCP addresses and routes
Also, KeepConfiguration=dhcp drops static foreign addresses and routes.
Yu Watanabe [Mon, 3 Jun 2019 17:05:26 +0000 (02:05 +0900)]
network: add KeepConfiguration=dhcp-on-stop
The option prevents to drop lease address on stop.
By setting this, we can safely restart networkd.
Susant Sahani [Mon, 3 Jun 2019 03:31:13 +0000 (12:31 +0900)]
networkd: add support to keep configuration
Yu Watanabe [Thu, 6 Jun 2019 13:23:09 +0000 (22:23 +0900)]
Merge pull request #12748 from keszybz/modernize-networkd-tests-style
Modernize networkd-tests.py style
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 08:41:46 +0000 (10:41 +0200)]
NEWS: add note about the CPUAffinity= changes
Yu Watanabe [Thu, 6 Jun 2019 12:31:19 +0000 (21:31 +0900)]
Merge pull request #12508 from keszybz/no-root-checks
Drop many root checks
Zbigniew Jędrzejewski-Szmek [Thu, 6 Jun 2019 12:08:01 +0000 (14:08 +0200)]
networkd-tests.py: properly escape pluses in regexps
Python warns that '\+' is an invalid escape. We need either '\\+' or r'\+'.
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 10:08:09 +0000 (12:08 +0200)]
networkd-tests.py: remove some java-style boilerplate
A class was used to put some utility functions under a namespace. But then this
namespace was inherited into classes, so the namespace split was undone. Let's
just define those functions in the module namespace.
(The Utilities class with a few functions still remain, because of the
unittest-style self.assert* craziness.)
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 10:03:01 +0000 (12:03 +0200)]
networkd-tests.py: use check_output() instead of unittests' assertEqual()
It's pretty much the same thing, but more in pytest style, without the
unittest boilerplate.
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 09:43:28 +0000 (11:43 +0200)]
networkd-tests.py: add helpers to common subprocess call patterns
For normal shell calls, python syntax is quite verbose. We don't need to punish
ourselves like that. In some places we would fork a shell to do argument splitting
for us. We know that our arguments can be safely split on whitespace, so let's do
that ourselves in all cases, without forking a shell.
We also expect command output to be valid text, so let's always set
universal_newlines=True.
This makes things shorter and easier to read. Development is also easier because
it's possible to paste many of the commands directly to/from a shell.
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 10:42:29 +0000 (12:42 +0200)]
networkd-tests.py: remove unused import
Yu Watanabe [Wed, 5 Jun 2019 15:42:05 +0000 (00:42 +0900)]
network: check stored object is euivalent to what we want to remove
When object A is stored in Manager::rules and B is in ::rules_foreign,
and compare function for the object cannot distinguish them,
then freeing A causes B to be removed from rules_foreign or vice versa.
Hopefully fixes #12731.
Michael Biebl [Wed, 5 Jun 2019 11:35:11 +0000 (13:35 +0200)]
Drop no longer needed halt-local.service.in
Follow-up for commit
44508946534eee032927c263b79464832656dd6e.
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 12:31:24 +0000 (14:31 +0200)]
Merge pull request #12744 from yuwata/test-network-stability-dhcp-tests
test-network: improve stability of DHCP client tests
Yu Watanabe [Tue, 4 Jun 2019 18:57:21 +0000 (03:57 +0900)]
test-network: do not directly compare two results of "ip address"
As it contains lifetime of the address.
Chris Down [Wed, 5 Jun 2019 09:02:00 +0000 (10:02 +0100)]
Merge pull request #11778 from anitazha/rfe_11654_dbus
core: add ExecStartXYZEx= with dbus support for executable prefixes
Yu Watanabe [Tue, 4 Jun 2019 18:09:20 +0000 (03:09 +0900)]
udev: propagate errors in udev_event_execute_rules()
And do not set initialized flag to the device.
Zbigniew Jędrzejewski-Szmek [Wed, 5 Jun 2019 07:54:54 +0000 (09:54 +0200)]
udevadm trigger: log errors and return first failure
When udevadm trigger is called, the list of devices to trigger is always
generated through enumeration, and devices can come and go, so we should not
treat -ENOENT as a failure. But other types of failure should be logged.
It seems they were logged until
baa30fbc2c04b23209d0b8fb3c86cd15ef9ea81a.
Also, return the first error. (I'm not sure if there are other failure modes
which we want to ignore. If they are, they'll need to be whitelisted like
-ENOENT.).
Yu Watanabe [Tue, 4 Jun 2019 18:55:32 +0000 (03:55 +0900)]
test-network: do not allow addresses in tentative state
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 11:44:46 +0000 (13:44 +0200)]
man: mention quoting in description of Parameters=
Also add a short example how to translate nspawn command line to .nspawn settings.
Fixes #12703.
Yu Watanabe [Tue, 4 Jun 2019 19:01:44 +0000 (04:01 +0900)]
Merge pull request #12741 from keszybz/bpf-firewall-warning
Silence BPF firewall warning when not useful
Yu Watanabe [Tue, 4 Jun 2019 17:45:39 +0000 (02:45 +0900)]
Merge pull request #12737 from keszybz/meson-man-nspawn
meson: escape dots in man/man helper
Yu Watanabe [Tue, 4 Jun 2019 15:46:29 +0000 (00:46 +0900)]
Merge pull request #12661 from mrc0mmand/debug-journalctl-flush
journal: disable varlink timeout for journalctl --flush or friends
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 15:33:59 +0000 (17:33 +0200)]
man/man: refer to the right build directory in the helpers
I have no idea how this one slipped through.
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 15:22:12 +0000 (17:22 +0200)]
Silence warning about BPF firewall in containers
We'd get a warning on every nspawn invocation:
dev-hugepages.mount: unit configures an IP firewall, but the local system does not support BPF/cgroup firewalling.
(This warning is only shown for the first unit using IP firewalling.)
Before the previous commit, I'd generally get a warning about systemd-udev.service, even though that service is
not started in containers. But are still many other units which that declare a
firewall, which is currently unsupported in containers. Let's stop warning
about this.
The warning is still emitted e.g. if legacy cgroups are used. This is something
that can be configured, so it makes more sense to emit the warning.
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 13:01:27 +0000 (15:01 +0200)]
Move warning about unsupported BPF firewall right before the firewall would be created
There's no need to warn about the firewall when parsing, because the unit might
not be started at all. Let's warn only when we're actually preparing to start
the firewall.
This changes behaviour:
- the warning is printed just once for all unit types, and not once
for normal units and once for transient units.
- on repeat warnings, the message is not printed at all. There's already
detailed debug info from bpf_firewall_compile(), so we don't need to repeat
ourselves.
- when we are not root, let's say precisely that, not "lack of necessary privileges"
and "the local system does not support BPF/cgroup firewalling".
Fixes #12673.
Yu Watanabe [Fri, 24 May 2019 13:32:08 +0000 (22:32 +0900)]
journalctl: make 'journalctl --flush' or friends not fail with varlink timeout
Closes #12570.
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 10:56:14 +0000 (12:56 +0200)]
meson: escape dots in man/man helper
It was impossible to view systemd.nspawn(5), because systemd-nspawn(1) was matched
also, and happened to be earlier in the list. The solution in this patch is pretty
crude, but is should be enough for our purposes, since we don't have any regexp
special characters in man page names except for the dot.
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 10:01:52 +0000 (12:01 +0200)]
Merge pull request #12733 from keszybz/sd-bus-error-reporting
Bus error reporting improvements
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 10:01:20 +0000 (12:01 +0200)]
Merge pull request #12734 from keszybz/cpu-set-util-on-i386
Fixes for test-cpu-set-util on i386
Yu Watanabe [Tue, 4 Jun 2019 08:13:07 +0000 (17:13 +0900)]
bash-completion: support "networkctl delete"
Yu Watanabe [Mon, 27 May 2019 20:17:27 +0000 (05:17 +0900)]
journalctl: mention --smart-relinquish-var in log message
Yu Watanabe [Fri, 24 May 2019 13:22:21 +0000 (22:22 +0900)]
journalctl: fix error cause in log message
If varlink_call() returns negative errno, then `error` is null.
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 07:40:38 +0000 (09:40 +0200)]
test-cpu-set-util: fix allocation size check on i386
We get just 28 bytes not 32 as on 64-bit architectures (__cpu_set_t is 4 bytes,
we need at least 26, so 28 satisfies the constraints).
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 07:19:04 +0000 (09:19 +0200)]
test-cpu-set-util: fix comparison for allocation size
On i386, __cpu_mask is 4 bytes, so we'd check if c.allocated >= 0, and
gcc would warn about a bogus comparison. Let's round up.
Fixes #12726.
Yu Watanabe [Tue, 4 Jun 2019 05:40:21 +0000 (14:40 +0900)]
network: remove unused argument in routing_policy_rule_configure()
Yu Watanabe [Tue, 4 Jun 2019 05:25:09 +0000 (14:25 +0900)]
network: fix double free on error path
Yu Watanabe [Mon, 3 Jun 2019 14:29:07 +0000 (23:29 +0900)]
network: fix UBSAN issue
Closes #12724.
Yu Watanabe [Tue, 4 Jun 2019 05:00:51 +0000 (14:00 +0900)]
networkctl: re-cast value stored in Set with INT_TO_PTR()
Zbigniew Jędrzejewski-Szmek [Tue, 4 Jun 2019 06:57:54 +0000 (08:57 +0200)]
shared/generator: voidify mkdir_parents() call
To appease coverity: CID#1401752.
Zbigniew Jędrzejewski-Szmek [Fri, 31 May 2019 14:21:56 +0000 (16:21 +0200)]
busctl: always prefix bus error message with local string
The message we get from the bus can be pretty bare-bones, and the user might be
confused which operation failed. Since we don't control the other side, let's
prefix the remote message with an informative prefix.
Zbigniew Jędrzejewski-Szmek [Fri, 31 May 2019 13:33:46 +0000 (15:33 +0200)]
sd-bus: improve bus error message for uknown properties
"Unknown interface or property." →
"Unknown interface org.freedesktop.network1.Link or property BitRates."
(I don't think the quotes are necessary. Dbus names have pretty strict rules.)
Zbigniew Jędrzejewski-Szmek [Fri, 31 May 2019 14:08:31 +0000 (16:08 +0200)]
networkctl: log quietly if we fail to get bit rates
If we query older networked, they will be missing. This is not an error.
Also, make the error more informative, because the bus error itself might
be just "Unknown interface or property" which is not enough to understand
what is going on.
Michal Sekletar [Mon, 3 Jun 2019 08:12:35 +0000 (10:12 +0200)]
cpu-set-util: use %d-%d format in cpu_set_to_range_string() only for actual ranges
Zbigniew Jędrzejewski-Szmek [Wed, 29 May 2019 14:08:47 +0000 (16:08 +0200)]
test-sleep: also print parsed modes and states
This allows the parser to be verified against on-disk config.
Yu Watanabe [Mon, 3 Jun 2019 18:58:47 +0000 (03:58 +0900)]
Merge pull request #12708 from yuwata/test-network-networkctl-tests
udevadm: add --wait-for-initialization option and use it in systemd-networkd-tests.py
Yu Watanabe [Sat, 1 Jun 2019 06:55:16 +0000 (15:55 +0900)]
test-network: disable SystemCallFilter= when *SAN is enabled
Yu Watanabe [Sat, 1 Jun 2019 06:44:04 +0000 (15:44 +0900)]
test-network: add test for MTU field of 'networkctl status'
Yu Watanabe [Fri, 31 May 2019 07:11:53 +0000 (16:11 +0900)]
test-network: add tests for "networkctl delete"
Yu Watanabe [Sat, 1 Jun 2019 01:29:08 +0000 (10:29 +0900)]
test-network: move networkctl related tests to NetworkctlTests class