]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
7 years agotest: fix stack overflow reported by ASAN
Cristian Rodríguez [Fri, 5 Aug 2016 16:07:49 +0000 (16:07 +0000)] 
test: fix stack overflow reported by ASAN

It was meant to write to q instead of t
FAIL: test-id128
================

=================================================================
==125770==ERROR: AddressSanitizer: stack-buffer-overflow on address 0x7ffd4615bd31 at pc 0x7a2f41b1bf33 bp 0x7ffd4615b750 sp 0x7ffd4615b748
WRITE of size 1 at 0x7ffd4615bd31 thread T0
    #0 0x7a2f41b1bf32 in id128_to_uuid_string src/libsystemd/sd-id128/id128-util.c:42
    #1 0x401f73 in main src/test/test-id128.c:147
    #2 0x7a2f41336341 in __libc_start_main (/lib64/libc.so.6+0x20341)
    #3 0x401129 in _start (/home/crrodriguez/scm/systemd/.libs/test-id128+0x401129)

Address 0x7ffd4615bd31 is located in stack of thread T0 at offset 1409 in frame
    #0 0x401205 in main src/test/test-id128.c:37

  This frame has 23 object(s):
    [32, 40) 'b'
    [96, 112) 'id'
    [160, 176) 'id2'
    [224, 240) 'a'
    [288, 304) 'b'
    [352, 368) 'a'
    [416, 432) 'b'
    [480, 496) 'a'
    [544, 560) 'b'
    [608, 624) 'a'
    [672, 688) 'b'
    [736, 752) 'a'
    [800, 816) 'b'
    [864, 880) 'a'
    [928, 944) 'b'
    [992, 1008) 'a'
    [1056, 1072) 'b'
    [1120, 1136) 'a'
    [1184, 1200) 'b'
    [1248, 1264) 'a'
    [1312, 1328) 'b'
    [1376, 1409) 't' <== Memory access at offset 1409 overflows this variable
    [1472, 1509) 'q'
HINT: this may be a false positive if your program uses some custom stack unwind mechanism or swapcontext
      (longjmp and C++ exceptions *are* supported)
SUMMARY: AddressSanitizer: stack-buffer-overflow src/libsystemd/sd-id128/id128-util.c:42 in id128_to_uuid_string
Shadow bytes around the buggy address:
  0x100028c23750: f2 f2 00 00 f4 f4 f2 f2 f2 f2 00 00 f4 f4 f2 f2
  0x100028c23760: f2 f2 00 00 f4 f4 f2 f2 f2 f2 00 00 f4 f4 f2 f2
  0x100028c23770: f2 f2 00 00 f4 f4 f2 f2 f2 f2 00 00 f4 f4 f2 f2
  0x100028c23780: f2 f2 00 00 f4 f4 f2 f2 f2 f2 00 00 f4 f4 f2 f2
  0x100028c23790: f2 f2 00 00 f4 f4 f2 f2 f2 f2 00 00 f4 f4 f2 f2
=>0x100028c237a0: f2 f2 00 00 00 00[01]f4 f4 f4 f2 f2 f2 f2 00 00
  0x100028c237b0: 00 00 05 f4 f4 f4 00 00 00 00 00 00 00 00 00 00
  0x100028c237c0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100028c237d0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100028c237e0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x100028c237f0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
Shadow byte legend (one shadow byte represents 8 application bytes):
  Addressable:           00
  Partially addressable: 01 02 03 04 05 06 07
  Heap left redzone:       fa
  Heap right redzone:      fb
  Freed heap region:       fd
  Stack left redzone:      f1
  Stack mid redzone:       f2
  Stack right redzone:     f3
  Stack partial redzone:   f4
  Stack after return:      f5
  Stack use after scope:   f8
  Global redzone:          f9
  Global init order:       f6
  Poisoned by user:        f7
  Container overflow:      fc
  Array cookie:            ac
  Intra object redzone:    bb
  ASan internal:           fe
  Left alloca redzone:     ca
  Right alloca redzone:    cb
==125770==ABORTING
FAIL test-id128 (exit status: 1)

7 years agotest: test-sigbus must be skipped when -fsanitize=address is used
Cristian Rodríguez [Thu, 4 Aug 2016 16:49:19 +0000 (16:49 +0000)] 
test: test-sigbus must be skipped when -fsanitize=address is used

ASAN is unable to handle it.

7 years agoMerge pull request #3818 from poettering/exit-status-env
Zbigniew Jędrzejewski-Szmek [Sat, 6 Aug 2016 00:55:08 +0000 (20:55 -0400)] 
Merge pull request #3818 from poettering/exit-status-env

beef up /var/tmp and /tmp handling; set $SERVICE_RESULT/$EXIT_CODE/$EXIT_STATUS on ExecStop= and make sure root/nobody are always resolvable

7 years agonetworkd: add support to set STP (#3903)
Susant Sahani [Fri, 5 Aug 2016 23:44:57 +0000 (05:14 +0530)] 
networkd: add support to set STP (#3903)

fixes #3881

7 years agoMerge pull request #3900 from keszybz/fix-3607
Lennart Poettering [Fri, 5 Aug 2016 15:03:09 +0000 (17:03 +0200)] 
Merge pull request #3900 from keszybz/fix-3607

Fix 3607

7 years agosocket: add helper function to remove code duplication 3900/head
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 12:24:00 +0000 (08:24 -0400)] 
socket: add helper function to remove code duplication

7 years agocore/socket: include remote address in the message when dropping connection
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 03:51:47 +0000 (23:51 -0400)] 
core/socket: include remote address in the message when dropping connection

Without the address the message is not very useful.

Aug 04 23:52:21 rawhide systemd[1]: testlimit.socket: Too many incoming connections (4) from source ::1, dropping connection.

7 years agosystemd: do not serialize peer, bump count when deserializing socket instead
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 03:42:27 +0000 (23:42 -0400)] 
systemd: do not serialize peer, bump count when deserializing socket instead

7 years agocore/service: serialize and deserialize accept_socket
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 03:26:31 +0000 (23:26 -0400)] 
core/service: serialize and deserialize accept_socket

This fixes an issue during reexec — the count of connections would be lost:

[zbyszek@fedora-rawhide ~]$ systemctl status testlimit.socket | grep Connected
 Accepted: 1; Connected: 1

[zbyszek@fedora-rawhide ~]$ sudo systemctl daemon-reexec
[zbyszek@fedora-rawhide ~]$ systemctl status testlimit.socket | grep Connected
 Accepted: 1; Connected: 0

With the patch, Connected count is preserved.

Also add "Accept Socket" to the dump output for services.

7 years agocore/socket: rework SocketPeer refcounting
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 01:42:23 +0000 (21:42 -0400)] 
core/socket: rework SocketPeer refcounting

Make functions and definitions that don't need to be shared local to
socket.c.

7 years agoMerge pull request #3902 from poettering/parse-nice
Ronny Chevalier [Fri, 5 Aug 2016 11:35:52 +0000 (13:35 +0200)] 
Merge pull request #3902 from poettering/parse-nice

util-lib: unify parsing of nice level values

7 years agoutil-lib: unify parsing of nice level values 3902/head
Lennart Poettering [Fri, 5 Aug 2016 09:17:08 +0000 (11:17 +0200)] 
util-lib: unify parsing of nice level values

This adds parse_nice() that parses a nice level and ensures it is in the right
range, via a new nice_is_valid() helper. It then ports over a number of users
to this.

No functional changes.

7 years agonetworkd: do not set NOARP unconditionally (#3891)
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 08:37:10 +0000 (04:37 -0400)] 
networkd: do not set NOARP unconditionally (#3891)

Fixes #3890.

7 years agofileio: fix MIN/MAX mixup (#3896)
Vito Caputo [Fri, 5 Aug 2016 04:09:23 +0000 (21:09 -0700)] 
fileio: fix MIN/MAX mixup (#3896)

The intention is to clamp the value to READ_FULL_BYTES_MAX, which
would be the minimum of the two.

7 years agojournal-remote: remove unnecessary gnutls includes (#3895)
Vito Caputo [Fri, 5 Aug 2016 04:05:34 +0000 (21:05 -0700)] 
journal-remote: remove unnecessary gnutls includes (#3895)

journal-(gatewayd,remote).c don't actually utilize libgnutls even when
HAVE_GNUTLS is defined.

7 years agosystemd: convert peers_by_address to a set
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 00:55:45 +0000 (20:55 -0400)] 
systemd: convert peers_by_address to a set

7 years agobasic/set: remove some spurious spaces
Zbigniew Jędrzejewski-Szmek [Fri, 5 Aug 2016 00:36:10 +0000 (20:36 -0400)] 
basic/set: remove some spurious spaces

7 years agocore: only set the watchdog variables in ExecStart= lines 3818/head
Lennart Poettering [Thu, 4 Aug 2016 20:11:29 +0000 (22:11 +0200)] 
core: only set the watchdog variables in ExecStart= lines

7 years agocore: remember first unit failure, not last unit failure
Lennart Poettering [Thu, 4 Aug 2016 19:14:27 +0000 (21:14 +0200)] 
core: remember first unit failure, not last unit failure

Previously, the result value of a unit was overriden with each failure that
took place, so that the result always reported the last failure that took
place.

With this commit this is changed, so that the first failure taking place is
stored instead. This should normally not matter much as multiple failures are
sufficiently uncommon. However, it improves one behaviour: if we send SIGABRT
to a service due to a watchdog timeout, then this currently would be reported
as "coredump" failure, rather than the "watchodg" failure it really is. Hence,
in order to report information about the type of the failure, and not about
the effect of it, let's change this from all unit type to store the first, not
the last failure.

This addresses the issue pointed out here:

https://github.com/systemd/systemd/pull/3818#discussion_r73433520

7 years agoupdate TODO
Lennart Poettering [Wed, 27 Jul 2016 11:30:58 +0000 (13:30 +0200)] 
update TODO

7 years agonss-systemd: resolve root/nobody statically
Lennart Poettering [Wed, 27 Jul 2016 11:14:01 +0000 (13:14 +0200)] 
nss-systemd: resolve root/nobody statically

Let's extend nss-systemd to also synthesize user/group entries for the
UIDs/GIDs 0 and 65534 which have special kernel meaning. Given that nss-systemd
is listed in /etc/nsswitch.conf only very late any explicit listing in
/etc/passwd or /etc/group takes precedence.

This functionality is useful in minimal container-like setups that lack
/etc/passwd files (or only have incompletely populated ones).

7 years agocore: set $SERVICE_RESULT, $EXIT_CODE and $EXIT_STATUS in ExecStop=/ExecStopPost...
Lennart Poettering [Wed, 27 Jul 2016 09:51:11 +0000 (11:51 +0200)] 
core: set $SERVICE_RESULT, $EXIT_CODE and $EXIT_STATUS in ExecStop=/ExecStopPost= commands

This should simplify monitoring tools for services, by passing the most basic
information about service result/exit information via environment variables,
thus making it unnecessary to retrieve them explicitly via the bus.

7 years agomain: use pager for --dump-configuration-items (#3894)
0xAX [Thu, 4 Aug 2016 20:52:24 +0000 (23:52 +0300)] 
main: use pager for --dump-configuration-items (#3894)

7 years agofileio: fix read_full_stream() bugs (#3887)
Vito Caputo [Thu, 4 Aug 2016 20:52:02 +0000 (13:52 -0700)] 
fileio: fix read_full_stream() bugs (#3887)

read_full_stream() _always_ allocated twice the memory needed, due to
only breaking the realloc() && fread() loop when fread() returned 0,
requiring another iteration and exponentially enlarged buffer just to
discover the EOF condition.

This also caused file sizes >2MiB && <= 4MiB to erroneously be treated
as E2BIG, due to the inappropriately doubled buffer size exceeding
4*1024*1024.

Also made the 4*1024*1024 magic number a READ_FULL_BYTES_MAX constant.

7 years agoMerge pull request #3892 from toanju/fix-brvlan-error-on-normal-bridge
Lennart Poettering [Thu, 4 Aug 2016 18:39:57 +0000 (20:39 +0200)] 
Merge pull request #3892 from toanju/fix-brvlan-error-on-normal-bridge

networkd: apply bridge vlan configuration correct

7 years agonetworkd: apply bridge vlan configuration correct 3892/head
Tobias Jungel [Thu, 4 Aug 2016 15:11:13 +0000 (17:11 +0200)] 
networkd: apply bridge vlan configuration correct

bridge vlan configuration was applied even if it wasn't configured.

fixes #3876

7 years agocore: use the correct APIs to determine whether a dual timestamp is initialized
Lennart Poettering [Wed, 27 Jul 2016 09:50:37 +0000 (11:50 +0200)] 
core: use the correct APIs to determine whether a dual timestamp is initialized

7 years agocore: move masking of chroot/permission masking into service_spawn()
Lennart Poettering [Tue, 26 Jul 2016 15:53:07 +0000 (17:53 +0200)] 
core: move masking of chroot/permission masking into service_spawn()

Let's fix up the flags fields in service_spawn() rather than its callers, in
order to simplify things a bit.

7 years agocore: turn various execution flags into a proper flags parameter
Lennart Poettering [Tue, 26 Jul 2016 15:40:35 +0000 (17:40 +0200)] 
core: turn various execution flags into a proper flags parameter

The ExecParameters structure contains a number of bit-flags, that were so far
exposed as bool:1, change this to a proper, single binary bit flag field. This
makes things a bit more expressive, and is helpful as we add more flags, since
these booleans are passed around in various callers, for example
service_spawn(), whose signature can be made much shorter now.

Not all bit booleans from ExecParameters are moved into the flags field for
now, but this can be added later.

7 years agoutil-lib: rework /tmp and /var/tmp handling code
Lennart Poettering [Tue, 26 Jul 2016 15:23:28 +0000 (17:23 +0200)] 
util-lib: rework /tmp and /var/tmp handling code

Beef up the existing var_tmp() call, rename it to var_tmp_dir() and add a
matching tmp_dir() call (the former looks for the place for /var/tmp, the
latter for /tmp).

Both calls check $TMPDIR, $TEMP, $TMP, following the algorithm Python3 uses.
All dirs are validated before use. secure_getenv() is used in order to limite
exposure in suid binaries.

This also ports a couple of users over to these new APIs.

The var_tmp() return parameter is changed from an allocated buffer the caller
will own to a const string either pointing into environ[], or into a static
const buffer. Given that environ[] is mostly considered constant (and this is
exposed in the very well-known getenv() call), this should be OK behaviour and
allows us to avoid memory allocations in most cases.

Note that $TMPDIR and friends override both /var/tmp and /tmp usage if set.

7 years agoMerge pull request #2471 from michaelolbrich/transient-mounts
Lennart Poettering [Thu, 4 Aug 2016 14:16:04 +0000 (16:16 +0200)] 
Merge pull request #2471 from michaelolbrich/transient-mounts

allow transient mounts and automounts

7 years agoMerge pull request #3885 from keszybz/help-output
Lennart Poettering [Thu, 4 Aug 2016 14:11:38 +0000 (16:11 +0200)] 
Merge pull request #3885 from keszybz/help-output

Update help for "short-full" and shorten to 80 columns

7 years agonetworkd: add support to configure NOARP/ARP for interface (#3854)
Susant Sahani [Thu, 4 Aug 2016 14:00:58 +0000 (19:30 +0530)] 
networkd: add support to configure NOARP/ARP for interface (#3854)

https://lists.freedesktop.org/archives/systemd-devel/2016-August/037268.html

7 years agonetworkd: remove route if carrier is lost (#3831)
Susant Sahani [Thu, 4 Aug 2016 13:56:39 +0000 (19:26 +0530)] 
networkd: remove route if carrier is lost (#3831)

Fixes #3669.

7 years agosrc/test: add tests for parse_percent_unbounded (#3889)
Jonathan Boulle [Thu, 4 Aug 2016 13:54:10 +0000 (15:54 +0200)] 
src/test: add tests for parse_percent_unbounded (#3889)

7 years agoman: describe list-dependencies --all 3885/head
Zbigniew Jędrzejewski-Szmek [Thu, 4 Aug 2016 03:49:18 +0000 (23:49 -0400)] 
man: describe list-dependencies --all

Meaning of --all was mentioned in list-dependencies description, but the this
effect should also be mentioned in the description of the option itself.

7 years agonspawn,resolve: short --help output to fit within 80 columns
Zbigniew Jędrzejewski-Szmek [Thu, 4 Aug 2016 00:05:37 +0000 (20:05 -0400)] 
nspawn,resolve: short --help output to fit within 80 columns

make dist-check-help FTW!

7 years agojournalctl,systemctl: add "short-full", "short-unix" mode to --help
Zbigniew Jędrzejewski-Szmek [Wed, 3 Aug 2016 23:52:28 +0000 (19:52 -0400)] 
journalctl,systemctl: add "short-full", "short-unix" mode to --help

7 years agoutil-lib: add parse_percent_unbounded() for percentages over 100% (#3886)
David Michael [Thu, 4 Aug 2016 11:09:54 +0000 (04:09 -0700)] 
util-lib: add parse_percent_unbounded() for percentages over 100% (#3886)

This permits CPUQuota to accept greater values as documented.

7 years agoMerge pull request #3820 from poettering/nspawn-resolvconf
Zbigniew Jędrzejewski-Szmek [Thu, 4 Aug 2016 00:14:32 +0000 (20:14 -0400)] 
Merge pull request #3820 from poettering/nspawn-resolvconf

nspawn resolv.conf handling improvements, and inherit $TERM all the way through nspawn → console login

7 years agohwdb: fix hwdb entry for numeric-only Lenovo *40, *50 and *60 series
Peter Hutterer [Wed, 3 Aug 2016 23:57:36 +0000 (09:57 +1000)] 
hwdb: fix hwdb entry for numeric-only Lenovo *40, *50 and *60 series

Commit e5bc3f4fdc matches on e.g. a T440s, but not a T440 (i.e. the one
without a suffix).

7 years agojournalctl: add new output mode "short-full" (#3880)
Lennart Poettering [Wed, 3 Aug 2016 23:45:07 +0000 (01:45 +0200)] 
journalctl: add new output mode "short-full" (#3880)

This new output mode formats all timestamps using the usual format_timestamp()
call we use pretty much everywhere else. Timestamps formatted this way are some
ways more useful than traditional syslog timestamps as they include weekday,
month and timezone information, while not being much longer. They are also not
locale-dependent. The primary advantage however is that they may be passed
directly to journalctl's --since= and --until= switches as soon as #3869 is
merged.

While we are at it, let's also add "short-unix" to shell completion.

7 years agoutil-lib: make timestamp generation and parsing reversible (#3869)
Lennart Poettering [Wed, 3 Aug 2016 23:04:53 +0000 (01:04 +0200)] 
util-lib: make timestamp generation and parsing reversible (#3869)

This patch improves parsing and generation of timestamps and calendar
specifications in two ways:

- The week day is now always printed in the abbreviated English form, instead
  of the locale's setting. This makes sure we can always parse the week day
  again, even if the locale is changed. Given that we don't follow locale
  settings for printing timestamps in any other way either (for example, we
  always use 24h syntax in order to make uniform parsing possible), it only
  makes sense to also stick to a generic, non-localized form for the timestamp,
  too.

- When parsing a timestamp, the local timezone (in its DST or non-DST name)
  may be specified, in addition to "UTC". Other timezones are still not
  supported however (not because we wouldn't want to, but mostly because libc
  offers no nice API for that). In itself this brings no new features, however
  it ensures that any locally formatted timestamp's timezone is also parsable
  again.

These two changes ensure that the output of format_timestamp() may always be
passed to parse_timestamp() and results in the original input. The related
flavours for usec/UTC also work accordingly. Calendar specifications are
extended in a similar way.

The man page is updated accordingly, in particular this removes the claim that
timestamps systemd prints wouldn't be parsable by systemd. They are now.

The man page previously showed invalid timestamps as examples. This has been
removed, as the man page shouldn't be a unit test, where such negative examples
would be useful. The man page also no longer mentions the names of internal
functions, such as format_timestamp_us() or UNIX error codes such as EINVAL.

7 years agosystemctl: consider service running only when it is in active or reloading state...
Lukáš Nykrýn [Wed, 3 Aug 2016 15:08:37 +0000 (17:08 +0200)] 
systemctl: consider service running only when it is in active or reloading state (#3874)

Otherwise for example services that are failing on start and have Restart=on-failure
and bigger RestartSec systemctl status will return 0.

Fixes: #3864
7 years agonspawn: if we can't mark the boot ID RO let's fail 3820/head
Lennart Poettering [Wed, 3 Aug 2016 12:51:05 +0000 (14:51 +0200)] 
nspawn: if we can't mark the boot ID RO let's fail

It's probably better to be safe here.

7 years agoexecute: don't set $SHELL and $HOME for services, if they don't contain interesting...
Lennart Poettering [Wed, 27 Jul 2016 18:00:33 +0000 (20:00 +0200)] 
execute: don't set $SHELL and $HOME for services, if they don't contain interesting data

7 years agocore: inherit TERM from PID 1 for all services started on /dev/console
Lennart Poettering [Wed, 27 Jul 2016 13:25:55 +0000 (15:25 +0200)] 
core: inherit TERM from PID 1 for all services started on /dev/console

This way, invoking nspawn from a shell in the best case inherits the TERM
setting all the way down into the login shell spawned in the container.

Fixes: #3697
7 years agocore: drop spurious newline
Lennart Poettering [Wed, 27 Jul 2016 13:12:42 +0000 (15:12 +0200)] 
core: drop spurious newline

7 years agonspawn: deprecate --share-system support
Lennart Poettering [Wed, 27 Jul 2016 12:56:17 +0000 (14:56 +0200)] 
nspawn: deprecate --share-system support

This removes the --share-system switch: from the documentation, the --help text
as well as the command line parsing. It's an ugly option, given that it kinda
contradicts the whole concept of PID namespaces that nspawn implements. Since
it's barely ever used, let's just deprecate it and remove it from the options.

It might be useful as a debugging option, hence the functionality is kept
around for now, exposed via an undocumented $SYSTEMD_NSPAWN_SHARE_SYSTEM
environment variable.

7 years agonspawn: try to bind mount resolved's resolv.conf snippet into the container
Lennart Poettering [Wed, 27 Jul 2016 12:50:45 +0000 (14:50 +0200)] 
nspawn: try to bind mount resolved's resolv.conf snippet into the container

This has the benefit that the container can follow the host's DNS server
changes without us having to constantly update the container's resolv.conf
settings.

7 years agoMerge pull request #3828 from keszybz/drop-systemd-vconsole-setup-service
Lennart Poettering [Wed, 3 Aug 2016 12:38:36 +0000 (14:38 +0200)] 
Merge pull request #3828 from keszybz/drop-systemd-vconsole-setup-service

Update documentation for systemd-vconsole-setup

7 years agohwdb: compress the various Lenovo *40, *50 and *60 series (#3877)
Peter Hutterer [Wed, 3 Aug 2016 11:12:37 +0000 (21:12 +1000)] 
hwdb: compress the various Lenovo *40, *50 and *60 series (#3877)

Each series has identical hardware, let's use a glob instead of listing them
one by one.

7 years agohwdb: add ID_INPUT_TRACKBALL as additional identifier (#3872)
Peter Hutterer [Wed, 3 Aug 2016 10:34:56 +0000 (20:34 +1000)] 
hwdb: add ID_INPUT_TRACKBALL as additional identifier (#3872)

Whether a device is a trackball or not is a physical property so we should
store this globally, in one place. The new property must be set in addition to
ID_INPUT_MOUSE, otherwise existing clients won't detect the device.

No actual code changes required, the default match rule is simply checking for
"Trackball" in the name (in a few versions), other entries need to be added
manually.

7 years agosocket: add support to control no. of connections from one source (#3607)
Susant Sahani [Tue, 2 Aug 2016 17:48:23 +0000 (23:18 +0530)] 
socket: add support to control no. of connections from one source (#3607)

Introduce MaxConnectionsPerSource= that is number of concurrent
connections allowed per IP.

RFE: 1939

7 years agoMerge pull request #3858 from jfilak/coredump-containers-v2
Zbigniew Jędrzejewski-Szmek [Tue, 2 Aug 2016 17:38:00 +0000 (13:38 -0400)] 
Merge pull request #3858 from jfilak/coredump-containers-v2

Coredump: save information useful for debuging crashes in containers - v2

7 years agotest: fix test-execute personality tests on ppc64 and aarch64 (#3825)
Jan Synacek [Tue, 2 Aug 2016 14:22:56 +0000 (16:22 +0200)] 
test: fix test-execute personality tests on ppc64 and aarch64 (#3825)

7 years agogitignore: libsystemd-journal.pc is no more (#3863)
Zbigniew Jędrzejewski-Szmek [Tue, 2 Aug 2016 14:04:39 +0000 (10:04 -0400)] 
gitignore: libsystemd-journal.pc is no more (#3863)

…since 4de282cf9324ab.

7 years agocoredump: save process container parent cmdline 3858/head
Jakub Filak [Wed, 27 Apr 2016 13:23:49 +0000 (15:23 +0200)] 
coredump: save process container parent cmdline

Process container parent is the process used to start processes with a new
user namespace - e.g systemd-nspawn, runc, lxc, etc.

There is not standard way how to find such a process - or I do not know
about it - hence I have decided to find the first process in the parent
process hierarchy with a different mount namespace and different
/proc/self/root's inode.

I have decided for this criteria because in ABRT we take special care
only if the crashed process runs different code than installed on the
host. Other processes with namespaces different than PID 1's namespaces
are just processes running code shipped by the OS vendor and bug
reporting tools can get information about the provider of the code
without the need to deal with changed root and so on.

7 years agomain: load Smack policy before IMA policy (#3859)
Ismo Puustinen [Tue, 2 Aug 2016 12:58:30 +0000 (15:58 +0300)] 
main: load Smack policy before IMA policy (#3859)

IMA wiki says: "If the IMA policy contains LSM labels, then the LSM
policy must be loaded prior to the IMA policy." Right now, in case of
Smack, the IMA policy is loaded before the Smack policy. Move the order
around to allow Smack labels to be used in IMA policy.

7 years agounits: add graphical-session-pre.target user unit (#3848)
Martin Pitt [Tue, 2 Aug 2016 12:56:45 +0000 (14:56 +0200)] 
units: add graphical-session-pre.target user unit (#3848)

This complements graphical-session.target for services which set up the
environment (e. g. dbus-update-activation-environment) and need to run before
the actual graphical session.

7 years agosystemd-ask-password: make sure directory watch is started before cryptsetup (#3850)
tblume [Tue, 2 Aug 2016 12:55:25 +0000 (14:55 +0200)] 
systemd-ask-password: make sure directory watch is started before cryptsetup (#3850)

The password directory watch should get ordered before cryptsetup to make sure
that the password for unlocking the crypt device gets prompted.

7 years agocoredump: save /proc/[pid]/mountinfo
Jakub Filak [Tue, 26 Apr 2016 07:54:39 +0000 (09:54 +0200)] 
coredump: save /proc/[pid]/mountinfo

The file contains information one can use to debug processes running
within a container.

7 years agomachinectl: hide legend in a case when no data (#3839)
0xAX [Mon, 1 Aug 2016 15:39:27 +0000 (18:39 +0300)] 
machinectl: hide legend in a case when no data (#3839)

For this moment machinectl prints legend and count of machines/images/etc.
But in a case when we have no images,machines,etc., there is no sense to
show legend:

~$ machinectl
MACHINE CLASS SERVICE

0 machines listed.

Let's print only 'No machines', 'No images', 'No transfers' in this case.

7 years agovirt: detect bhyve (FreeBSD hypervisor) (#3840)
Leonardo Brondani Schenkel [Mon, 1 Aug 2016 13:04:49 +0000 (15:04 +0200)] 
virt: detect bhyve (FreeBSD hypervisor) (#3840)

The CPUID and DMI vendor strings do not seem to be documented.
Values were found experimentally and by inspecting the source code.

7 years agomain: get rid of ACTION_DONE (#3849)
0xAX [Mon, 1 Aug 2016 10:38:25 +0000 (13:38 +0300)] 
main: get rid of ACTION_DONE (#3849)

the ACTION_DONE was introduced in the 4288f61921 (dbus: automatically
generate and install introspection files ) commit and was used in
systemd --introspect command.

Later 'introspect' command was removed in the ca2871d9b (bus: remove
static introspection file export) commit and have no users anymore.

So we can remove it.

7 years agoMerge pull request #3817 from dwassenberg/lenovo-trackpoint-speed-fixes
Peter Hutterer [Mon, 1 Aug 2016 03:15:39 +0000 (13:15 +1000)] 
Merge pull request #3817 from dwassenberg/lenovo-trackpoint-speed-fixes

Lenovo trackpoint speed fixes

7 years agoman: move description of kernel vconsole.conf overrides to vconsole.conf(5) 3828/head
Zbigniew Jędrzejewski-Szmek [Fri, 29 Jul 2016 05:01:04 +0000 (01:01 -0400)] 
man: move description of kernel vconsole.conf overrides to vconsole.conf(5)

They were outdated, and this way it's less likely that they'll get out of sync
again. Anyway, it's easier for the reader to have the kernel and config file
options next to one another.

7 years agovconsole-setup: add lots of debug messages
Zbigniew Jędrzejewski-Szmek [Sun, 24 Jul 2016 18:14:20 +0000 (14:14 -0400)] 
vconsole-setup: add lots of debug messages

For error messages, make them more meaningful by printing the tty name.

Follow-up for #3742.

7 years agoAdd enable_disable() helper
Zbigniew Jędrzejewski-Szmek [Sun, 24 Jul 2016 18:12:58 +0000 (14:12 -0400)] 
Add enable_disable() helper

In this patch "enabled" and "disabled" is used exclusively, but "enable" and
"disable" forms are need for the following patch.

7 years agoMerge pull request 3821 from davide125/fix-tests
Zbigniew Jędrzejewski-Szmek [Mon, 1 Aug 2016 02:01:43 +0000 (22:01 -0400)] 
Merge pull request 3821 from davide125/fix-tests

7 years agotest-path-util: check for /lt-test-path-util or /test-path-util (#3841)
Mike Gilbert [Mon, 1 Aug 2016 01:50:50 +0000 (21:50 -0400)] 
test-path-util: check for /lt-test-path-util or /test-path-util (#3841)

Depending on how binutils was configured and the --enable-fast-install
configure option, the test binary might be called either name.

Fixes: https://github.com/systemd/systemd/issues/3838
7 years agologind: 0% and 100% should be valid for UserTasksMax (#3836)
Tejun Heo [Mon, 1 Aug 2016 01:38:47 +0000 (21:38 -0400)] 
logind: 0% and 100% should be valid for UserTasksMax (#3836)

config_parse_user_tasks_max() was incorrectly accepting percentage value
between 1 and 99.  Update it to accept 0% and 100%.  This brings it in line
with TasksMax handling in systemd.

7 years agoMerge pull request #3843 from maxime1986/minor-systemd.resource-control
Zbigniew Jędrzejewski-Szmek [Mon, 1 Aug 2016 01:14:26 +0000 (21:14 -0400)] 
Merge pull request #3843 from maxime1986/minor-systemd.resource-control

7 years agodocumentation: cgroup-v1 and systemd user instance 3843/head
Maxime de Roucy [Sun, 31 Jul 2016 12:43:23 +0000 (14:43 +0200)] 
documentation: cgroup-v1 and systemd user instance

Explain in the systemd.resource-control man that systemd user instance can't use resource control on
cgroup-v1.

7 years agodocumentation: add cgroup-v2.txt link
Maxime de Roucy [Sun, 31 Jul 2016 12:38:56 +0000 (14:38 +0200)] 
documentation: add cgroup-v2.txt link

add cgroup-v2.txt link in section "Unified and Legacy Control Group
Hierarchies" of systemd.resource-control man.

7 years agotests: don't run private device tests if running in a container 3821/head
Steve Muir [Wed, 27 Jul 2016 21:23:44 +0000 (14:23 -0700)] 
tests: don't run private device tests if running in a container

Private devices don't exist when running in a container, so skip the related
tests.

7 years agotests: skip process 1 tests if systemd not is running
Davide Cavalca [Wed, 27 Jul 2016 21:22:26 +0000 (14:22 -0700)] 
tests: skip process 1 tests if systemd not is running

No point running tests against process 1 if systemd is not running as that
process. This is a rework of an unpublished patch by @9muir.

7 years agotests: don't test hostname if it looks like an id128
Steve Muir [Wed, 27 Jul 2016 21:19:37 +0000 (14:19 -0700)] 
tests: don't test hostname if it looks like an id128

The condition tests for hostname will fail if hostname looks like an id128.
The test function attempts to convert hostname to an id128, and if that
succeeds compare it to the machine ID (presumably because the 'hostname'
condition test is overloaded to also test machine ID). That will typically
fail, and unfortunately the 'mock' utility generates a random hostname that
happens to have the same format as an id128, thus causing a test failure.

7 years agotests: skip udev-test if running inside a chroot
Davide Cavalca [Wed, 27 Jul 2016 21:17:52 +0000 (14:17 -0700)] 
tests: skip udev-test if running inside a chroot

7 years agoMerge pull request #3742 from msoltyspl/vconfix2
Zbigniew Jędrzejewski-Szmek [Fri, 29 Jul 2016 03:59:06 +0000 (23:59 -0400)] 
Merge pull request #3742 from msoltyspl/vconfix2

vconsole-setup: updates & fixes V2

7 years agobuild-sys: conditionally disable LTO if requested (#3823)
Davide Cavalca [Fri, 29 Jul 2016 03:42:45 +0000 (20:42 -0700)] 
build-sys: conditionally disable LTO if requested (#3823)

This adds a --disable-lto option to ./configure, but does not change the
default behavior.

7 years agosystemctl: be sure to be quiet with 'systemctl is-enabled --quiet' (#3819)
Christian Rebischke [Thu, 28 Jul 2016 02:40:20 +0000 (04:40 +0200)] 
systemctl: be sure to be quiet with 'systemctl is-enabled --quiet' (#3819)

Fixes #3813.

7 years agohwdb: add Lenovo X260 pointing stick speed fix 3817/head
Dennis Wassenberg [Wed, 27 Jul 2016 09:01:27 +0000 (11:01 +0200)] 
hwdb: add Lenovo X260 pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the X260 models.

7 years agohwdb: add Lenovo T560 pointing stick speed fix
Dennis Wassenberg [Wed, 27 Jul 2016 09:00:56 +0000 (11:00 +0200)] 
hwdb: add Lenovo T560 pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the T560 models.

7 years agohwdb: add Lenovo T460s pointing stick speed fix
Dennis Wassenberg [Wed, 27 Jul 2016 09:00:27 +0000 (11:00 +0200)] 
hwdb: add Lenovo T460s pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the T460s models.

7 years agohwdb: add Lenovo L460 pointing stick speed fix
Dennis Wassenberg [Wed, 27 Jul 2016 08:59:38 +0000 (10:59 +0200)] 
hwdb: add Lenovo L460 pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the L460 models.

7 years agohwdb: add Lenovo X250 pointing stick speed fix
Dennis Wassenberg [Wed, 27 Jul 2016 08:56:50 +0000 (10:56 +0200)] 
hwdb: add Lenovo X250 pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the X250 models.

7 years agohwdb: add Lenovo T450s pointing stick speed fix
Dennis Wassenberg [Tue, 26 Jul 2016 14:50:07 +0000 (16:50 +0200)] 
hwdb: add Lenovo T450s pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the T450s models.

7 years agohwdb: add Lenovo L450 pointing stick speed fix
Dennis Wassenberg [Tue, 26 Jul 2016 14:47:54 +0000 (16:47 +0200)] 
hwdb: add Lenovo L450 pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the L450 models.

7 years agohwdb: add Lenovo T440p pointing stick speed fix
Dennis Wassenberg [Tue, 26 Jul 2016 14:41:47 +0000 (16:41 +0200)] 
hwdb: add Lenovo T440p pointing stick speed fix

Like many other recent thinkpads the factory default pointingstick
sensitivity on these devices is quite low, making the pointingstick
very slow in moving the cursor.

This extends the existing hwdb rules for tweaking the sensitivity to
also apply to the T440p models.

7 years agostring-util: rework memory_erase() to not use GCC optimize attribute (#3812)
Michael Biebl [Wed, 27 Jul 2016 03:32:37 +0000 (05:32 +0200)] 
string-util: rework memory_erase() to not use GCC optimize attribute (#3812)

"#pragma GCC optimize" is merely a convenience to decorate multiple
functions with attribute optimize. And the manual has this to say about
this attribute:

  This attribute should be used for debugging purposes only. It
  is not suitable in production code.

Some versions of GCC also seem to have a problem with this pragma in
combination with LTO, resulting in ICEs.

So use a different approach (indirect the memset call via a volatile
function pointer) as implemented in openssl's crypto/mem_clr.c.

Closes: #3811
7 years agovconsole: update man page 3742/head
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: update man page

- about namespace
- about udev rules

7 years agovconsole: correct kernel command line namespace
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: correct kernel command line namespace

7 years agovconsole: add copyright line
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: add copyright line

7 years agovconsole: Don't do static installation under sysinit.target
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: Don't do static installation under sysinit.target

Udev rules cover all the necessary initializations.

As the service now is neither installed, nor installable - we can
remove explicit dependencies and RemainAfterExit=yes option.

7 years agovconsole: use KD_FONT_OP_GET/SET to handle copying
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: use KD_FONT_OP_GET/SET to handle copying

We now use KD_FONT_OP_GET & KD_FONT_OP_SET instead of
problematic KD_FONT_OP_COPY.

7 years agovconsole: updates of keyboard/font loading functions
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: updates of keyboard/font loading functions

Change return convention to -errno/==0 and use isempty() instead
of just pointer tests.

7 years agovconsole: Add generic is_*() functions
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: Add generic is_*() functions

is_allocated() and is_allocated_byfd():

Checks if the console is allocated by its index (first function) or
its open descriptor (second function).

is_settable():

Checks if the console is in xlate or unicode mode, so we can adjust
is safely without interfering with X.

7 years agovconsole: add two new toggle functions, remove old enable/disable ones
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: add two new toggle functions, remove old enable/disable ones

Add toggle_utf8() and toggle_utf8_sysfs() and use them in place of old
enable/disable functions. toggle_utf8() also adds iutf8 setting and is
set up to be called per-console (in subsequent patches).

Note, that old disable_utf8() didn't bother checking if it was ok
to change the kbdmode.

7 years agovconsole: copy font to 63 consoles instead of 15
Michal Soltys [Tue, 26 Jul 2016 22:57:01 +0000 (00:57 +0200)] 
vconsole: copy font to 63 consoles instead of 15

We copy only to allocated consoles, so the cost of looping over
all possible ones is minuscule.