2020-11-09 07:23:58 +03:00
# SPDX-License-Identifier: LGPL-2.1-or-later
2017-11-18 20:32:01 +03:00
2020-04-29 00:11:55 +03:00
with_runlevels = conf . get ( 'HAVE_SYSV_COMPAT' ) == 1
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
units = [
2017-04-18 02:25:00 +03:00
[ 'basic.target' , '' ] ,
2019-12-19 19:38:55 +03:00
[ 'blockdev@.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'bluetooth.target' , '' ] ,
2018-06-22 13:52:28 +03:00
[ 'boot-complete.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'cryptsetup-pre.target' , 'HAVE_LIBCRYPTSETUP' ] ,
[ 'cryptsetup.target' , 'HAVE_LIBCRYPTSETUP' ,
'sysinit.target.wants/' ] ,
veritysetup-generator: add support for veritytab
This adds the support for veritytab.
The veritytab file contains at most five fields, the first four are
mandatory, the last one is optional:
- The first field contains the name of the resulting verity volume; its
block device is set up /dev/mapper/</filename>.
- The second field contains a path to the underlying block data device,
or a specification of a block device via UUID= followed by the UUID.
- The third field contains a path to the underlying block hash device,
or a specification of a block device via UUID= followed by the UUID.
- The fourth field is the roothash in hexadecimal.
- The fifth field, if present, is a comma-delimited list of options.
The following options are recognized only: ignore-corruption,
restart-on-corruption, panic-on-corruption, ignore-zero-blocks,
check-at-most-once and root-hash-signature. The others options will
be implemented later.
Also, this adds support for the new kernel verity command line boolean
option "veritytab" which enables the read for veritytab, and the new
environment variable SYSTEMD_VERITYTAB which sets the path to the file
veritytab to read.
2020-11-14 17:21:39 +03:00
[ 'veritysetup-pre.target' , 'HAVE_LIBCRYPTSETUP' ] ,
[ 'veritysetup.target' , 'HAVE_LIBCRYPTSETUP' ,
'sysinit.target.wants/' ] ,
2021-09-26 19:53:42 +03:00
[ 'integritysetup-pre.target' , 'HAVE_LIBCRYPTSETUP' ] ,
[ 'integritysetup.target' , 'HAVE_LIBCRYPTSETUP' ,
'sysinit.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'dev-hugepages.mount' , '' ,
'sysinit.target.wants/' ] ,
[ 'dev-mqueue.mount' , '' ,
'sysinit.target.wants/' ] ,
[ 'emergency.target' , '' ] ,
[ 'exit.target' , '' ] ,
2021-07-25 05:20:27 +03:00
[ 'factory-reset.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'final.target' , '' ] ,
2020-09-06 22:23:36 +03:00
[ 'first-boot-complete.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'getty.target' , '' ,
'multi-user.target.wants/' ] ,
2017-08-31 12:20:14 +03:00
[ 'getty-pre.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'graphical.target' , '' ,
2020-10-27 12:49:11 +03:00
'default.target' + ( with_runlevels ? ' runlevel5.target' : '' ) ] ,
2017-04-18 02:25:00 +03:00
[ 'halt.target' , '' ] ,
[ 'hibernate.target' , 'ENABLE_HIBERNATE' ] ,
[ 'hybrid-sleep.target' , 'ENABLE_HIBERNATE' ] ,
2019-04-01 14:57:07 +03:00
[ 'suspend-then-hibernate.target' , 'ENABLE_HIBERNATE' ] ,
2020-04-09 00:59:13 +03:00
[ 'initrd-cleanup.service' , 'ENABLE_INITRD' ] ,
[ 'initrd-fs.target' , 'ENABLE_INITRD' ] ,
[ 'initrd-root-device.target' , 'ENABLE_INITRD' ] ,
[ 'initrd-root-fs.target' , 'ENABLE_INITRD' ] ,
[ 'initrd-switch-root.service' , 'ENABLE_INITRD' ] ,
[ 'initrd-switch-root.target' , 'ENABLE_INITRD' ] ,
[ 'initrd-udevadm-cleanup-db.service' , 'ENABLE_INITRD' ] ,
2021-03-27 00:40:40 +03:00
[ 'initrd-usr-fs.target' , 'ENABLE_INITRD' ] ,
2020-04-09 00:59:13 +03:00
[ 'initrd.target' , 'ENABLE_INITRD' ] ,
2017-04-18 02:25:00 +03:00
[ 'kexec.target' , '' ] ,
[ 'ldconfig.service' , 'ENABLE_LDCONFIG' ,
'sysinit.target.wants/' ] ,
[ 'local-fs-pre.target' , '' ] ,
[ 'local-fs.target' , '' ] ,
[ 'machine.slice' , 'ENABLE_MACHINED' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'machines.target' , 'ENABLE_MACHINED' ] ,
2020-01-07 17:33:29 +03:00
[ 'modprobe@.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'multi-user.target' , '' ,
2020-04-29 00:11:55 +03:00
( with_runlevels ? 'runlevel2.target runlevel3.target runlevel4.target' : '' ) ] ,
2017-04-18 02:25:00 +03:00
[ 'network-online.target' , '' ] ,
[ 'network-pre.target' , '' ] ,
[ 'network.target' , '' ] ,
[ 'nss-lookup.target' , '' ] ,
[ 'nss-user-lookup.target' , '' ] ,
[ 'paths.target' , '' ] ,
[ 'poweroff.target' , '' ,
2020-04-29 00:11:55 +03:00
( with_runlevels ? 'runlevel0.target' : '' ) ] ,
2017-04-18 02:25:00 +03:00
[ 'printer.target' , '' ] ,
[ 'proc-sys-fs-binfmt_misc.automount' , 'ENABLE_BINFMT' ,
'sysinit.target.wants/' ] ,
[ 'proc-sys-fs-binfmt_misc.mount' , 'ENABLE_BINFMT' ] ,
[ 'reboot.target' , '' ,
2020-10-27 12:49:11 +03:00
'ctrl-alt-del.target' + ( with_runlevels ? ' runlevel6.target' : '' ) ] ,
2020-10-27 15:29:38 +03:00
[ 'remote-cryptsetup.target' , 'HAVE_LIBCRYPTSETUP' ,
'initrd-root-device.target.wants/' ] ,
veritysetup-generator: add support for veritytab
This adds the support for veritytab.
The veritytab file contains at most five fields, the first four are
mandatory, the last one is optional:
- The first field contains the name of the resulting verity volume; its
block device is set up /dev/mapper/</filename>.
- The second field contains a path to the underlying block data device,
or a specification of a block device via UUID= followed by the UUID.
- The third field contains a path to the underlying block hash device,
or a specification of a block device via UUID= followed by the UUID.
- The fourth field is the roothash in hexadecimal.
- The fifth field, if present, is a comma-delimited list of options.
The following options are recognized only: ignore-corruption,
restart-on-corruption, panic-on-corruption, ignore-zero-blocks,
check-at-most-once and root-hash-signature. The others options will
be implemented later.
Also, this adds support for the new kernel verity command line boolean
option "veritytab" which enables the read for veritytab, and the new
environment variable SYSTEMD_VERITYTAB which sets the path to the file
veritytab to read.
2020-11-14 17:21:39 +03:00
[ 'remote-veritysetup.target' , 'HAVE_LIBCRYPTSETUP' ,
'initrd-root-device.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'remote-fs-pre.target' , '' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'remote-fs.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'rescue.target' , '' ,
2020-04-29 00:11:55 +03:00
( with_runlevels ? 'runlevel1.target' : '' ) ] ,
2017-04-18 02:25:00 +03:00
[ 'rpcbind.target' , '' ] ,
[ 'shutdown.target' , '' ] ,
[ 'sigpwr.target' , '' ] ,
[ 'sleep.target' , '' ] ,
[ 'slices.target' , '' ] ,
[ 'smartcard.target' , '' ] ,
[ 'sockets.target' , '' ] ,
[ 'sound.target' , '' ] ,
[ 'suspend.target' , '' ] ,
[ 'swap.target' , '' ] ,
[ 'sys-fs-fuse-connections.mount' , '' ,
'sysinit.target.wants/' ] ,
[ 'sys-kernel-config.mount' , '' ,
'sysinit.target.wants/' ] ,
[ 'sys-kernel-debug.mount' , '' ,
'sysinit.target.wants/' ] ,
2020-02-21 17:08:13 +03:00
[ 'sys-kernel-tracing.mount' , '' ,
'sysinit.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'sysinit.target' , '' ] ,
[ 'syslog.socket' , '' ] ,
2019-12-03 11:30:57 +03:00
[ 'system-systemd\\x2dcryptsetup.slice' , 'HAVE_LIBCRYPTSETUP' ] ,
2017-04-18 02:25:00 +03:00
[ 'system-update.target' , '' ] ,
2018-06-19 11:50:41 +03:00
[ 'system-update-pre.target' , '' ] ,
2018-04-17 20:49:10 +03:00
[ 'system-update-cleanup.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-ask-password-console.path' , '' ,
'sysinit.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-ask-password-console.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-ask-password-wall.path' , '' ,
'multi-user.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-ask-password-wall.service' , '' ] ,
2021-08-30 19:38:09 +03:00
[ 'systemd-boot-system-token.service' , 'HAVE_GNU_EFI' ,
2019-12-18 11:14:57 +03:00
'sysinit.target.wants/' ] ,
2021-09-20 18:46:26 +03:00
[ 'systemd-boot-update.service' , 'HAVE_GNU_EFI' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-coredump.socket' , 'ENABLE_COREDUMP' ,
'sockets.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-exit.service' , '' ] ,
[ 'systemd-firstboot.service' , 'ENABLE_FIRSTBOOT' ,
'sysinit.target.wants/' ] ,
[ 'systemd-halt.service' , '' ] ,
2020-09-21 19:25:46 +03:00
[ 'systemd-homed-activate.service' , 'ENABLE_HOMED' ] ,
2020-04-29 00:11:55 +03:00
[ 'systemd-initctl.socket' , 'HAVE_SYSV_COMPAT' ,
2017-04-18 02:25:00 +03:00
'sockets.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-journal-catalog-update.service' , '' ,
'sysinit.target.wants/' ] ,
[ 'systemd-journal-flush.service' , '' ,
'sysinit.target.wants/' ] ,
2017-04-27 20:47:04 +03:00
[ 'systemd-journal-gatewayd.socket' , 'ENABLE_REMOTE HAVE_MICROHTTPD' ] ,
[ 'systemd-journal-remote.socket' , 'ENABLE_REMOTE HAVE_MICROHTTPD' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-journald-audit.socket' , '' ,
'sockets.target.wants/' ] ,
[ 'systemd-journald-dev-log.socket' , '' ,
'sockets.target.wants/' ] ,
[ 'systemd-journald.socket' , '' ,
'sockets.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-kexec.service' , '' ] ,
[ 'systemd-machine-id-commit.service' , '' ,
'sysinit.target.wants/' ] ,
2019-11-25 17:37:35 +03:00
[ 'systemd-journald@.socket' , '' ] ,
2019-11-27 16:47:37 +03:00
[ 'systemd-journald-varlink@.socket' , '' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'systemd-networkd.socket' , 'ENABLE_NETWORKD' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-poweroff.service' , '' ] ,
[ 'systemd-reboot.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-rfkill.socket' , 'ENABLE_RFKILL' ] ,
2021-01-19 20:23:57 +03:00
[ 'systemd-sysext.service' , 'ENABLE_SYSEXT' ] ,
2021-06-16 13:00:34 +03:00
[ 'systemd-sysupdate.timer' , 'ENABLE_SYSUPDATE' ] ,
[ 'systemd-sysupdate-reboot.timer' , 'ENABLE_SYSUPDATE' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-sysusers.service' , 'ENABLE_SYSUSERS' ,
'sysinit.target.wants/' ] ,
[ 'systemd-tmpfiles-clean.service' , 'ENABLE_TMPFILES' ] ,
2019-11-22 11:20:20 +03:00
[ 'systemd-tmpfiles-clean.timer' , 'ENABLE_TMPFILES' ,
2017-04-18 02:25:00 +03:00
'timers.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-tmpfiles-setup-dev.service' , 'ENABLE_TMPFILES' ,
'sysinit.target.wants/' ] ,
[ 'systemd-tmpfiles-setup.service' , 'ENABLE_TMPFILES' ,
'sysinit.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-udevd-control.socket' , '' ,
'sockets.target.wants/' ] ,
2019-12-18 11:14:57 +03:00
[ 'systemd-udev-settle.service' , '' ] ,
[ 'systemd-udev-trigger.service' , '' ,
'sysinit.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-udevd-kernel.socket' , '' ,
'sockets.target.wants/' ] ,
2020-03-13 20:40:54 +03:00
[ 'systemd-userdbd.socket' , 'ENABLE_USERDB' ] ,
2018-04-30 15:05:29 +03:00
[ 'time-set.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'time-sync.target' , '' ] ,
[ 'timers.target' , '' ] ,
2017-08-09 16:13:41 +03:00
[ 'tmp.mount' , '' ,
'local-fs.target.wants/' ] ,
2017-04-18 02:25:00 +03:00
[ 'umount.target' , '' ] ,
2020-08-28 16:36:35 +03:00
[ 'usb-gadget.target' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'user.slice' , '' ] ,
2017-06-21 23:04:38 +03:00
[ 'var-lib-machines.mount' , 'ENABLE_MACHINED' ,
'remote-fs.target.wants/ machines.target.wants/' ] ,
2021-09-09 18:12:55 +03:00
[ 'systemd-oomd.socket' , 'ENABLE_OOMD' ] ,
2017-04-13 03:58:55 +03:00
]
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
in_units = [
2021-05-16 12:55:36 +03:00
[ 'console-getty.service' , '' ] ,
[ 'container-getty@.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'debug-shell.service' , '' ] ,
[ 'emergency.service' , '' ] ,
2021-05-16 12:55:36 +03:00
[ 'getty@.service' , '' ,
'autovt@.service' ] ,
units/initrd-parse-etc.service: only start units that are required
This makes use of the option switch that was added in the previous commit.
We used a pretty big hammer on a relatively small nail: we would do daemon-reload
and (in principle) allow any configuration to be changed. But in fact we only
made use of this in systemd-fstab-generator. systemd-fstab-generator filters
out all mountpoints except /usr and those marked with x-initrd.mount, i.e. on
a big majority of systems it wouldn't do anything.
Also, since systemd-fstab-generator first parses /proc/cmdline, and then
initrd's /etc/fstab, and only then /sysroot/etc/fstab, configuration in the
host would only matter if it the same mountpoint wasn't configured "earlier".
So the config in the host could be used for new mountpoints, but it couldn't
be used to amend configuration for existing mountpoints. And we wouldn't actually
remount anything, so mountpoints that were already mounted wouldn't be affected,
even if did change some config.
In the new scheme, we will parse /sysroot/etc/fstab and explicitly start
sysroot-usr.mount and other units that we just wrote. In most cases (as written
above), this will actually result in no units being created or started.
If the generator is invoked on a system with /sysroot/etc/fstab present,
behaviour is not changed and we'll create units as before. This is needed so
that if daemon-reload is later at some points, we don't "lose" those units.
There's a minor bugfix here: we honour x-initrd.mount for swaps, but we
wouldn't restart swap.target, i.e. the new swaps wouldn't necessarilly be
pulled in immediately.
2022-07-14 19:05:55 +03:00
[ 'initrd-parse-etc.service' , 'ENABLE_INITRD' ] ,
2017-04-18 02:25:00 +03:00
[ 'kmod-static-nodes.service' , 'HAVE_KMOD ENABLE_TMPFILES' ,
'sysinit.target.wants/' ] ,
[ 'quotaon.service' , 'ENABLE_QUOTACHECK' ] ,
[ 'rc-local.service' , 'HAVE_SYSV_COMPAT' ] ,
[ 'rescue.service' , '' ] ,
2021-05-16 12:55:36 +03:00
[ 'serial-getty@.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-backlight@.service' , 'ENABLE_BACKLIGHT' ] ,
[ 'systemd-binfmt.service' , 'ENABLE_BINFMT' ,
'sysinit.target.wants/' ] ,
2021-09-21 23:47:42 +03:00
[ 'systemd-bless-boot.service' , 'HAVE_GNU_EFI HAVE_BLKID' ] ,
2018-06-25 17:07:33 +03:00
[ 'systemd-boot-check-no-failures.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-coredump@.service' , 'ENABLE_COREDUMP' ] ,
pstore: Tool to archive contents of pstore
This patch introduces the systemd pstore service which will archive the
contents of the Linux persistent storage filesystem, pstore, to other storage,
thus preserving the existing information contained in the pstore, and clearing
pstore storage for future error events.
Linux provides a persistent storage file system, pstore[1], that can store
error records when the kernel dies (or reboots or powers-off). These records in
turn can be referenced to debug kernel problems (currently the kernel stuffs
the tail of the dmesg, which also contains a stack backtrace, into pstore).
The pstore file system supports a variety of backends that map onto persistent
storage, such as the ACPI ERST[2, Section 18.5 Error Serialization] and UEFI
variables[3 Appendix N Common Platform Error Record]. The pstore backends
typically offer a relatively small amount of persistent storage, e.g. 64KiB,
which can quickly fill up and thus prevent subsequent kernel crashes from
recording errors. Thus there is a need to monitor and extract the pstore
contents so that future kernel problems can also record information in the
pstore.
The pstore service is independent of the kdump service. In cloud environments
specifically, host and guest filesystems are on remote filesystems (eg. iSCSI
or NFS), thus kdump relies [implicitly and/or explicitly] upon proper operation
of networking software *and* hardware *and* infrastructure. Thus it may not be
possible to capture a kernel coredump to a file since writes over the network
may not be possible.
The pstore backend, on the other hand, is completely local and provides a path
to store error records which will survive a reboot and aid in post-mortem
debugging.
Usage Notes:
This tool moves files from /sys/fs/pstore into /var/lib/systemd/pstore.
To enable kernel recording of error records into pstore, one must either pass
crash_kexec_post_notifiers[4] to the kernel command line or enable via 'echo Y
> /sys/module/kernel/parameters/crash_kexec_post_notifiers'. This option
invokes the recording of errors into pstore *before* an attempt to kexec/kdump
on a kernel crash.
Optionally, to record reboots and shutdowns in the pstore, one can either pass
the printk.always_kmsg_dump[4] to the kernel command line or enable via 'echo Y >
/sys/module/printk/parameters/always_kmsg_dump'. This option enables code on the
shutdown path to record information via pstore.
This pstore service is a oneshot service. When run, the service invokes
systemd-pstore which is a tool that performs the following:
- reads the pstore.conf configuration file
- collects the lists of files in the pstore (eg. /sys/fs/pstore)
- for certain file types (eg. dmesg) a handler is invoked
- for all other files, the file is moved from pstore
- In the case of dmesg handler, final processing occurs as such:
- files processed in reverse lexigraphical order to faciliate
reconstruction of original dmesg
- the filename is examined to determine which dmesg it is a part
- the file is appended to the reconstructed dmesg
For example, the following pstore contents:
root@vm356:~# ls -al /sys/fs/pstore
total 0
drwxr-x--- 2 root root 0 May 9 09:50 .
drwxr-xr-x 7 root root 0 May 9 09:50 ..
-r--r--r-- 1 root root 1610 May 9 09:49 dmesg-efi-155741337601001
-r--r--r-- 1 root root 1778 May 9 09:49 dmesg-efi-155741337602001
-r--r--r-- 1 root root 1726 May 9 09:49 dmesg-efi-155741337603001
-r--r--r-- 1 root root 1746 May 9 09:49 dmesg-efi-155741337604001
-r--r--r-- 1 root root 1686 May 9 09:49 dmesg-efi-155741337605001
-r--r--r-- 1 root root 1690 May 9 09:49 dmesg-efi-155741337606001
-r--r--r-- 1 root root 1775 May 9 09:49 dmesg-efi-155741337607001
-r--r--r-- 1 root root 1811 May 9 09:49 dmesg-efi-155741337608001
-r--r--r-- 1 root root 1817 May 9 09:49 dmesg-efi-155741337609001
-r--r--r-- 1 root root 1795 May 9 09:49 dmesg-efi-155741337710001
-r--r--r-- 1 root root 1770 May 9 09:49 dmesg-efi-155741337711001
-r--r--r-- 1 root root 1796 May 9 09:49 dmesg-efi-155741337712001
-r--r--r-- 1 root root 1787 May 9 09:49 dmesg-efi-155741337713001
-r--r--r-- 1 root root 1808 May 9 09:49 dmesg-efi-155741337714001
-r--r--r-- 1 root root 1754 May 9 09:49 dmesg-efi-155741337715001
results in the following:
root@vm356:~# ls -al /var/lib/systemd/pstore/155741337/
total 92
drwxr-xr-x 2 root root 4096 May 9 09:50 .
drwxr-xr-x 4 root root 40 May 9 09:50 ..
-rw-r--r-- 1 root root 1610 May 9 09:50 dmesg-efi-155741337601001
-rw-r--r-- 1 root root 1778 May 9 09:50 dmesg-efi-155741337602001
-rw-r--r-- 1 root root 1726 May 9 09:50 dmesg-efi-155741337603001
-rw-r--r-- 1 root root 1746 May 9 09:50 dmesg-efi-155741337604001
-rw-r--r-- 1 root root 1686 May 9 09:50 dmesg-efi-155741337605001
-rw-r--r-- 1 root root 1690 May 9 09:50 dmesg-efi-155741337606001
-rw-r--r-- 1 root root 1775 May 9 09:50 dmesg-efi-155741337607001
-rw-r--r-- 1 root root 1811 May 9 09:50 dmesg-efi-155741337608001
-rw-r--r-- 1 root root 1817 May 9 09:50 dmesg-efi-155741337609001
-rw-r--r-- 1 root root 1795 May 9 09:50 dmesg-efi-155741337710001
-rw-r--r-- 1 root root 1770 May 9 09:50 dmesg-efi-155741337711001
-rw-r--r-- 1 root root 1796 May 9 09:50 dmesg-efi-155741337712001
-rw-r--r-- 1 root root 1787 May 9 09:50 dmesg-efi-155741337713001
-rw-r--r-- 1 root root 1808 May 9 09:50 dmesg-efi-155741337714001
-rw-r--r-- 1 root root 1754 May 9 09:50 dmesg-efi-155741337715001
-rw-r--r-- 1 root root 26754 May 9 09:50 dmesg.txt
where dmesg.txt is reconstructed from the group of related
dmesg-efi-155741337* files.
Configuration file:
The pstore.conf configuration file has four settings, described below.
- Storage : one of "none", "external", or "journal". With "none", this
tool leaves the contents of pstore untouched. With "external", the
contents of the pstore are moved into the /var/lib/systemd/pstore,
as well as logged into the journal. With "journal", the contents of
the pstore are recorded only in the systemd journal. The default is
"external".
- Unlink : is a boolean. When "true", the default, then files in the
pstore are removed once processed. When "false", processing of the
pstore occurs normally, but the pstore files remain.
References:
[1] "Persistent storage for a kernel's dying breath",
March 23, 2011.
https://lwn.net/Articles/434821/
[2] "Advanced Configuration and Power Interface Specification",
version 6.2, May 2017.
https://www.uefi.org/sites/default/files/resources/ACPI_6_2.pdf
[3] "Unified Extensible Firmware Interface Specification",
version 2.8, March 2019.
https://uefi.org/sites/default/files/resources/UEFI_Spec_2_8_final.pdf
[4] "The kernel’s command-line parameters",
https://static.lwn.net/kerneldoc/admin-guide/kernel-parameters.html
2019-05-16 16:59:01 +03:00
[ 'systemd-pstore.service' , 'ENABLE_PSTORE' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-fsck-root.service' , '' ] ,
[ 'systemd-fsck@.service' , '' ] ,
[ 'systemd-hibernate-resume@.service' , 'ENABLE_HIBERNATE' ] ,
[ 'systemd-hibernate.service' , 'ENABLE_HIBERNATE' ] ,
[ 'systemd-hybrid-sleep.service' , 'ENABLE_HIBERNATE' ] ,
2018-03-28 19:00:06 +03:00
[ 'systemd-suspend-then-hibernate.service' , 'ENABLE_HIBERNATE' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-hostnamed.service' , 'ENABLE_HOSTNAMED' ,
'dbus-org.freedesktop.hostname1.service' ] ,
[ 'systemd-hwdb-update.service' , 'ENABLE_HWDB' ,
'sysinit.target.wants/' ] ,
[ 'systemd-importd.service' , 'ENABLE_IMPORTD' ,
'dbus-org.freedesktop.import1.service' ] ,
2020-07-14 01:49:25 +03:00
[ 'systemd-initctl.service' , 'HAVE_SYSV_COMPAT' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-journal-gatewayd.service' , 'ENABLE_REMOTE HAVE_MICROHTTPD' ] ,
[ 'systemd-journal-remote.service' , 'ENABLE_REMOTE HAVE_MICROHTTPD' ] ,
[ 'systemd-journal-upload.service' , 'ENABLE_REMOTE HAVE_LIBCURL' ] ,
[ 'systemd-journald.service' , '' ,
'sysinit.target.wants/' ] ,
2019-11-25 17:37:35 +03:00
[ 'systemd-journald@.service' , '' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-localed.service' , 'ENABLE_LOCALED' ,
'dbus-org.freedesktop.locale1.service' ] ,
[ 'systemd-logind.service' , 'ENABLE_LOGIND' ,
'multi-user.target.wants/ dbus-org.freedesktop.login1.service' ] ,
[ 'systemd-machined.service' , 'ENABLE_MACHINED' ,
'dbus-org.freedesktop.machine1.service' ] ,
[ 'systemd-modules-load.service' , 'HAVE_KMOD' ,
'sysinit.target.wants/' ] ,
2021-12-15 19:51:22 +03:00
[ 'systemd-network-generator.service' , '' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'systemd-networkd.service' , 'ENABLE_NETWORKD' ] ,
[ 'systemd-networkd-wait-online.service' , 'ENABLE_NETWORKD' ] ,
2022-01-28 09:30:01 +03:00
[ 'systemd-networkd-wait-online@.service' , 'ENABLE_NETWORKD' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-nspawn@.service' , '' ] ,
2022-01-12 10:16:45 +03:00
[ 'systemd-oomd.service' , 'ENABLE_OOMD' ] ,
2018-04-16 22:41:40 +03:00
[ 'systemd-portabled.service' , 'ENABLE_PORTABLED' ,
'dbus-org.freedesktop.portable1.service' ] ,
2019-07-04 19:33:30 +03:00
[ 'systemd-userdbd.service' , 'ENABLE_USERDB' ] ,
2020-03-13 20:38:09 +03:00
[ 'systemd-homed.service' , 'ENABLE_HOMED' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-quotacheck.service' , 'ENABLE_QUOTACHECK' ] ,
[ 'systemd-random-seed.service' , 'ENABLE_RANDOMSEED' ,
'sysinit.target.wants/' ] ,
2018-12-20 17:52:52 +03:00
[ 'systemd-remount-fs.service' , '' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'systemd-resolved.service' , 'ENABLE_RESOLVE' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-rfkill.service' , 'ENABLE_RFKILL' ] ,
[ 'systemd-suspend.service' , '' ] ,
[ 'systemd-sysctl.service' , '' ,
'sysinit.target.wants/' ] ,
2021-06-16 13:00:34 +03:00
[ 'systemd-sysupdate.service' , 'ENABLE_SYSUPDATE' ] ,
[ 'systemd-sysupdate-reboot.service' , 'ENABLE_SYSUPDATE' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-timedated.service' , 'ENABLE_TIMEDATED' ,
'dbus-org.freedesktop.timedate1.service' ] ,
meson: stop creating enablement symlinks in /etc during installation
This patch was initially prompted by a report on a Fedora update [1], that the
upgrade causes systemd-resolved.service and systemd-networkd.service to be
re-enabled. We generally want to preserve the enablement of all services during
upgrades, so a reset like this is not expected.
Both services declare two symlinks in their [Install] sections, for their dbus
names and for multi-user.target.wants/. It turns out that both services were
only partially enabled, because their dbus unit symlinks
/etc/systemd/system/dbus-org.freedesktop.{resolve1,network1}.service were
created, by the symlinks in /etc/systemd/system/multi-user.target.wants/ were
not. This means that the units could be activated by dbus, but not in usual
fashion using systemctl start. Our tools make it rather hard to figure out when
something like this happens, and it is definitely an area for improvement on its
own. The symlink in .wants/ was filtered out by during packaging, but the dbus
symlink was left in (I assume by mistake).
Let's simplify things by not creating the symlinks statically during 'ninja
install'. This means that the units shipped by systemd have to be enabled in
the usual fashion, which in turns means that [Install] section and presets
become the "single source of truth" and we don't have two sets of conflicting
configuration.
Let's consider a few cases:
- developer: a developer installs systemd from git on a running system, and they
don't want the installation to reset enablement of anything. So this change is
either positive for them, or has no effect (if they have everything at
defaults).
- package creation: we want to create symlinks using 'preset-all' and 'preset'
on upgraded packages, we don't want to have any static symlinks. This change
will remove the need to filter out symlinks in packaging and of course fix
the original report.
- installation of systemd from scratch: this change means that without
'preset-all' the system will not be functional. This case could be affected
negatively by this change, but I think it's enough of a corner case to accept
this. In practice I expect people to build a package, not installl directly
into the file system, so this might not even matter in practice.
Creating those symlinks was probably the right thing in the beginning, but
nowadays the preset system is very well established and people expect it to
be honoured. Ignoring the presets and doing static configuration is not welcome
anymore.
Note: during package installation, either 'preset-all' or 'preset getty@.service
machines.target remote-cryptsetup.target remote-fs.target
systemd-networkd.service systemd-resolved.service
systemd-networkd-wait-online.service systemd-timesyncd.service' should be called.
[1] https://bodhi.fedoraproject.org/updates/FEDORA-2019-616045ca76
2019-04-01 14:57:24 +03:00
[ 'systemd-timesyncd.service' , 'ENABLE_TIMESYNCD' ] ,
2018-04-10 19:05:25 +03:00
[ 'systemd-time-wait-sync.service' , 'ENABLE_TIMESYNCD' ] ,
2017-04-18 02:25:00 +03:00
[ 'systemd-udevd.service' , '' ,
'sysinit.target.wants/' ] ,
[ 'systemd-update-done.service' , '' ,
'sysinit.target.wants/' ] ,
2017-10-03 13:19:30 +03:00
[ 'systemd-update-utmp-runlevel.service' , 'ENABLE_UTMP HAVE_SYSV_COMPAT' ,
2017-04-18 02:25:00 +03:00
'multi-user.target.wants/ graphical.target.wants/ rescue.target.wants/' ] ,
2017-10-03 13:19:30 +03:00
[ 'systemd-update-utmp.service' , 'ENABLE_UTMP' ,
2017-04-18 02:25:00 +03:00
'sysinit.target.wants/' ] ,
2017-10-31 10:20:53 +03:00
[ 'systemd-user-sessions.service' , 'HAVE_PAM' ,
2017-04-18 02:25:00 +03:00
'multi-user.target.wants/' ] ,
[ 'systemd-vconsole-setup.service' , 'ENABLE_VCONSOLE' ] ,
2020-04-09 00:59:13 +03:00
[ 'systemd-volatile-root.service' , 'ENABLE_INITRD' ] ,
Revert "units: make systemd-repart.service installable"
This reverts commit 7e1ed1f3b29162df25064b33dc55ac8cf432bb0b.
systemd-repart is not a user service that should be something people
enable/disable, instead it should just work if there's configuration for
it. It's like systemd-tmpfiles, systemd-sysusers, systemd-load-modules,
systemd-binfmt, systemd-systemd-sysctl which are NOPs if they have no
configuration, and thus don't hurt, but cannot be disabled since they
are too deep part of the OS.
This doesn't mean people couldn't disable the service if they really
want to, there's after all "systemctl mask" and build-time disabling,
but those are OS developer facing instead of admin facing, that's how it
should be.
Note that systemd-repart is in particular an initrd service, and so far
enable/disable state of those is not managed anyway via "systemctl
enable/disable" but more what dracut decides to package up and what not.
2020-04-02 18:01:34 +03:00
[ 'systemd-repart.service' , 'ENABLE_REPART' ,
'sysinit.target.wants/ initrd-root-fs.target.wants/' ] ,
2017-12-09 21:30:17 +03:00
[ 'user-runtime-dir@.service' , '' ] ,
2017-08-09 16:13:41 +03:00
[ 'user@.service' , '' ] ,
2022-10-10 17:17:22 +03:00
[ 'systemd-pcrphase-initrd.service' , 'HAVE_GNU_EFI HAVE_OPENSSL HAVE_TPM2 ENABLE_INITRD' ,
2022-09-17 01:50:38 +03:00
'initrd.target.wants/' ] ,
2022-10-10 17:17:22 +03:00
[ 'systemd-pcrphase.service' , 'HAVE_GNU_EFI HAVE_OPENSSL HAVE_TPM2' ,
2022-09-17 01:50:38 +03:00
'sysinit.target.wants/' ] ,
2017-04-13 03:58:55 +03:00
]
2021-01-09 22:48:39 +03:00
add_wants = [ ]
2017-04-10 06:43:53 +03:00
foreach tuple : in_units
2017-04-18 02:25:00 +03:00
file = tuple [ 0 ]
2017-04-13 03:58:55 +03:00
2017-04-18 02:25:00 +03:00
# we do this here because install_data does not accept custom_target output
conds = tuple [ 1 ] . split ( ' ' )
2017-10-03 11:41:51 +03:00
install = ( ( conds . get ( 0 , '' ) == '' or conf . get ( conds [ 0 ] ) == 1 ) and
( conds . get ( 1 , '' ) == '' or conf . get ( conds [ 1 ] ) == 1 ) )
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
2021-05-16 12:55:36 +03:00
custom_target (
2017-04-18 02:25:00 +03:00
file ,
2021-05-16 12:55:36 +03:00
input : file + '.in' ,
2017-04-18 02:25:00 +03:00
output : file ,
2022-04-05 17:52:44 +03:00
command : [ jinja2_cmdline , '@INPUT@' , '@OUTPUT@' ] ,
2017-04-18 02:25:00 +03:00
install : install ,
install_dir : systemunitdir )
2017-04-10 06:43:53 +03:00
2017-04-18 02:25:00 +03:00
if install and tuple . length ( ) > 2
foreach target : tuple [ 2 ] . split ( )
2021-01-09 22:48:39 +03:00
add_wants + = [ systemunitdir , target , file ]
2017-04-18 02:25:00 +03:00
endforeach
endif
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
endforeach
2017-04-13 03:58:55 +03:00
foreach tuple : units
2017-04-18 02:25:00 +03:00
file = tuple [ 0 ]
input = tuple . get ( 3 , file )
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
2017-04-18 02:25:00 +03:00
conds = tuple [ 1 ] . split ( ' ' )
2017-10-03 11:41:51 +03:00
install = ( ( conds . get ( 0 , '' ) == '' or conf . get ( conds [ 0 ] ) == 1 ) and
( conds . get ( 1 , '' ) == '' or conf . get ( conds [ 1 ] ) == 1 ) )
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
2017-04-18 02:25:00 +03:00
if install
install_data ( input ,
install_dir : systemunitdir )
2017-04-10 06:43:53 +03:00
2017-04-18 02:25:00 +03:00
if tuple . length ( ) > 2
foreach target : tuple [ 2 ] . split ( )
2021-01-09 22:48:39 +03:00
add_wants + = [ systemunitdir , target , file ]
2017-04-18 02:25:00 +03:00
endforeach
endif
endif
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
endforeach
2021-01-09 22:48:39 +03:00
meson . add_install_script ( 'meson-add-wants.sh' , add_wants )
2017-12-08 00:25:26 +03:00
install_data ( 'user-.slice.d/10-defaults.conf' ,
install_dir : systemunitdir + '/user-.slice.d' )
2022-07-07 13:02:04 +03:00
install_data ( 'user@.service.d/10-login-barrier.conf' ,
install_dir : systemunitdir + '/user@.service.d' )
install_data ( 'user@0.service.d/10-login-barrier.conf' ,
install_dir : systemunitdir + '/user@0.service.d' )
2017-04-13 03:58:55 +03:00
############################################################
2020-11-12 10:01:39 +03:00
if install_sysconfdir
meson . add_install_script ( meson_make_symlink ,
2021-07-27 20:32:35 +03:00
pkgsysconfdir / 'user' ,
sysconfdir / 'xdg/systemd/user' )
2020-11-12 10:01:39 +03:00
endif
2019-12-20 14:26:17 +03:00
meson . add_install_script ( meson_make_symlink ,
2021-07-27 20:32:35 +03:00
dbussystemservicedir / 'org.freedesktop.systemd1.service' ,
dbussessionservicedir / 'org.freedesktop.systemd1.service' )
2017-10-03 11:41:51 +03:00
if conf . get ( 'HAVE_SYSV_COMPAT' ) == 1
2017-04-18 02:25:00 +03:00
foreach i : [ 1 , 2 , 3 , 4 , 5 ]
meson . add_install_script (
2021-05-14 17:12:51 +03:00
'sh' , '-c' ,
2021-07-27 20:32:35 +03:00
mkdir_p . format ( systemunitdir / 'runlevel@0@.target.wants' . format ( i ) ) )
2017-04-18 02:25:00 +03:00
endforeach
2017-04-10 06:55:05 +03:00
endif
meson: build systemd using meson
It's crucial that we can build systemd using VS2010!
... er, wait, no, that's not the official reason. We need to shed old systems
by requring python 3! Oh, no, it's something else. Maybe we need to throw out
345 years of knowlege accumulated in autotools? Whatever, this new thing is
cool and shiny, let's use it.
This is not complete, I'm throwing it out here for your amusement and critique.
- rules for sd-boot are missing. Those might be quite complicated.
- rules for tests are missing too. Those are probably quite simple and
repetitive, but there's lots of them.
- it's likely that I didn't get all the conditions right, I only tested "full"
compilation where most deps are provided and nothing is disabled.
- busname.target and all .busname units are skipped on purpose.
Otherwise, installation into $DESTDIR has the same list of files and the
autoconf install, except for .la files.
It'd be great if people had a careful look at all the library linking options.
I added stuff until things compiled, and in the end there's much less linking
then in the old system. But it seems that there's still a lot of unnecessary
deps.
meson has a `shared_module` statement, which sounds like something appropriate
for our nss and pam modules. Unfortunately, I couldn't get it to work. For the
nss modules, we need an .so version of '2', but `shared_module` disallows the
version argument. For the pam module, it also didn't work, I forgot the reason.
The handling of .m4 and .in and .m4.in files is rather awkward. It's likely
that this could be simplified. If make support is ever dropped, I think it'd
make sense to switch to a different templating system so that two different
languages and not required, which would make everything simpler yet.
v2:
- use get_pkgconfig_variable
- use sh not bash
- use add_project_arguments
v3:
- drop required:true and fix progs/prog typo
v4:
- use find_library('bz2')
- add TTY_GID definition
- define __SANE_USERSPACE_TYPES__
- use join_paths(prefix, ...) is used on all paths to make them all absolute
v5:
- replace all declare_dependency's with []
- add more conf.get guards around optional components
v6:
- drop -pipe, -Wall which are the default in meson
- use compiler.has_function() and compiler.has_header_symbol instead of the
hand-rolled checks.
- fix duplication in 'liblibsystemd' library name
- use the right .sym file for pam_systemd
- rename 'compiler' to 'cc': shorter, and more idiomatic.
v7:
- use ENABLE_ENVIRONMENT_D not HAVE_ENVIRONMENT_D
- rename prefix to prefixdir, rootprefix to rootprefixdir
("prefix" is too common of a name and too easy to overwrite by mistake)
- wrap more stuff with conf.get('ENABLE...') == 1
- use rootprefix=='/' and rootbindir as install_dir, to fix paths under
split-usr==true.
v8:
- use .split() also for src/coredump. Now everything is consistent ;)
- add rootlibdir option and use it on the libraries that require it
v9:
- indentation
v10:
- fix check for qrencode and libaudit
v11:
- unify handling of executable paths, provide options for all progs
This makes the meson build behave slightly differently than the
autoconf-based one, because we always first try to find the executable in the
filesystem, and fall back to the default. I think different handling of
loadkeys, setfont, and telinit was just a historical accident.
In addition to checking in $PATH, also check /usr/sbin/, /sbin for programs.
In Fedora $PATH includes /usr/sbin, (and /sbin is is a symlink to /usr/sbin),
but in Debian, those directories are not included in the path.
C.f. https://github.com/mesonbuild/meson/issues/1576.
- call all the options 'xxx-path' for clarity.
- sort man/rules/meson.build properly so it's stable
2017-04-05 06:03:47 +03:00
subdir ( 'user' )