2013-12-13 20:29:35 +01:00
*.a
*.cache
*.html
*.la
*.lo
*.log
*.o
*.plist
*.pyc
*.stamp
2014-07-11 16:35:37 +02:00
*.swp
2013-12-13 20:29:35 +01:00
*.trs
*~
2014-11-24 15:39:00 +01:00
.config.args
2013-12-13 20:29:35 +01:00
.deps/
.dirstamp
.libs/
2014-07-07 10:04:33 +02:00
/*.gcda
/*.gcno
2013-12-13 20:29:35 +01:00
/*.tar.bz2
/*.tar.gz
/*.tar.xz
2012-12-01 10:37:52 +01:00
/Makefile
/TAGS
/accelerometer
/ata_id
2013-02-08 17:24:43 +01:00
/bootctl
2012-12-01 10:37:52 +01:00
/build-aux
2013-03-20 22:56:25 +01:00
/busctl
2012-12-01 10:37:52 +01:00
/cdrom_id
/collect
2014-06-19 13:46:01 +02:00
/coredumpctl
2013-03-28 14:54:06 +01:00
/coverage/
2013-12-13 20:29:35 +01:00
/defined
/exported
/exported-*
2012-12-01 10:37:52 +01:00
/gtk-doc.make
2012-10-17 21:23:30 +02:00
/hostnamectl
2012-09-28 00:46:32 +02:00
/install-tree
2012-04-13 21:36:37 +02:00
/journalctl
2014-01-25 23:35:28 -05:00
/libsystemd-*.c
2012-12-01 10:37:52 +01:00
/libtool
/localectl
/loginctl
2013-07-02 03:47:23 +02:00
/machinectl
2012-12-01 10:37:52 +01:00
/mtd_probe
2014-08-12 01:41:42 +02:00
/networkctl
2012-12-01 10:37:52 +01:00
/scsi_id
/systemadm
/systemctl
/systemd
2012-04-13 21:36:37 +02:00
/systemd-ac-power
2013-12-13 20:29:35 +01:00
/systemd-activate
2013-02-13 14:51:12 -08:00
/systemd-analyze
2012-12-01 10:37:52 +01:00
/systemd-ask-password
2013-08-14 01:57:02 +02:00
/systemd-backlight
2012-12-01 10:37:52 +01:00
/systemd-binfmt
2013-01-08 00:49:39 +01:00
/systemd-bootchart
2013-12-13 20:29:35 +01:00
/systemd-bus-proxyd
2012-12-01 10:37:52 +01:00
/systemd-cat
/systemd-cgls
/systemd-cgroups-agent
/systemd-cgtop
2014-10-03 15:58:44 +02:00
/systemd-consoled
2012-12-01 10:37:52 +01:00
/systemd-coredump
2012-04-13 21:36:37 +02:00
/systemd-cryptsetup
/systemd-cryptsetup-generator
2013-12-03 01:13:03 +01:00
/systemd-dbus1-generator
2014-06-19 16:10:55 +02:00
/systemd-debug-generator
2012-12-01 10:37:52 +01:00
/systemd-delta
/systemd-detect-virt
2013-01-21 01:02:53 +01:00
/systemd-efi-boot-generator
2014-07-07 22:23:00 +02:00
/systemd-escape
2014-08-27 18:38:01 +02:00
/systemd-evcat
2014-07-07 15:05:37 +02:00
/systemd-firstboot
2012-04-13 21:36:37 +02:00
/systemd-fsck
2012-12-01 10:37:52 +01:00
/systemd-fstab-generator
/systemd-getty-generator
2012-04-13 21:36:37 +02:00
/systemd-gnome-ask-password-agent
2013-08-13 10:13:45 +02:00
/systemd-gpt-auto-generator
2014-08-27 00:17:44 +04:00
/systemd-hibernate-resume
2014-08-27 00:17:45 +04:00
/systemd-hibernate-resume-generator
2012-12-01 10:37:52 +01:00
/systemd-hostnamed
/systemd-inhibit
/systemd-initctl
/systemd-journal-gatewayd
2014-03-25 23:05:52 +01:00
/systemd-journal-remote
2014-03-17 22:54:28 -04:00
/systemd-journal-upload
/systemd-journald
2012-04-13 21:36:37 +02:00
/systemd-kmsg-syslogd
2012-12-01 10:37:52 +01:00
/systemd-localed
/systemd-logind
2014-06-19 16:13:36 +02:00
/systemd-machine-id-setup
2014-03-17 22:54:28 -04:00
/systemd-machined
2014-09-19 14:48:54 +02:00
/systemd-modeset
2012-04-13 21:36:37 +02:00
/systemd-modules-load
2013-10-17 03:18:36 +02:00
/systemd-networkd
2014-03-01 07:39:14 -05:00
/systemd-networkd-wait-online
2012-12-01 10:37:52 +01:00
/systemd-notify
/systemd-nspawn
2014-07-02 12:23:36 +02:00
/systemd-path
2012-12-01 10:37:52 +01:00
/systemd-quotacheck
2012-04-13 21:36:37 +02:00
/systemd-random-seed
2012-12-01 10:37:52 +01:00
/systemd-rc-local-generator
/systemd-remount-api-vfs
/systemd-remount-fs
/systemd-reply-password
2014-07-16 22:55:23 +02:00
/systemd-resolve-host
2014-05-18 22:10:48 +02:00
/systemd-resolved
2013-10-14 04:31:49 +02:00
/systemd-rfkill
2013-06-28 04:12:58 +02:00
/systemd-run
2012-12-01 10:37:52 +01:00
/systemd-shutdown
/systemd-shutdownd
/systemd-sleep
2013-12-13 20:29:35 +01:00
/systemd-socket-proxyd
2014-07-17 11:10:53 +02:00
/systemd-subterm
2012-12-01 10:37:52 +01:00
/systemd-sysctl
/systemd-system-update-generator
sysusers: add minimal tool to reconstruct /etc/passwd and /etc/group from static files
systemd-sysusers is a tool to reconstruct /etc/passwd and /etc/group
from static definition files that take a lot of inspiration from
tmpfiles snippets. These snippets should carry information about system
users only. To make sure it is not misused for normal users these
snippets only allow configuring UID and gecos field for each user, but
do not allow configuration of the home directory or shell, which is
necessary for real login users.
The purpose of this tool is to enable state-less systems that can
populate /etc with the minimal files necessary, solely from static data
in /usr. systemd-sysuser is additive only, and will never override
existing users.
This tool will create these files directly, and not via some user
database abtsraction layer. This is appropriate as this tool is supposed
to run really early at boot, and is only useful for creating system
users, and system users cannot be stored in remote databases anyway.
The tool is also useful to be invoked from RPM scriptlets, instead of
useradd. This allows moving from imperative user descriptions in RPM to
declarative descriptions.
The UID/GID for a user/group to be created can either be chosen dynamic,
or fixed, or be read from the owner of a file in the file system, in
order to support reconstructing the correct IDs for files that shall be
owned by them.
This also adds a minimal user definition file, that should be
sufficient for most basic systems. Distributions are expected to patch
these files and augment the contents, for example with fixed UIDs for
the users where that's necessary.
2014-06-12 22:54:02 +02:00
/systemd-sysusers
2014-05-23 00:37:39 +02:00
/systemd-sysv-generator
2012-12-01 10:37:52 +01:00
/systemd-timedated
2014-04-28 14:45:42 +02:00
/systemd-timesyncd
2012-12-01 10:37:52 +01:00
/systemd-tmpfiles
/systemd-tty-ask-password-agent
/systemd-uaccess
/systemd-udevd
update-done: add minimal tool to manage system updates for /etc and /var, if /usr has changed
In order to support offline updates to /usr, we need to be able to run
certain tasks on next boot-up to bring /etc and /var in line with the
updated /usr. Hence, let's devise a mechanism how we can detect whether
/etc or /var are not up-to-date with /usr anymore: we keep "touch
files" in /etc/.updated and /var/.updated that are mtime-compared with
/usr. This means:
Whenever the vendor OS tree in /usr is updated, and any services that
shall be executed at next boot shall be triggered, it is sufficient to
update the mtime of /usr itself. At next boot, if /etc/.updated and/or
/var/.updated is older than than /usr (or missing), we know we have to
run the update tools once. After that is completed we need to update the
mtime of these files to the one of /usr, to keep track that we made the
necessary updates, and won't repeat them on next reboot.
A subsequent commit adds a new ConditionNeedsUpdate= condition that
allows checking on boot whether /etc or /var are outdated and need
updating.
This is an early step to allow booting up with an empty /etc, with
automatic rebuilding of the necessary cache files or user databases
therein, as well as supporting later updates of /usr that then propagate
to /etc and /var again.
2014-06-13 12:43:49 +02:00
/systemd-update-done
2012-04-13 21:36:37 +02:00
/systemd-update-utmp
2012-12-01 10:37:52 +01:00
/systemd-user-sessions
/systemd-vconsole-setup
/tags
2014-02-21 23:21:26 +01:00
/test-architecture
2014-06-22 14:53:24 +02:00
/test-async
shared: add generic IPC barrier
The "Barrier" object is a simple inter-process barrier implementation. It
allows placing synchronization points and waiting for the other side to
reach it. Additionally, it has an abortion-mechanism as second-layer
synchronization to send abortion-events asynchronously to the other side.
The API is usually used to synchronize processes during fork(). However,
it can be extended to pass state through execve() so you could synchronize
beyond execve().
Usually, it's used like this (error-handling replaced by assert() for
simplicity):
Barrier b;
r = barrier_init(&b);
assert_se(r >= 0);
pid = fork();
assert_se(pid >= 0);
if (pid == 0) {
barrier_set_role(&b, BARRIER_CHILD);
...do child post-setup...
if (CHILD_SETUP_FAILED)
exit(1);
...child setup done...
barrier_place(&b);
if (!barrier_sync(&b)) {
/* parent setup failed */
exit(1);
}
barrier_destroy(&b); /* redundant as execve() and exit() imply this */
/* parent & child setup successful */
execve(...);
}
barrier_set_role(&b, BARRIER_PARENT);
...do parent post-setup...
if (PARENT_SETUP_FAILED) {
barrier_abort(&b); /* send abortion event */
barrier_wait_abortion(&b); /* wait for child to abort (exit() implies abortion) */
barrier_destroy(&b);
...bail out...
}
...parent setup done...
barrier_place(&b);
if (!barrier_sync(&b)) {
...child setup failed... ;
barrier_destroy(&b);
...bail out...
}
barrier_destroy(&b);
...child setup successfull...
This is the most basic API. Using barrier_place() to place barriers and
barrier_sync() to perform a full synchronization between both processes.
barrier_abort() places an abortion barrier which superceeds any other
barriers, exit() (or barrier_destroy()) places an abortion-barrier that
queues behind existing barriers (thus *not* replacing existing barriers
unlike barrier_abort()).
This example uses hard-synchronization with wait_abortion(), sync() and
friends. These are all optional. Barriers are highly dynamic and can be
used for one-way synchronization or even no synchronization at all
(postponing it for later). The sync() call performs a full two-way
synchronization.
The API is documented and should be fairly self-explanatory. A test-suite
shows some special semantics regarding abortion, wait_next() and exit().
Internally, barriers use two eventfds and a pipe. The pipe is used to
detect exit()s of the remote side as eventfds do not allow that. The
eventfds are used to place barriers, one for each side. Barriers itself
are numbered, but the numbers are reused once both sides reached the same
barrier, thus you cannot address barriers by the index. Moreover, the
numbering is implicit and we only store a counter. This makes the
implementation itself very lightweight, which is probably negligible
considering that we need 3 FDs for a barrier..
Last but not least: This barrier implementation is quite heavy. It's
definitely not meant for fast IPC synchronization. However, it's very easy
to use. And given the *HUGE* overhead of fork(), the barrier-overhead
should be negligible.
2014-07-10 15:25:47 +02:00
/test-barrier
2013-09-23 17:23:35 -05:00
/test-boot-timestamp
2013-03-31 16:16:37 +02:00
/test-bus-chat
2014-06-19 16:13:36 +02:00
/test-bus-cleanup
2013-11-28 17:50:02 +01:00
/test-bus-creds
2013-11-22 14:30:52 +01:00
/test-bus-error
2013-12-13 20:29:35 +01:00
/test-bus-gvariant
2013-10-09 02:37:10 +02:00
/test-bus-introspect
2013-04-12 00:26:12 +02:00
/test-bus-kernel
2013-05-22 16:02:21 +02:00
/test-bus-kernel-benchmark
2013-12-13 20:29:35 +01:00
/test-bus-kernel-bloom
2013-03-19 20:03:16 +01:00
/test-bus-marshal
2013-03-31 16:16:37 +02:00
/test-bus-match
2013-10-09 02:37:10 +02:00
/test-bus-objects
2014-09-19 14:50:53 +02:00
/test-bus-policy
2013-03-30 15:30:23 +01:00
/test-bus-server
2013-12-13 20:29:35 +01:00
/test-bus-signature
2013-05-15 19:45:05 +02:00
/test-bus-zero-copy
2012-12-01 10:37:52 +01:00
/test-calendarspec
2014-06-22 14:53:24 +02:00
/test-capability
2012-12-01 10:37:52 +01:00
/test-catalog
2012-04-13 21:36:37 +02:00
/test-cgroup
2013-11-11 19:03:31 +10:00
/test-cgroup-mask
2013-01-19 04:20:23 +01:00
/test-cgroup-util
2014-06-24 20:42:29 +02:00
/test-compress
compress: add benchmark-style test
This is useful to test the behaviour of the compressor for various buffer
sizes.
Time is limited to a minute per compression, since otherwise, when LZ4
takes more than a second which is necessary to reduce the noise, XZ
takes more than 10 minutes.
% build/test-compress-benchmark (without time limit)
XZ: compressed & decompressed 2535300963 bytes in 794.57s (3.04MiB/s), mean compresion 99.95%, skipped 3570 bytes
LZ4: compressed & decompressed 2535303543 bytes in 1.56s (1550.07MiB/s), mean compresion 99.60%, skipped 990 bytes
% build/test-compress-benchmark (with time limit)
XZ: compressed & decompressed 174321481 bytes in 60.02s (2.77MiB/s), mean compresion 99.76%, skipped 3570 bytes
LZ4: compressed & decompressed 2535303543 bytes in 1.63s (1480.83MiB/s), mean compresion 99.60%, skipped 990 bytes
It appears that there's a bug in lzma_end where it leaks 32 bytes.
2014-07-05 14:29:56 -04:00
/test-compress-benchmark
2014-11-06 14:19:05 +01:00
/test-condition
2014-06-19 19:07:05 -07:00
/test-conf-files
2014-10-29 22:28:50 +01:00
/test-copy
2014-06-27 18:57:24 +02:00
/test-coredump-vacuum
2012-04-13 21:36:37 +02:00
/test-daemon
2012-12-01 10:37:52 +01:00
/test-date
2013-09-18 12:12:04 -04:00
/test-device-nodes
2013-12-13 02:43:35 +01:00
/test-dhcp-client
/test-dhcp-option
2014-06-19 16:13:36 +02:00
/test-dhcp-server
2014-06-19 16:57:10 +02:00
/test-dhcp6-client
2014-10-31 00:02:57 +01:00
/test-pppoe
2014-07-16 00:26:02 +02:00
/test-dns-domain
2014-06-19 16:57:10 +02:00
/test-icmp6-rs
2013-10-14 19:02:11 +02:00
/test-ellipsize
2012-04-13 21:36:37 +02:00
/test-engine
2012-12-01 10:37:52 +01:00
/test-env-replace
2013-10-10 04:40:28 +02:00
/test-event
2014-11-11 20:05:40 +01:00
/test-execute
2014-06-14 22:10:45 +02:00
/test-fdset
2013-04-03 19:04:03 +02:00
/test-fileio
2013-05-10 14:34:57 +02:00
/test-hashmap
2012-12-01 10:37:52 +01:00
/test-hostname
/test-id128
/test-inhibit
/test-install
2014-03-14 01:38:19 +01:00
/test-ipcrm
2014-04-28 14:45:42 +02:00
/test-ipv4ll
2012-04-13 21:36:37 +02:00
/test-job-type
2012-12-01 10:37:52 +01:00
/test-journal
/test-journal-enum
2013-11-27 01:01:53 +01:00
/test-journal-flush
2013-12-13 20:29:35 +01:00
/test-journal-init
2013-06-12 13:05:15 +02:00
/test-journal-interleaving
2012-12-01 10:37:52 +01:00
/test-journal-match
/test-journal-send
/test-journal-stream
/test-journal-syslog
/test-journal-verify
2014-01-13 17:30:51 +01:00
/test-libsystemd-sym*
2012-12-01 10:37:52 +01:00
/test-libudev
2013-12-13 20:29:35 +01:00
/test-libudev-sym*
2013-06-26 13:43:16 +02:00
/test-list
2014-11-01 14:04:17 +01:00
/test-unaligned
2014-10-12 18:05:10 +02:00
/test-locale-util
2012-12-01 10:37:52 +01:00
/test-log
/test-login
2013-09-17 15:39:09 -04:00
/test-login-shared
2013-12-13 20:29:35 +01:00
/test-login-tables
2012-12-01 10:37:52 +01:00
/test-loopback
2013-12-13 20:29:35 +01:00
/test-machine-tables
2012-12-01 10:37:52 +01:00
/test-mmap-cache
2013-10-23 14:10:02 -04:00
/test-namespace
2013-10-17 03:18:36 +02:00
/test-network
2014-07-09 22:29:24 -04:00
/test-network-tables
2012-12-01 10:37:52 +01:00
/test-ns
2014-11-05 21:27:01 +01:00
/test-path
2013-03-30 15:06:51 +01:00
/test-path-util
2013-03-21 02:42:28 +01:00
/test-prioq
2014-06-23 21:28:22 +02:00
/test-ratelimit
2014-07-11 16:29:56 +02:00
/test-pty
2012-12-01 10:37:52 +01:00
/test-replace-var
2014-06-19 16:13:36 +02:00
/test-resolve
2014-05-13 20:08:18 +02:00
/test-ring
2013-10-21 19:12:52 +01:00
/test-rtnl
2014-06-19 16:13:36 +02:00
/test-rtnl-manual
2012-11-01 18:48:11 +01:00
/test-sched-prio
2014-10-01 23:22:02 +02:00
/test-set
2012-12-01 10:37:52 +01:00
/test-sleep
2014-06-14 22:10:44 +02:00
/test-socket-util
2014-05-16 20:14:23 +02:00
/test-ssd
2013-02-09 01:39:44 +01:00
/test-strbuf
2013-12-13 20:29:35 +01:00
/test-strip-tab-ansi
2012-12-01 10:37:52 +01:00
/test-strv
2013-02-10 21:56:03 +01:00
/test-strxcpyx
2013-07-05 00:25:26 -04:00
/test-tables
2014-06-12 17:51:14 +02:00
/test-term-page
2014-06-15 14:50:00 +02:00
/test-term-parser
2013-04-03 22:58:41 +02:00
/test-time
2014-01-25 23:35:28 -05:00
/test-tmpfiles
2012-12-01 10:37:52 +01:00
/test-udev
2014-08-19 19:05:11 +02:00
/test-uid-range
2014-07-18 17:34:03 +02:00
/test-unifont
2012-12-01 10:37:52 +01:00
/test-unit-file
/test-unit-name
2013-09-17 15:39:09 -04:00
/test-utf8
2013-02-06 21:15:23 +01:00
/test-util
2012-12-01 10:37:52 +01:00
/test-watchdog
2013-12-28 03:03:50 +01:00
/test-xml
2012-12-01 10:37:52 +01:00
/timedatectl
/udevadm
2013-12-13 20:29:35 +01:00
/undefined
2012-12-01 10:37:52 +01:00
/v4l_id
2010-02-03 14:21:48 +01:00
Makefile.in
2013-12-13 20:29:35 +01:00
__pycache__/
2010-02-03 14:21:48 +01:00
aclocal.m4
config.h
config.h.in
config.log
config.status
configure
stamp-*