]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
7 years agoresolved: add an option to control the DNS stub listener 4061/head
David Michael [Wed, 31 Aug 2016 22:34:29 +0000 (15:34 -0700)] 
resolved: add an option to control the DNS stub listener

7 years agoresolved: directly include some required headers instead of inheriting
David Michael [Wed, 31 Aug 2016 22:33:21 +0000 (15:33 -0700)] 
resolved: directly include some required headers instead of inheriting

7 years agoresolved: remove unused prototype
David Michael [Wed, 31 Aug 2016 18:57:52 +0000 (11:57 -0700)] 
resolved: remove unused prototype

7 years agoinstall: fix disable when /etc/systemd/system is a symlink (#4063)
Lennart Poettering [Wed, 31 Aug 2016 11:02:02 +0000 (13:02 +0200)] 
install: fix disable when /etc/systemd/system is a symlink (#4063)

7 years agonetworkd: do not drop config for unmanaged interfaces (#4033)
Lennart Poettering [Wed, 31 Aug 2016 10:36:55 +0000 (12:36 +0200)] 
networkd: do not drop config for unmanaged interfaces (#4033)

Flushing foreign configuration for unmanaged interfaces is outright
evil, especially when it's a regular occurence with Wi-Fi.

Fixes: 3104883ddc24 "networkd: remove route if carrier is lost"
Ref: #3831

7 years agohwdb: 60-keyboard: remove line causing a syntax error (#3999)
Lennart Poettering [Wed, 31 Aug 2016 10:29:51 +0000 (12:29 +0200)] 
hwdb: 60-keyboard: remove line causing a syntax error (#3999)

7 years agocore: introduce MemorySwapMax= (#3659)
Lennart Poettering [Wed, 31 Aug 2016 10:28:54 +0000 (12:28 +0200)] 
core: introduce MemorySwapMax= (#3659)

Similar to MemoryMax=, MemorySwapMax= limits swap usage. This controls
controls "memory.swap.max" attribute in unified cgroup.

7 years agolink : add support to configure LRO and GRO Offload features (#4064)
Lennart Poettering [Wed, 31 Aug 2016 10:13:08 +0000 (12:13 +0200)] 
link : add support to configure LRO and GRO Offload features (#4064)

The patch supports to configure

GenericReceiveOffload
LargeReceiveOffload

7 years agoload-fragment: Resolve specifiers in OnCalendar and On*Sec (#4045)
Lennart Poettering [Wed, 31 Aug 2016 10:07:39 +0000 (12:07 +0200)] 
load-fragment: Resolve specifiers in OnCalendar and On*Sec (#4045)

Resolves #3534

7 years agolink : add support to configure LRO and GRO Offload features 4064/head
Susant Sahani [Wed, 31 Aug 2016 07:17:02 +0000 (12:47 +0530)] 
link : add support to configure LRO and GRO Offload features

The patch supports to configure

GenericReceiveOffload
LargeReceiveOffload

7 years agolink : add support to configure Offload features (#4017)
Susant Sahani [Tue, 30 Aug 2016 14:52:04 +0000 (20:22 +0530)] 
link : add support to configure Offload features (#4017)

This patch supports these features to be on or off

Generic Segmentation Offload
TCP Segmentation Offload
UDP Segmentation Offload

fixes #432

7 years agobootctl: properly skip duplicate entries (#4048)
Mantas Mikulėnas [Tue, 30 Aug 2016 14:50:19 +0000 (17:50 +0300)] 
bootctl: properly skip duplicate entries (#4048)

'continue' is a fancy no-op here – it only skips through the inner loop,
not the outer one, so entries already in BootOrder get printed twice.

This partially reverts f939cff71577 "bootctl: various coding style
updates".

7 years agoMerge pull request #4053 from brulon/force-unmount
Lennart Poettering [Tue, 30 Aug 2016 14:44:51 +0000 (16:44 +0200)] 
Merge pull request #4053 from brulon/force-unmount

add ForceUnmount= setting for mount units

7 years agoinstall: fix disable when /etc/systemd/system is a symlink 4063/head
Lukas Nykryn [Tue, 30 Aug 2016 13:04:07 +0000 (15:04 +0200)] 
install: fix disable when /etc/systemd/system is a symlink

7 years agoMerge pull request #4052 from yann-morin-1998/yem/o-tmpfile
Lennart Poettering [Tue, 30 Aug 2016 07:47:25 +0000 (09:47 +0200)] 
Merge pull request #4052 from yann-morin-1998/yem/o-tmpfile

importd: fix build failure with missing O_TMPFILE (branch yem/o-tmpfile)

7 years agoMerge pull request #4054 from yuwata/man-fix
Martin Pitt [Tue, 30 Aug 2016 04:27:04 +0000 (06:27 +0200)] 
Merge pull request #4054 from yuwata/man-fix

man page fixes

7 years agocore: introduce MemorySwapMax= 3659/head
WaLyong Cho [Mon, 4 Jul 2016 07:03:54 +0000 (07:03 +0000)] 
core: introduce MemorySwapMax=

Similar to MemoryMax=, MemorySwapMax= limits swap usage. This controls
controls "memory.swap.max" attribute in unified cgroup.

7 years agobasic/fileio: we always have O_TMPFILE now 4052/head
Yann E. MORIN [Mon, 29 Aug 2016 10:34:50 +0000 (12:34 +0200)] 
basic/fileio: we always have O_TMPFILE now

fileio makes use of O_TMPFILE when it is available.

We now always have O_TMPFILE, defined in missing.h if missing
from the toolchain headers.

Have fileio include missing.h and drop the guards around the
use of O_TMPFILE.

7 years agomissing.h: add missing definitions for __O_TMPFILE
Yann E. MORIN [Sun, 28 Aug 2016 15:26:42 +0000 (17:26 +0200)] 
missing.h: add missing definitions for __O_TMPFILE

Currently, a missing __O_TMPFILE was only defined for i386 and x86_64,
leaving any other architectures with an "old" toolchain fail miserably
at build time:
    src/import/export-raw.c: In function 'reflink_snapshot':
    src/import/export-raw.c:271:26: error: 'O_TMPFILE' undeclared (first use in this function)
             new_fd = open(d, O_TMPFILE|O_CLOEXEC|O_NOCTTY|O_RDWR, 0600);
                              ^

__O_TMPFILE (and O_TMPFILE) are available since glibc 2.19. However, a
lot of existing toolchains are still using glibc-2.18, and some even
before that, and it is not really possible to update those toolchains.

Instead of defining it only for i386 and x86_64, define __O_TMPFILE
with the specific values for those archs where it is different from the
generic value. Use the values as found in the Linux kernel (v4.8-rc3,
current as of time of commit).

---
Note: tested on ARM (build+run), with glibc-2.18 and linux headers 3.12.
Untested on other archs, though (I have no board to test this).

Changes v1 -> v2:
  - add a comment specifying some are hexa, others are octal.

7 years agoimportd/export-raw: needs missing.h for O_TMPFILE
Yann E. MORIN [Sun, 28 Aug 2016 14:26:04 +0000 (16:26 +0200)] 
importd/export-raw: needs missing.h for O_TMPFILE

O_TMPFILE may be missing from the system headers, so use our fallback
definition.

---
Changes v1 -> v2:
  - move include with local includes

7 years agoman: systemd-journal-remote: do not use ulink tags for example addresses 4054/head
Yu Watanabe [Mon, 29 Aug 2016 06:59:18 +0000 (15:59 +0900)] 
man: systemd-journal-remote: do not use ulink tags for example addresses

Applying ulink tags to example addresses adds meaningless references in NOTES section of the man page.

7 years agoman: systemd.mount: DefaultTimeoutStart -> DefaultTimeoutStartSec
Yu Watanabe [Mon, 29 Aug 2016 02:02:36 +0000 (11:02 +0900)] 
man: systemd.mount: DefaultTimeoutStart -> DefaultTimeoutStartSec

7 years agoMerge pull request #4046 from pilophae/ideapad500isk
Peter Hutterer [Mon, 29 Aug 2016 01:37:01 +0000 (11:37 +1000)] 
Merge pull request #4046 from pilophae/ideapad500isk

hwdb: add axis range corrections for Lenovo Ideapad 500S-13ISK

7 years agohwdb: 60-keyboard: remove line causing a syntax error 3999/head
Mantas Mikulėnas [Fri, 19 Aug 2016 18:33:28 +0000 (21:33 +0300)] 
hwdb: 60-keyboard: remove line causing a syntax error

7 years agomount: add SloppyOptions= to mount_dump() 4053/head
Barron Rulon [Sat, 27 Aug 2016 14:42:05 +0000 (10:42 -0400)] 
mount: add SloppyOptions= to mount_dump()

7 years agomount: add new ForceUnmount= setting for mount units, mapping to umount(8)'s "-f...
Barron Rulon [Sat, 27 Aug 2016 14:27:49 +0000 (10:27 -0400)] 
mount: add new ForceUnmount= setting for mount units, mapping to umount(8)'s "-f" switch

7 years agohwdb: add axis range corrections for Lenovo Ideapad 500S-13ISK 4046/head
Erik Karlsson [Wed, 24 Aug 2016 18:18:22 +0000 (20:18 +0200)] 
hwdb: add axis range corrections for Lenovo Ideapad 500S-13ISK

7 years agoload-fragment: Resolve specifiers in OnCalendar and On*Sec 4045/head
Douglas Christman [Fri, 26 Aug 2016 16:13:16 +0000 (12:13 -0400)] 
load-fragment: Resolve specifiers in OnCalendar and On*Sec

Resolves #3534

7 years agomount: add new LazyUnmount= setting for mount units, mapping to umount(8)'s "-l"...
brulon [Fri, 26 Aug 2016 15:57:22 +0000 (11:57 -0400)] 
mount: add new LazyUnmount= setting for mount units, mapping to umount(8)'s "-l" switch (#3827)

7 years agojournal: add/use flushed_flag_is_set() helper (#4041)
Vito Caputo [Fri, 26 Aug 2016 15:51:13 +0000 (08:51 -0700)] 
journal: add/use flushed_flag_is_set() helper (#4041)

Minor cleanup suggested by Lennart.

7 years agotests: mount proc before `exec valgrind` (#4044)
Evgeny Vereshchagin [Fri, 26 Aug 2016 15:49:56 +0000 (18:49 +0300)] 
tests: mount proc before `exec valgrind` (#4044)

Fixes:
$ sudo make run QEMU_BIN=/usr/bin/qemu-system-x86_64  KERNEL_APPEND=systemd.unit=multi-user.target SKIP_INITRD=yes
TEST RUN: Basic systemd setup
+ /usr/bin/qemu-system-x86_64 -smp 1 -net none -m 512M -nographic -kernel /boot/vmlinuz-4.6.7-200.fc23.x86_64 -drive format=raw,cache=unsafe,file=/var/tmp/systemd-test.izx99J/rootdisk.img -append 'root=/dev/sda1 raid=noautodetect loglevel=2 init=/usr/lib/systemd/systemd-under-valgrind rw console=ttyS0 selinux=0 systemd.unified_cgroup_hierarchy=no systemd.unit=multi-user.target '
valgrind: warning (non-fatal): readlink("/proc/self/exe") failed.
valgrind: continuing, however --trace-children=yes will not work.
--1:0: aspacem Valgrind: FATAL: can't open /proc/self/maps
--1:0: aspacem Exiting now.
[    3.152367] Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000100
[    3.152367]
[    3.152367] CPU: 0 PID: 1 Comm: memcheck-amd64- Not tainted 4.6.7-200.fc23.x86_64 #1
[    3.152367] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.8.2-20150714_191134- 04/01/2014
[    3.152367]  0000000000000086 0000000047ca1666 ffff88001ea43e00 ffffffff813d954e
[    3.152367]  ffffffff81a205a0 ffff88001ea43e98 ffff88001ea43e88 ffffffff811b5557
[    3.152367]  ffffffff00000010 ffff88001ea43e98 ffff88001ea43e30 0000000047ca1666
[    3.152367] Call Trace:
[    3.152367]  [<ffffffff813d954e>] dump_stack+0x63/0x85
[    3.152367]  [<ffffffff811b5557>] panic+0xde/0x220
[    3.152367]  [<ffffffff810ab9c3>] do_exit+0xb43/0xb50
[    3.152367]  [<ffffffff810aba57>] do_group_exit+0x47/0xb0
[    3.152367]  [<ffffffff810abad4>] SyS_exit_group+0x14/0x20
[    3.152367]  [<ffffffff817dae72>] entry_SYSCALL_64_fastpath+0x1a/0xa4
[    3.152367] Kernel Offset: disabled
[    3.152367] ---[ end Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000100
[    3.152367]
QEMU: Terminated

7 years agoMerge pull request #3984 from poettering/refcnt
Evgeny Vereshchagin [Fri, 26 Aug 2016 13:17:05 +0000 (16:17 +0300)] 
Merge pull request #3984 from poettering/refcnt

permit bus clients to pin units to avoid automatic GC

7 years agonspawn: split down SYSTEMD_NSPAWN_SHARE_SYSTEM (#4023)
Luca Bruno [Thu, 25 Aug 2016 22:08:26 +0000 (22:08 +0000)] 
nspawn: split down SYSTEMD_NSPAWN_SHARE_SYSTEM (#4023)

This commit follows further on the deprecation path for --share-system,
by splitting and gating each share-able namespace behind its own
environment flag.

7 years agounits: remove udev control socket when systemd stops the socket unit (#4039)
Michal Sekletar [Thu, 25 Aug 2016 22:07:58 +0000 (00:07 +0200)] 
units: remove udev control socket when systemd stops the socket unit (#4039)

Mere presence of the socket in the filesystem makes
udev_queue_get_udev_is_active() return that udev is running. Note that,
udev on exit doesn't unlink control socket nor does systemd. Thus socket
stays around even when both daemon and socket are stopped. This causes
problems for cryptsetup because when it detects running udev it launches
synchronous operations that *really* require udev. This in turn may
cause blocking and subsequent timeout in systemd-cryptsetup on reboot
while machine is in a state that udev and its control socket units are
stopped, e.g. emergency mode.

Fixes #2477

7 years agojournal: implicitly flush to var on recovery (#4028)
Vito Caputo [Thu, 25 Aug 2016 15:37:57 +0000 (08:37 -0700)] 
journal: implicitly flush to var on recovery (#4028)

When the system journal becomes re-opened post-flush with the runtime
journal open, it implies we've recovered from something like an ENOSPC
situation where the system journal rotate had failed, leaving the system
journal closed, causing the runtime journal to be opened post-flush.

For the duration of the unavailable system journal, we log to the
runtime journal.  But when the system journal gets opened (space made
available, for example), we need to close the runtime journal before new
journal writes will go to the system journal.  Calling
server_flush_to_var() after opening the system journal with a runtime
journal present, post-flush, achieves this while preserving the runtime
journal's contents in the system journal.

The combination of the present flushed flag file and the runtime journal
being open is a state where we should be logging to the system journal,
so it's appropriate to resume doing so once we've successfully opened
the system journal.

7 years agonetworkd: do not drop config for unmanaged interfaces 4033/head
Mantas Mikulėnas [Wed, 24 Aug 2016 15:26:48 +0000 (18:26 +0300)] 
networkd: do not drop config for unmanaged interfaces

Flushing foreign configuration for unmanaged interfaces is outright
evil, especially when it's a regular occurence with Wi-Fi.

Fixes: 3104883ddc24 "networkd: remove route if carrier is lost"
Ref: #3831

7 years agoudev: inform systemd how many workers we can potentially spawn (#4036)
Michal Sekletar [Thu, 25 Aug 2016 06:18:42 +0000 (08:18 +0200)] 
udev: inform systemd how many workers we can potentially spawn (#4036)

7 years agodocs: add --with-support-url= to distribution porting guide. (#4035)
Stefan [Wed, 24 Aug 2016 18:49:53 +0000 (20:49 +0200)] 
docs: add --with-support-url= to distribution porting guide. (#4035)

7 years agorun: respect quiet when starting timer (#4029)
Nick Owens [Wed, 24 Aug 2016 10:12:18 +0000 (03:12 -0700)] 
run: respect quiet when starting timer (#4029)

7 years agohwdb: add axis ranges for the MacBook 4,1 (#4030)
Peter Hutterer [Wed, 24 Aug 2016 10:11:48 +0000 (20:11 +1000)] 
hwdb: add axis ranges for the MacBook 4,1 (#4030)

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

7 years agoUpdated Hungarian translation (#4026)
Balázs Úr [Tue, 23 Aug 2016 18:08:35 +0000 (20:08 +0200)] 
Updated Hungarian translation (#4026)

7 years agocore,network: Use const qualifiers for block-local variables in macro functions ...
Felipe Sateler [Tue, 23 Aug 2016 09:29:30 +0000 (06:29 -0300)] 
core,network: Use const qualifiers for block-local variables in macro functions (#4019)

Prevents discard-qualifiers warnings when the passed variable was const

7 years agocore: do not fail at step SECCOMP if there is no kernel support (#4004)
Felipe Sateler [Mon, 22 Aug 2016 19:40:58 +0000 (16:40 -0300)] 
core: do not fail at step SECCOMP if there is no kernel support (#4004)

Fixes #3882

7 years agobus-util: turn on exit-on-disconnect for all command line tools 3984/head
Lennart Poettering [Mon, 22 Aug 2016 15:21:27 +0000 (17:21 +0200)] 
bus-util: turn on exit-on-disconnect for all command line tools

bus_connect_transport() is exclusively used from our command line tools, hence
let's set exit-on-disconnect for all of them, making behaviour a bit nicer in
case dbus-daemon goes down.

7 years agosd-bus: optionally, exit process or event loop on disconnect
Lennart Poettering [Mon, 22 Aug 2016 15:19:12 +0000 (17:19 +0200)] 
sd-bus: optionally, exit process or event loop on disconnect

Old libdbus has a feature that the process is terminated whenever the the bus
connection receives a disconnect. This is pretty useful on desktop apps (where
a disconnect indicates session termination), as well as on command line apps
(where we really shouldn't stay hanging in most cases if dbus daemon goes
down).

Add a similar feature to sd-bus, but make it opt-in rather than opt-out, like
it is on libdbus. Also, if the bus is attached to an event loop just exit the
event loop rather than the the whole process.

7 years agoupdate TODO
Lennart Poettering [Mon, 15 Aug 2016 12:48:14 +0000 (14:48 +0200)] 
update TODO

7 years agosd-bus: add a small test case for sd_bus_track
Lennart Poettering [Mon, 22 Aug 2016 14:13:19 +0000 (16:13 +0200)] 
sd-bus: add a small test case for sd_bus_track

This tests in particular that disconnecting results in the tracking object's
handlers to be called.

7 years agosd-bus: when the server-side disconnects, make sure to dispatch all tracking objects...
Lennart Poettering [Mon, 22 Aug 2016 14:11:54 +0000 (16:11 +0200)] 
sd-bus: when the server-side disconnects, make sure to dispatch all tracking objects immediately

If the server side kicks us from the bus, from our view no names are on the bus
anymore, hence let's make sure to dispatch all tracking objects immediately.

7 years agosd-bus: ensure we don't dispatch track objects while we are adding names to them
Lennart Poettering [Mon, 22 Aug 2016 14:09:15 +0000 (16:09 +0200)] 
sd-bus: ensure we don't dispatch track objects while we are adding names to them

In order to add a name to a bus tracking object we need to do some bus
operations: we need to check if the name already exists and add match for it.
Both are synchronous bus calls. While processing those we need to make sure
that the tracking object is not dispatched yet, as it might still be empty, but
is not going to be empty for very long.

hence, block dispatching by removing the object from the dispatch queue while
adding it, and readding it on error.

7 years agosd-bus: split out handling of reply callbacks on close into its own function
Lennart Poettering [Mon, 22 Aug 2016 12:45:34 +0000 (14:45 +0200)] 
sd-bus: split out handling of reply callbacks on close into its own function

When a bus connection is closed we dispatch all reply callbacks. Do so in a new
function if its own.

No behaviour changes.

7 years agocore: let's use set_contains() where appropriate
Lennart Poettering [Fri, 19 Aug 2016 17:30:06 +0000 (19:30 +0200)] 
core: let's use set_contains() where appropriate

7 years agoman: document the new --wait switch of systemd-run
Lennart Poettering [Thu, 18 Aug 2016 19:53:38 +0000 (21:53 +0200)] 
man: document the new --wait switch of systemd-run

Also, make major improvements to the an page in general.

7 years agorun: optionally, wait for the service to finish and show its result
Lennart Poettering [Wed, 17 Aug 2016 12:24:17 +0000 (14:24 +0200)] 
run: optionally, wait for the service to finish and show its result

7 years agocore: cache last CPU usage counter, before destorying a cgroup
Lennart Poettering [Thu, 18 Aug 2016 18:58:10 +0000 (20:58 +0200)] 
core: cache last CPU usage counter, before destorying a cgroup

It is useful for clients to be able to read the last CPU usage counter value of
a unit even if the unit is already terminated. Hence, before destroying a
cgroup's cgroup cache the last CPU usage counter and return it if the cgroup is
gone.

7 years agobus-util: make sure map_basic() returns EOPNOTSUPP if called for an unknown type
Lennart Poettering [Wed, 17 Aug 2016 17:04:35 +0000 (19:04 +0200)] 
bus-util: make sure map_basic() returns EOPNOTSUPP if called for an unknown type

Make sure we return proper errors for types not understood yet.

7 years agobus-util: treat an empty string as a NULL
Lennart Poettering [Wed, 17 Aug 2016 17:03:44 +0000 (19:03 +0200)] 
bus-util: treat an empty string as a NULL

Instead of ignoring empty strings retrieved via the bus, treat them as NULL, as
it's customary in systemd.

7 years agobus-util: support mapping signed integers with bus_map_properties()
Lennart Poettering [Wed, 17 Aug 2016 17:00:12 +0000 (19:00 +0200)] 
bus-util: support mapping signed integers with bus_map_properties()

Let's make sure we can read the exit code/status properties exposed by PID 1
properly. Let's reuse the existing code for unsigned fields, as we just use it
to copy words around, and don't calculate it.

7 years agocore: add Ref()/Unref() bus calls for units
Lennart Poettering [Mon, 15 Aug 2016 16:12:01 +0000 (18:12 +0200)] 
core: add Ref()/Unref() bus calls for units

This adds two (privileged) bus calls Ref() and Unref() to the Unit interface.
The two calls may be used by clients to pin a unit into memory, so that various
runtime properties aren't flushed out by the automatic GC. This is necessary
to permit clients to race-freely acquire runtime results (such as process exit
status/code or accumulated CPU time) on successful service termination.

Ref() and Unref() are fully recursive, hence act like the usual reference
counting concept in C. Taking a reference is a privileged operation, as this
allows pinning units into memory which consumes resources.

Transient units may also gain a reference at the time of creation, via the new
AddRef property (that is only defined for transient units at the time of
creation).

7 years agoman: document sd_bus_track objects
Lennart Poettering [Mon, 15 Aug 2016 12:59:59 +0000 (14:59 +0200)] 
man: document sd_bus_track objects

And while ware at it, also drop some references to kdbus, and stop claiming
sd-bus wasn't stable yet. Also order man page references in the main sd-bus man
page alphabetically.

7 years agosd-bus: add a "recursive" mode to sd_bus_track
Lennart Poettering [Mon, 15 Aug 2016 12:58:09 +0000 (14:58 +0200)] 
sd-bus: add a "recursive" mode to sd_bus_track

This adds an optional "recursive" counting mode to sd_bus_track. If enabled
adding the same name multiple times to an sd_bus_track object is counted
individually, so that it also has to be removed the same number of times before
it is gone again from the tracking object.

This functionality is useful for implementing local ref counted objects that
peers make take references on.

7 years agoman: don't claim arguments where const that actually are not
Lennart Poettering [Mon, 15 Aug 2016 12:57:29 +0000 (14:57 +0200)] 
man: don't claim arguments where const that actually are not

7 years agoseccomp: make sure getrlimit() is among the default permitted syscalls
Lennart Poettering [Wed, 17 Aug 2016 15:53:25 +0000 (17:53 +0200)] 
seccomp: make sure getrlimit() is among the default permitted syscalls

A lot of basic code wants to know the stack size, and it is safe if they do,
hence let's permit getrlimit() (but not setrlimit()) by default.

See: #3970

7 years agomount-tool: return 0 instead of NULL in the acquire_description() (#4009)
0xAX [Mon, 22 Aug 2016 06:14:23 +0000 (09:14 +0300)] 
mount-tool: return 0 instead of NULL in the acquire_description() (#4009)

to prevent:

src/mount/mount-tool.c: In function ‘acquire_description’:
src/mount/mount-tool.c:728:24: warning: return makes integer from pointer without a cast [-Wint-conversion]
                 return NULL;
                                         ^~~~
warning.

Additionally we don't set Description property in a case when
arg_description is NULL.

7 years agohwdb: provide axis ranges for the Dell XPS M1530 (#4016)
Peter Hutterer [Sun, 21 Aug 2016 23:31:25 +0000 (09:31 +1000)] 
hwdb: provide axis ranges for the Dell XPS M1530 (#4016)

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

7 years agonetworkd: fix typo (#4013)
Zbigniew Jędrzejewski-Szmek [Sun, 21 Aug 2016 17:15:26 +0000 (13:15 -0400)] 
networkd: fix typo (#4013)

7 years agoshared/install: do not enable masked instances (#4005)
Zbigniew Jędrzejewski-Szmek [Sun, 21 Aug 2016 13:10:51 +0000 (09:10 -0400)] 
shared/install: do not enable masked instances (#4005)

When told to enable a template unit, and the DefaultInstance specified in that
unit was masked, we would do this. Such a unit cannot be started or loaded, so
reporting successful enabling is misleading and unexpected.

$ systemctl mask getty@tty1
Created symlink /etc/systemd/system/getty@tty1.service → /dev/null.
$ systemctl --root=/ enable getty@tty1
(unchanged)
Failed to enable unit, unit /etc/systemd/system/getty@tty1.service is masked.

$ systemctl --root=/ enable getty@
(before)
Created symlink /etc/systemd/system/getty.target.wants/getty@tty1.service → /usr/lib/systemd/system/getty@.service.
(now)
Failed to enable unit, unit /etc/systemd/system/getty@tty1.service is masked.

The same error is emitted for enable and preset. And an error is emmited, not a
warning, so the failure to enable DefaultInstance is treated the same as if the
instance was specified on the command line. I think that this makes most sense,
for most template units.

Fixes #2513.

7 years agonetworkd: limit the number of routes to the kernel limit (#4007)
Zbigniew Jędrzejewski-Szmek [Sun, 21 Aug 2016 13:06:28 +0000 (09:06 -0400)] 
networkd: limit the number of routes to the kernel limit (#4007)

Fixes #3922.

7 years agomachinectl: print OS release in `machinectl list` (#3975)
Seraphime [Sun, 21 Aug 2016 03:39:07 +0000 (05:39 +0200)] 
machinectl: print OS release in `machinectl list` (#3975)

7 years agoMerge pull request #4001 from clintonroy/master
Ronny Chevalier [Sat, 20 Aug 2016 09:42:24 +0000 (11:42 +0200)] 
Merge pull request #4001 from clintonroy/master

systemctl: kill all units specified on the command line, not just the…

7 years agoMerge pull request #3965 from htejun/systemd-controller-on-unified
Zbigniew Jędrzejewski-Szmek [Fri, 19 Aug 2016 23:00:25 +0000 (19:00 -0400)] 
Merge pull request #3965 from htejun/systemd-controller-on-unified

7 years agosystemctl: kill all units specified on the command line, not just the first one. 4001/head
Clinton Roy [Fri, 19 Aug 2016 22:59:02 +0000 (08:59 +1000)] 
systemctl: kill all units specified on the command line, not just the first one.

7 years agoterminal-util: remove unnecessary check of result of isatty() (#4000)
0xAX [Fri, 19 Aug 2016 22:51:54 +0000 (01:51 +0300)] 
terminal-util: remove unnecessary check of result of isatty() (#4000)

After the call of the isatty() we check its result twice in the
open_terminal(). There are no sense to check result of isatty() that
it is less than zero and return -errno, because as described in
documentation:

isatty() returns 1 if fd is an open file descriptor referring to a
terminal;  otherwise 0 is returned, and errno is set to indicate the
error.

So it can't be less than zero.

7 years agoMerge pull request #3909 from poettering/mount-tool
Evgeny Vereshchagin [Fri, 19 Aug 2016 20:33:49 +0000 (23:33 +0300)] 
Merge pull request #3909 from poettering/mount-tool

add a new tool for creating transient mount and automount units

7 years agoMerge pull request #3987 from keszybz/console-color-setup
Lennart Poettering [Fri, 19 Aug 2016 17:36:09 +0000 (19:36 +0200)] 
Merge pull request #3987 from keszybz/console-color-setup

Rework console color setup

7 years agoMerge pull request #3955 from keszybz/fix-preset-all
Lennart Poettering [Fri, 19 Aug 2016 17:10:30 +0000 (19:10 +0200)] 
Merge pull request #3955 from keszybz/fix-preset-all

Fix preset-all

7 years agoMerge pull request #3961 from keszybz/pr/3924
Lennart Poettering [Fri, 19 Aug 2016 17:08:41 +0000 (19:08 +0200)] 
Merge pull request #3961 from keszybz/pr/3924

Add documentation to #3924

7 years agoman: document that "systemctl switch-root" tries hard to pass state across (#3995)
Lennart Poettering [Fri, 19 Aug 2016 16:16:28 +0000 (18:16 +0200)] 
man: document that "systemctl switch-root" tries hard to pass state across (#3995)

As suggested:

https://github.com/systemd/systemd/pull/3958#issuecomment-240410958

Let's document that we try hard to pass system state from the initrd to the
host, and even compare the systemd binary paths.

7 years agoMerge pull request #3997 from poettering/codition-udev-fix
Zbigniew Jędrzejewski-Szmek [Fri, 19 Aug 2016 16:13:44 +0000 (12:13 -0400)] 
Merge pull request #3997 from poettering/codition-udev-fix

Trivial fixes to udev and condition tests

7 years agoterminal-util: use getenv_bool for $SYSTEMD_COLORS 3987/head
Zbigniew Jędrzejewski-Szmek [Fri, 19 Aug 2016 14:26:27 +0000 (10:26 -0400)] 
terminal-util: use getenv_bool for $SYSTEMD_COLORS

This changes the semantics a bit: before, SYSTEMD_COLORS= would be treated as
"yes", same as SYSTEMD_COLORS=xxx and SYSTEMD_COLORS=1, and only
SYSTEMD_COLORS=0 would be treated as "no". Now, only valid booleans are treated
as "yes". This actually matches how $SYSTEMD_COLORS was announced in NEWS.

7 years agosystemd: ignore lack of tty when checking whether colors should be enabled
Zbigniew Jędrzejewski-Szmek [Fri, 19 Aug 2016 02:03:56 +0000 (22:03 -0400)] 
systemd: ignore lack of tty when checking whether colors should be enabled

When started by the kernel, we are connected to the console, and we'll set TERM
properly to some value in fixup_environment(). We'll then enable or disable
colors based on the value of $SYSTEMD_COLORS and $TERM.

When reexecuting, TERM should be already set, so we can use this value.
Effectively, behaviour is the same as before affd7ed1a was reverted, but instead
of reopening the console before configuring color output, we just ignore what
stdout is connected to and decide based on the variables only.

7 years agoMerge pull request #3992 from poettering/hostname-fix2
Ronny Chevalier [Fri, 19 Aug 2016 14:46:49 +0000 (16:46 +0200)] 
Merge pull request #3992 from poettering/hostname-fix2

some hostname fixes, triggered by #3979

7 years agotests: let's stick to 8ch indenting, in perl code too 3997/head
Lennart Poettering [Fri, 19 Aug 2016 14:01:17 +0000 (16:01 +0200)] 
tests: let's stick to 8ch indenting, in perl code too

7 years agotest: always check whether condition allocation worked
Lennart Poettering [Fri, 19 Aug 2016 14:00:51 +0000 (16:00 +0200)] 
test: always check whether condition allocation worked

Our tests should test for OOM too explicitly, hence fix the test accordingly

7 years agoshared/install: properly report masked units listed in Also= 3955/head
Zbigniew Jędrzejewski-Szmek [Thu, 18 Aug 2016 02:15:54 +0000 (22:15 -0400)] 
shared/install: properly report masked units listed in Also=

A masked unit is listed in Also=:

$ systemctl cat test1 test2
→# /etc/systemd/system/test1.service
[Unit]
Description=test service 1

[Service]
Type=oneshot
ExecStart=/usr/bin/true

[Install]
WantedBy=multi-user.target
Also=test2.service
Alias=alias1.service

→# /dev/null

$ systemctl --root=/ enable test1
(before)
Created symlink /etc/systemd/system/alias1.service → /etc/systemd/system/test1.service.
Created symlink /etc/systemd/system/multi-user.target.wants/test1.service → /etc/systemd/system/test1.service.
The unit files have no installation config (WantedBy, RequiredBy, Also, Alias
settings in the [Install] section, and DefaultInstance for template units).
This means they are not meant to be enabled using systemctl.
Possible reasons for having this kind of units are:
1) A unit may be statically enabled by being symlinked from another unit's
   .wants/ or .requires/ directory.
2) A unit's purpose may be to act as a helper for some other unit which has
   a requirement dependency on it.
3) A unit may be started when needed via activation (socket, path, timer,
   D-Bus, udev, scripted systemctl call, ...).
4) In case of template units, the unit is meant to be enabled with some
   instance name specified.

(after)
Created symlink /etc/systemd/system/alias1.service → /etc/systemd/system/test1.service.
Created symlink /etc/systemd/system/multi-user.target.wants/test1.service → /etc/systemd/system/test1.service.
Unit /etc/systemd/system/test2.service is masked, ignoring.

7 years agounits: install user units as real files, not symlinks to ../system/
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 14:09:11 +0000 (10:09 -0400)] 
units: install user units as real files, not symlinks to ../system/

This was causing preset-all --global to create symlinks:

$ systemctl preset-all --global --root=/var/tmp/inst1
Created symlink /var/tmp/inst1/etc/systemd/user/shutdown.target → /usr/lib/systemd/user/../system/shutdown.target.
Created symlink /var/tmp/inst1/etc/systemd/user/sockets.target → /usr/lib/systemd/user/../system/sockets.target.
Created symlink /var/tmp/inst1/etc/systemd/user/timers.target → /usr/lib/systemd/user/../system/timers.target.
Created symlink /var/tmp/inst1/etc/systemd/user/paths.target → /usr/lib/systemd/user/../system/paths.target.
Created symlink /var/tmp/inst1/etc/systemd/user/bluetooth.target → /usr/lib/systemd/user/../system/bluetooth.target.
Created symlink /var/tmp/inst1/etc/systemd/user/printer.target → /usr/lib/systemd/user/../system/printer.target.
Created symlink /var/tmp/inst1/etc/systemd/user/sound.target → /usr/lib/systemd/user/../system/sound.target.
Created symlink /var/tmp/inst1/etc/systemd/user/smartcard.target → /usr/lib/systemd/user/../system/smartcard.target.
Created symlink /var/tmp/inst1/etc/systemd/user/busnames.target → /usr/lib/systemd/user/../system/busnames.target.

It is better to create units in a state that completely matches the presets, i.e.
preset-all should do nothing when invoked immediately after installation.

I'm sure it was confusing to users too, suggesting that system and user units
may somehow alias each other.

7 years agounits: synchronize Makefile and presets settings
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 05:55:16 +0000 (01:55 -0400)] 
units: synchronize Makefile and presets settings

Enable reboot.target and disable exit.target: the first is used on normal
machines, the second only in containers, and the more general one
should be enabled by default.

Also fix the Makefile to match what preset-all does.

With this and the previous commits, doing "make instal DESTDIR=…" followed
by "systemctl preset-all --root=…" doesn't result in any changes.

7 years agounits: enable systemd-networkd-wait-online.service, disable all journal-remote stuff
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 05:52:12 +0000 (01:52 -0400)] 
units: enable systemd-networkd-wait-online.service, disable all journal-remote stuff

The preset for systemd-networkd-wait-online.service should match
whatever we do for systemd-networkd.service. s-n-wait-online.service
is only pulled in when some other unit pulls in network-online.target,
otherwise it's not used. But if something pulls in network-online.target,
they should expect s-n-wait-online.service to be active iff
systemd-networkd.service is active.

OTOH, the journal-remote and journal-upload services should be disabled
by default, since they don't do anything without additional configuration.

7 years agoshared/install: when creating symlinks, keep existing relative symlinks
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 05:27:21 +0000 (01:27 -0400)] 
shared/install: when creating symlinks, keep existing relative symlinks

Running preset-all on a system installed from rpms or even created
using make install would remove and recreate a lot of symlinks, changing
relative to absolute symlinks. In general relative symlinks are nicer,
so there is no reason to change them, and those spurious changes were
obscuring more interesting stuff.

$ make install DESTDIR=/var/tmp/inst1

$ systemctl preset-all --root=/var/tmp/inst1
(before)
Removed /var/tmp/inst1/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service.
Created symlink /var/tmp/inst1/etc/systemd/system/ctrl-alt-del.target → /usr/lib/systemd/system/exit.target.
Removed /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/remote-fs.target.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/remote-fs.target → /usr/lib/systemd/system/remote-fs.target.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/machines.target → /usr/lib/systemd/system/machines.target.
Created symlink /var/tmp/inst1/etc/systemd/system/sockets.target.wants/systemd-journal-remote.socket → /usr/lib/systemd/system/systemd-journal-remote.socket.
Removed /var/tmp/inst1/etc/systemd/system/sockets.target.wants/systemd-networkd.socket.
Created symlink /var/tmp/inst1/etc/systemd/system/sockets.target.wants/systemd-networkd.socket → /usr/lib/systemd/system/systemd-networkd.socket.
Removed /var/tmp/inst1/etc/systemd/system/getty.target.wants/getty@tty1.service.
Created symlink /var/tmp/inst1/etc/systemd/system/getty.target.wants/getty@tty1.service → /usr/lib/systemd/system/getty@.service.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-journal-upload.service → /usr/lib/systemd/system/systemd-journal-upload.service.
Removed /var/tmp/inst1/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service.
Created symlink /var/tmp/inst1/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service → /usr/lib/systemd/system/systemd-timesyncd.service.
Removed /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-resolved.service.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-resolved.service → /usr/lib/systemd/system/systemd-resolved.service.
Removed /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-networkd.service.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-networkd.service → /usr/lib/systemd/system/systemd-networkd.service.

(after)
Removed /var/tmp/inst1/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service.
Created symlink /var/tmp/inst1/etc/systemd/system/ctrl-alt-del.target → /usr/lib/systemd/system/exit.target.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/machines.target → /usr/lib/systemd/system/machines.target.
Created symlink /var/tmp/inst1/etc/systemd/system/sockets.target.wants/systemd-journal-remote.socket → /usr/lib/systemd/system/systemd-journal-remote.socket.
Created symlink /var/tmp/inst1/etc/systemd/system/multi-user.target.wants/systemd-journal-upload.service → /usr/lib/systemd/system/systemd-journal-upload.service.

7 years agoshared/install: move root skipping into create_symlink()
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 05:21:57 +0000 (01:21 -0400)] 
shared/install: move root skipping into create_symlink()

No functional change intended.

7 years agoman: describe what symlinks to unit do, and specify that presets must use real names
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 13:38:12 +0000 (09:38 -0400)] 
man: describe what symlinks to unit do, and specify that presets must use real names

The man pages didn't ever mention that symlinks to units can be created, and what
exactly this means. Fix that omission, and disallow presets on alias names.

7 years agoshared/install: ignore unit symlinks when doing preset-all
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 05:20:29 +0000 (01:20 -0400)] 
shared/install: ignore unit symlinks when doing preset-all

Before, when interating over unit files during preset-all, behaviour was the
following:

- if we hit the real unit name first, presets were queried for that name, and
  that unit was enabled or disabled accordingly,

- if we hit an alias first (one of the symlinks chaining to the real unit), we
  checked the presets using the symlink name, and then proceeded to enable or
  disable the real unit.

E.g. for systemd-networkd.service we have the alias dbus-org.freedesktop.network1.service
(/usr/lib/systemd/system/dbus-org.freedesktop.network1.service), but the preset
is only for the systemd-networkd.service name. The service would be enabled or
disabled pseudorandomly depending on the order of iteration.

For "preset", behaviour was analogous: preset on the alias name disabled the
service (following the default disable policy), preset on the "real" name
applied the presets.

With the patch, for "preset" and "preset-all" we silently skip symlinks. This
gives mostly the right behaviour, with the limitation that presets on aliases
are ignored.  I think that presets on aliases are not that common (at least my
preset files on Fedora don't exhibit any such usage), and should not be
necessary, since whoever installs the preset can just refer to the real unit
file. It would be possible to overcome this limitation by gathering a list of
names of a unit first, and then checking whether *any* of the names matches the
presets list. That would require a significant redesign of the code, and be
a lot slower (since we would have to fully read all unit directories to preset
one unit) to so I'm not doing that for now.

With this patch, two properties are satisfied:
- preset-all and preset are idempotent, and the second and subsequent invocations
  do not produce any changes,
- preset-all and preset for a specific name produce the same state for that unit.

Fixes #3616.

7 years agoshared/install: remove unused paramater and add more comments
Zbigniew Jędrzejewski-Szmek [Sat, 13 Aug 2016 03:50:58 +0000 (23:50 -0400)] 
shared/install: remove unused paramater and add more comments

7 years agosystemctl: fix preset-all with missing /etc/systemd/system
Zbigniew Jędrzejewski-Szmek [Fri, 12 Aug 2016 01:53:32 +0000 (21:53 -0400)] 
systemctl: fix preset-all with missing /etc/systemd/system

If the directory is missing, we can assume that those pesky symlinks are gone too.

7 years agohwdb: let's no abbreivate HORIZONTAL as HORIZ (#3994)
Lennart Poettering [Fri, 19 Aug 2016 13:31:36 +0000 (15:31 +0200)] 
hwdb: let's no abbreivate HORIZONTAL as HORIZ (#3994)

I think I am developing OCD... Let's fix this before this actually gets used in
the wild.

A follow-up for #3986 (5fc9e4abb41e7f58f6c308f54881c596713fba75).

7 years agoman: minor wording fixes 3992/head
Lennart Poettering [Fri, 19 Aug 2016 09:04:13 +0000 (11:04 +0200)] 
man: minor wording fixes

7 years agoman: don't claim we replace spaces by dashes when cleaning up hostnames
Lennart Poettering [Fri, 19 Aug 2016 09:02:55 +0000 (11:02 +0200)] 
man: don't claim we replace spaces by dashes when cleaning up hostnames

Let's make sure the man page actually documents what is implemented, i.e.
"Lennart's PC" turns into "LennartsPC" when we clean up the name.

7 years agoman: document that static/transient hostnames may be 64 chars at max
Lennart Poettering [Fri, 19 Aug 2016 09:02:24 +0000 (11:02 +0200)] 
man: document that static/transient hostnames may be 64 chars at max

7 years agotests: add test from #3979
Lennart Poettering [Fri, 19 Aug 2016 09:01:21 +0000 (11:01 +0200)] 
tests: add test from #3979

Let's add one more test that came up during the discussion of an issue.

The selected name with 69 chars is above the Linux hostname limit of 64.

7 years agoMerge pull request #3990 from AnchorCat/networkd-fixes
Lennart Poettering [Fri, 19 Aug 2016 08:43:58 +0000 (10:43 +0200)] 
Merge pull request #3990 from AnchorCat/networkd-fixes

networkd: various fixes for route configuration

7 years agoMerge pull request #3988 from keszybz/journald-dynamic-users
Lennart Poettering [Fri, 19 Aug 2016 08:41:26 +0000 (10:41 +0200)] 
Merge pull request #3988 from keszybz/journald-dynamic-users

Journald dynamic users