mirror of
https://github.com/flatcar/scripts.git
synced 2025-09-27 16:41:11 +02:00
sys-apps/systemd: Sync with Gentoo
It's from Gentoo commit 473b0997ba121fcc629f94a480238f8e664f900d
This commit is contained in:
parent
57ba242829
commit
ca868e8a04
@ -1 +1 @@
|
|||||||
DIST systemd-stable-255.8.tar.gz 15070471 BLAKE2B b437404af7fd73ef527f80d9d14d46a781444103d1756c27494ecf2664c9c5efe1169c85b91148a3bf190dc7c5e31cf8d42a13c84102d101ea7e4a0570e8d719 SHA512 7692be761a393924669a90f6f343998a85707a9daa3ce169ce67f62ae2a39338c2c3496066b2659c6500849104fab0529fca5704a3eb32375f2f44131216d1f1
|
DIST systemd-256.7.tar.gz 15672532 BLAKE2B d718b7bcbf9c3583953a9fa82319f04b32d17c5b7539a49b9999881bd8cea7fd9a06f252d763170613a6cd0fd2535762b233cba74eb87764f662c4bdf2d8c1da SHA512 2ff3805a7d97780a716b23ddeea3722a85aba6326ecee527e53e9d35510a0ffa5ec0bf0cdbf8f3409bb9c6832406916f63eb7e8305db5f67c284e5590c642422
|
||||||
|
26
sdk_container/src/third_party/coreos-overlay/sys-apps/systemd/files/256-bpf-gcc.patch
vendored
Normal file
26
sdk_container/src/third_party/coreos-overlay/sys-apps/systemd/files/256-bpf-gcc.patch
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
https://github.com/systemd/systemd/commit/dde6f1d7456db7aa72d24b1d6956b419b6f9945c
|
||||||
|
|
||||||
|
From dde6f1d7456db7aa72d24b1d6956b419b6f9945c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Sam James <sam@gentoo.org>
|
||||||
|
Date: Sat, 24 Aug 2024 13:09:47 +0100
|
||||||
|
Subject: [PATCH] meson: search for 'bpf-unknown-none' too
|
||||||
|
|
||||||
|
We currently search for 'bpf-gcc' and 'bpf-none-gcc'. Gentoo's
|
||||||
|
sys-devel/bpf-toolchain package uses 'bpf-unknown-none-gcc', as does Fedora's
|
||||||
|
cross-binutils. Search for this name too.
|
||||||
|
---
|
||||||
|
meson.build | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
diff --git a/meson.build b/meson.build
|
||||||
|
index 5e0b666c64b17..fbc2bbdf2f22f 100644
|
||||||
|
--- a/meson.build
|
||||||
|
+++ b/meson.build
|
||||||
|
@@ -1109,6 +1109,7 @@ else
|
||||||
|
elif bpf_compiler == 'gcc'
|
||||||
|
bpf_gcc = find_program('bpf-gcc',
|
||||||
|
'bpf-none-gcc',
|
||||||
|
+ 'bpf-unknown-none-gcc',
|
||||||
|
required : true,
|
||||||
|
version : '>= 13.1.0')
|
||||||
|
bpf_gcc_found = bpf_gcc.found()
|
@ -2,7 +2,7 @@
|
|||||||
# Distributed under the terms of the GNU General Public License v2
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
EAPI=8
|
EAPI=8
|
||||||
PYTHON_COMPAT=( python3_{10..12} )
|
PYTHON_COMPAT=( python3_{10..13} )
|
||||||
|
|
||||||
# Avoid QA warnings
|
# Avoid QA warnings
|
||||||
TMPFILES_OPTIONAL=1
|
TMPFILES_OPTIONAL=1
|
||||||
@ -14,32 +14,26 @@ if [[ ${PV} == 9999 ]]; then
|
|||||||
EGIT_REPO_URI="https://github.com/systemd/systemd.git"
|
EGIT_REPO_URI="https://github.com/systemd/systemd.git"
|
||||||
inherit git-r3
|
inherit git-r3
|
||||||
else
|
else
|
||||||
if [[ ${PV} == *.* ]]; then
|
|
||||||
MY_PN=systemd-stable
|
|
||||||
else
|
|
||||||
MY_PN=systemd
|
|
||||||
fi
|
|
||||||
MY_PV=${PV/_/-}
|
MY_PV=${PV/_/-}
|
||||||
MY_P=${MY_PN}-${MY_PV}
|
MY_P=${PN}-${MY_PV}
|
||||||
S=${WORKDIR}/${MY_P}
|
S=${WORKDIR}/${MY_P}
|
||||||
SRC_URI="https://github.com/systemd/${MY_PN}/archive/v${MY_PV}/${MY_P}.tar.gz"
|
SRC_URI="https://github.com/systemd/${PN}/archive/refs/tags/v${MY_PV}.tar.gz -> ${MY_P}.tar.gz"
|
||||||
|
|
||||||
if [[ ${PV} != *rc* ]] ; then
|
if [[ ${PV} != *rc* ]] ; then
|
||||||
# Flatcar: mark as stable
|
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
||||||
KEYWORDS="~alpha amd64 ~arm arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
inherit bash-completion-r1 linux-info meson-multilib optfeature pam python-single-r1
|
inherit bash-completion-r1 linux-info meson-multilib optfeature pam python-single-r1
|
||||||
inherit secureboot systemd tmpfiles toolchain-funcs udev
|
inherit secureboot systemd toolchain-funcs udev
|
||||||
|
|
||||||
DESCRIPTION="System and service manager for Linux"
|
DESCRIPTION="System and service manager for Linux"
|
||||||
HOMEPAGE="http://systemd.io/"
|
HOMEPAGE="https://systemd.io/"
|
||||||
|
|
||||||
LICENSE="GPL-2 LGPL-2.1 MIT public-domain"
|
LICENSE="GPL-2 LGPL-2.1 MIT public-domain"
|
||||||
SLOT="0/2"
|
SLOT="0/2"
|
||||||
IUSE="
|
IUSE="
|
||||||
acl apparmor audit boot cgroup-hybrid cryptsetup curl +dns-over-tls elfutils
|
acl apparmor audit boot bpf cgroup-hybrid cryptsetup curl +dns-over-tls elfutils
|
||||||
fido2 +gcrypt gnutls homed http idn importd iptables +kernel-install +kmod
|
fido2 +gcrypt gnutls homed http idn importd iptables +kernel-install +kmod
|
||||||
+lz4 lzma +openssl pam pcre pkcs11 policykit pwquality qrcode
|
+lz4 lzma +openssl pam pcre pkcs11 policykit pwquality qrcode
|
||||||
+resolvconf +seccomp selinux split-usr +sysv-utils test tpm ukify vanilla xkb +zstd
|
+resolvconf +seccomp selinux split-usr +sysv-utils test tpm ukify vanilla xkb +zstd
|
||||||
@ -65,6 +59,7 @@ COMMON_DEPEND="
|
|||||||
acl? ( sys-apps/acl:0= )
|
acl? ( sys-apps/acl:0= )
|
||||||
apparmor? ( >=sys-libs/libapparmor-2.13:0= )
|
apparmor? ( >=sys-libs/libapparmor-2.13:0= )
|
||||||
audit? ( >=sys-process/audit-2:0= )
|
audit? ( >=sys-process/audit-2:0= )
|
||||||
|
bpf? ( >=dev-libs/libbpf-1.4.0:0= )
|
||||||
cryptsetup? ( >=sys-fs/cryptsetup-2.0.1:0= )
|
cryptsetup? ( >=sys-fs/cryptsetup-2.0.1:0= )
|
||||||
curl? ( >=net-misc/curl-7.32.0:0= )
|
curl? ( >=net-misc/curl-7.32.0:0= )
|
||||||
elfutils? ( >=dev-libs/elfutils-0.158:0= )
|
elfutils? ( >=dev-libs/elfutils-0.158:0= )
|
||||||
@ -102,14 +97,6 @@ DEPEND="${COMMON_DEPEND}
|
|||||||
PEFILE_DEPEND='dev-python/pefile[${PYTHON_USEDEP}]'
|
PEFILE_DEPEND='dev-python/pefile[${PYTHON_USEDEP}]'
|
||||||
|
|
||||||
# baselayout-2.2 has /run
|
# baselayout-2.2 has /run
|
||||||
#
|
|
||||||
# Flatcar: Drop sec-policy/selinux-ntp from deps (under selinux use
|
|
||||||
# flag). The image stage fails with "Failed to resolve
|
|
||||||
# typeattributeset statement at
|
|
||||||
# /var/lib/selinux/mcs/tmp/modules/400/ntp/cil:120"
|
|
||||||
#
|
|
||||||
# Flatcar: Added a dep on sys-apps/kbd. It provides a loadkeys binary
|
|
||||||
# needed by dracut's systemd-vconsole-setup module.
|
|
||||||
RDEPEND="${COMMON_DEPEND}
|
RDEPEND="${COMMON_DEPEND}
|
||||||
>=acct-group/adm-0-r1
|
>=acct-group/adm-0-r1
|
||||||
>=acct-group/wheel-0-r1
|
>=acct-group/wheel-0-r1
|
||||||
@ -138,21 +125,21 @@ RDEPEND="${COMMON_DEPEND}
|
|||||||
>=acct-user/systemd-resolve-0-r1
|
>=acct-user/systemd-resolve-0-r1
|
||||||
>=acct-user/systemd-timesync-0-r1
|
>=acct-user/systemd-timesync-0-r1
|
||||||
>=sys-apps/baselayout-2.2
|
>=sys-apps/baselayout-2.2
|
||||||
sys-apps/kbd
|
|
||||||
ukify? (
|
ukify? (
|
||||||
${PYTHON_DEPS}
|
${PYTHON_DEPS}
|
||||||
$(python_gen_cond_dep "${PEFILE_DEPEND}")
|
$(python_gen_cond_dep "${PEFILE_DEPEND}")
|
||||||
)
|
)
|
||||||
selinux? (
|
selinux? (
|
||||||
sec-policy/selinux-base-policy[systemd]
|
sec-policy/selinux-base-policy[systemd]
|
||||||
|
sec-policy/selinux-ntp
|
||||||
)
|
)
|
||||||
sysv-utils? (
|
sysv-utils? (
|
||||||
!sys-apps/openrc[sysv-utils(-)]
|
!sys-apps/openrc[sysv-utils(-)]
|
||||||
|
!sys-apps/openrc-navi[sysv-utils(-)]
|
||||||
!sys-apps/sysvinit
|
!sys-apps/sysvinit
|
||||||
)
|
)
|
||||||
!sysv-utils? ( sys-apps/sysvinit )
|
!sysv-utils? ( sys-apps/sysvinit )
|
||||||
resolvconf? ( !net-dns/openresolv )
|
resolvconf? ( !net-dns/openresolv )
|
||||||
!sys-apps/hwids[udev]
|
|
||||||
!sys-auth/nss-myhostname
|
!sys-auth/nss-myhostname
|
||||||
!sys-fs/eudev
|
!sys-fs/eudev
|
||||||
!sys-fs/udev
|
!sys-fs/udev
|
||||||
@ -171,6 +158,10 @@ BDEPEND="
|
|||||||
>=sys-apps/coreutils-8.16
|
>=sys-apps/coreutils-8.16
|
||||||
sys-devel/gettext
|
sys-devel/gettext
|
||||||
virtual/pkgconfig
|
virtual/pkgconfig
|
||||||
|
bpf? (
|
||||||
|
dev-util/bpftool
|
||||||
|
sys-devel/bpf-toolchain
|
||||||
|
)
|
||||||
test? (
|
test? (
|
||||||
app-text/tree
|
app-text/tree
|
||||||
dev-lang/perl
|
dev-lang/perl
|
||||||
@ -194,13 +185,38 @@ BDEPEND="
|
|||||||
QA_FLAGS_IGNORED="usr/lib/systemd/boot/efi/.*"
|
QA_FLAGS_IGNORED="usr/lib/systemd/boot/efi/.*"
|
||||||
QA_EXECSTACK="usr/lib/systemd/boot/efi/*"
|
QA_EXECSTACK="usr/lib/systemd/boot/efi/*"
|
||||||
|
|
||||||
|
check_cgroup_layout() {
|
||||||
|
# https://bugs.gentoo.org/935261
|
||||||
|
[[ ${MERGE_TYPE} != buildonly ]] || return
|
||||||
|
[[ -z ${ROOT} ]] || return
|
||||||
|
[[ -e /sys/fs/cgroup/unified ]] || return
|
||||||
|
grep -q 'SYSTEMD_CGROUP_ENABLE_LEGACY_FORCE=1' /proc/cmdline && return
|
||||||
|
|
||||||
|
eerror "This system appears to be booted with the 'hybrid' cgroup layout."
|
||||||
|
eerror "This layout obsolete and is disabled in systemd."
|
||||||
|
|
||||||
|
if grep -qF 'systemd.unified_cgroup_hierarchy'; then
|
||||||
|
eerror "Remove the systemd.unified_cgroup_hierarchy option"
|
||||||
|
eerror "from the kernel command line and reboot."
|
||||||
|
die "hybrid cgroup layout detected"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
pkg_pretend() {
|
pkg_pretend() {
|
||||||
# Flatcar: We keep using split-usr for SDK.
|
if use split-usr; then
|
||||||
# if use split-usr; then
|
eerror "Please complete the migration to merged-usr."
|
||||||
# eerror "Please complete the migration to merged-usr."
|
eerror "https://wiki.gentoo.org/wiki/Merge-usr"
|
||||||
# eerror "https://wiki.gentoo.org/wiki/Merge-usr"
|
die "systemd no longer supports split-usr"
|
||||||
# die "systemd no longer supports split-usr"
|
fi
|
||||||
# fi
|
|
||||||
|
check_cgroup_layout
|
||||||
|
|
||||||
|
if use cgroup-hybrid; then
|
||||||
|
eerror "Disable the 'cgroup-hybrid' USE flag."
|
||||||
|
eerror "Rebuild any initramfs images after rebuilding systemd."
|
||||||
|
die "cgroup-hybrid is no longer supported"
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ ${MERGE_TYPE} != buildonly ]]; then
|
if [[ ${MERGE_TYPE} != buildonly ]]; then
|
||||||
local CONFIG_CHECK="~BLK_DEV_BSG ~CGROUPS
|
local CONFIG_CHECK="~BLK_DEV_BSG ~CGROUPS
|
||||||
~CGROUP_BPF ~DEVTMPFS ~EPOLL ~FANOTIFY ~FHANDLE
|
~CGROUP_BPF ~DEVTMPFS ~EPOLL ~FANOTIFY ~FHANDLE
|
||||||
@ -211,6 +227,7 @@ pkg_pretend() {
|
|||||||
~!SYSFS_DEPRECATED_V2"
|
~!SYSFS_DEPRECATED_V2"
|
||||||
|
|
||||||
use acl && CONFIG_CHECK+=" ~TMPFS_POSIX_ACL"
|
use acl && CONFIG_CHECK+=" ~TMPFS_POSIX_ACL"
|
||||||
|
use bpf && CONFIG_CHECK+=" ~BPF ~BPF_SYSCALL ~BPF_LSM ~DEBUG_INFO_BTF"
|
||||||
use seccomp && CONFIG_CHECK+=" ~SECCOMP ~SECCOMP_FILTER"
|
use seccomp && CONFIG_CHECK+=" ~SECCOMP ~SECCOMP_FILTER"
|
||||||
|
|
||||||
if kernel_is -ge 5 10 20; then
|
if kernel_is -ge 5 10 20; then
|
||||||
@ -256,42 +273,15 @@ src_unpack() {
|
|||||||
src_prepare() {
|
src_prepare() {
|
||||||
local PATCHES=(
|
local PATCHES=(
|
||||||
"${FILESDIR}/systemd-test-process-util.patch"
|
"${FILESDIR}/systemd-test-process-util.patch"
|
||||||
# Flatcar: Adding our own patches here.
|
"${FILESDIR}/256-bpf-gcc.patch"
|
||||||
"${FILESDIR}/0001-wait-online-set-any-by-default.patch"
|
|
||||||
"${FILESDIR}/0002-networkd-default-to-kernel-IPForwarding-setting.patch"
|
|
||||||
"${FILESDIR}/0003-needs-update-don-t-require-strictly-newer-usr.patch"
|
|
||||||
"${FILESDIR}/0004-core-use-max-for-DefaultTasksMax.patch"
|
|
||||||
"${FILESDIR}/0005-systemd-Disable-SELinux-permissions-checks.patch"
|
|
||||||
"${FILESDIR}/0006-Revert-getty-Pass-tty-to-use-by-agetty-via-stdin.patch"
|
|
||||||
"${FILESDIR}/0007-units-Keep-using-old-journal-file-format.patch"
|
|
||||||
# Flatcar: This can be dropped when updating to 256.
|
|
||||||
"${FILESDIR}/0008-sysext-Mutable-overlays.patch"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
if ! use vanilla; then
|
if ! use vanilla; then
|
||||||
PATCHES+=(
|
PATCHES+=(
|
||||||
"${FILESDIR}/gentoo-generator-path-r2.patch"
|
|
||||||
"${FILESDIR}/gentoo-journald-audit-r1.patch"
|
"${FILESDIR}/gentoo-journald-audit-r1.patch"
|
||||||
)
|
)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Fails with split-usr.
|
|
||||||
sed -i -e '2i exit 77' test/test-rpm-macros.sh || die
|
|
||||||
|
|
||||||
# Flatcar: The Kubelet takes /etc/resolv.conf for, e.g.,
|
|
||||||
# CoreDNS which has dnsPolicy "default", but unless the
|
|
||||||
# kubelet --resolv-conf flag is set to point to
|
|
||||||
# /run/systemd/resolve/resolv.conf this won't work with
|
|
||||||
# /etc/resolv.conf pointing to
|
|
||||||
# /run/systemd/resolve/stub-resolv.conf which configures
|
|
||||||
# 127.0.0.53. See
|
|
||||||
# https://kubernetes.io/docs/tasks/administer-cluster/dns-debugging-resolution/#known-issues
|
|
||||||
# This means that users who need split DNS to work should
|
|
||||||
# point /etc/resolv.conf back to
|
|
||||||
# /run/systemd/resolve/stub-resolv.conf (and if using K8s
|
|
||||||
# configure the kubelet resolvConf variable/--resolv-conf flag
|
|
||||||
# to /run/systemd/resolve/resolv.conf).
|
|
||||||
sed -i -e 's,/run/systemd/resolve/stub-resolv.conf,/run/systemd/resolve/resolv.conf,' tmpfiles.d/systemd-resolve.conf || die
|
|
||||||
default
|
default
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,42 +294,21 @@ src_configure() {
|
|||||||
multilib-minimal_src_configure
|
multilib-minimal_src_configure
|
||||||
}
|
}
|
||||||
|
|
||||||
# Flatcar: Our function, we use it in some places below.
|
|
||||||
get_rootprefix() {
|
|
||||||
usex split-usr "${EPREFIX:-/}" "${EPREFIX}/usr"
|
|
||||||
}
|
|
||||||
|
|
||||||
multilib_src_configure() {
|
multilib_src_configure() {
|
||||||
local myconf=(
|
local myconf=(
|
||||||
--localstatedir="${EPREFIX}/var"
|
--localstatedir="${EPREFIX}/var"
|
||||||
# default is developer, bug 918671
|
# default is developer, bug 918671
|
||||||
-Dmode=release
|
-Dmode=release
|
||||||
# Flatcar: Point to our user mailing list.
|
-Dsupport-url="https://gentoo.org/support/"
|
||||||
-Dsupport-url="https://groups.google.com/forum/#!forum/flatcar-linux-user"
|
|
||||||
-Dpamlibdir="$(getpam_mod_dir)"
|
-Dpamlibdir="$(getpam_mod_dir)"
|
||||||
# avoid bash-completion dep
|
# avoid bash-completion dep
|
||||||
-Dbashcompletiondir="$(get_bashcompdir)"
|
-Dbashcompletiondir="$(get_bashcompdir)"
|
||||||
# Flatcar: We keep using split-usr in SDK.
|
-Dsplit-bin=false
|
||||||
$(meson_use split-usr)
|
|
||||||
# Flatcar: Always set split-bin to true, we always
|
|
||||||
# have separate bin and sbin directories
|
|
||||||
-Dsplit-bin=true
|
|
||||||
# Flatcar: Use get_rootprefix. No functional change
|
|
||||||
# from upstream, just refactoring the common code used
|
|
||||||
# in some places.
|
|
||||||
#
|
|
||||||
# TODO: Drop -Drootprefix and -Drootlibdir we get rid
|
|
||||||
# of split-usr in SDK
|
|
||||||
-Drootprefix="$(get_rootprefix)"
|
|
||||||
-Drootlibdir="${EPREFIX}/usr/$(get_libdir)"
|
|
||||||
# Disable compatibility with sysvinit
|
# Disable compatibility with sysvinit
|
||||||
-Dsysvinit-path=
|
-Dsysvinit-path=
|
||||||
-Dsysvrcnd-path=
|
-Dsysvrcnd-path=
|
||||||
# Avoid infinite exec recursion, bug 642724
|
|
||||||
-Dtelinit-path="${EPREFIX}/lib/sysvinit/telinit"
|
|
||||||
# no deps
|
# no deps
|
||||||
-Dima=true
|
-Dima=true
|
||||||
-Ddefault-hierarchy=$(usex cgroup-hybrid hybrid unified)
|
|
||||||
# Match /etc/shells, bug 919749
|
# Match /etc/shells, bug 919749
|
||||||
-Ddebug-shell="${EPREFIX}/bin/sh"
|
-Ddebug-shell="${EPREFIX}/bin/sh"
|
||||||
-Ddefault-user-shell="${EPREFIX}/bin/bash"
|
-Ddefault-user-shell="${EPREFIX}/bin/bash"
|
||||||
@ -348,6 +317,8 @@ multilib_src_configure() {
|
|||||||
$(meson_native_use_bool apparmor)
|
$(meson_native_use_bool apparmor)
|
||||||
$(meson_native_use_bool audit)
|
$(meson_native_use_bool audit)
|
||||||
$(meson_native_use_bool boot bootloader)
|
$(meson_native_use_bool boot bootloader)
|
||||||
|
$(meson_native_use_bool bpf bpf-framework)
|
||||||
|
-Dbpf-compiler=gcc
|
||||||
$(meson_native_use_bool cryptsetup libcryptsetup)
|
$(meson_native_use_bool cryptsetup libcryptsetup)
|
||||||
$(meson_native_use_bool curl libcurl)
|
$(meson_native_use_bool curl libcurl)
|
||||||
$(meson_native_use_bool dns-over-tls dns-over-tls)
|
$(meson_native_use_bool dns-over-tls dns-over-tls)
|
||||||
@ -381,11 +352,9 @@ multilib_src_configure() {
|
|||||||
$(meson_native_use_bool test dbus)
|
$(meson_native_use_bool test dbus)
|
||||||
$(meson_native_use_bool ukify)
|
$(meson_native_use_bool ukify)
|
||||||
$(meson_native_use_bool xkb xkbcommon)
|
$(meson_native_use_bool xkb xkbcommon)
|
||||||
# Flatcar: Use our ntp servers.
|
-Dntp-servers="0.gentoo.pool.ntp.org 1.gentoo.pool.ntp.org 2.gentoo.pool.ntp.org 3.gentoo.pool.ntp.org"
|
||||||
-Dntp-servers="0.flatcar.pool.ntp.org 1.flatcar.pool.ntp.org 2.flatcar.pool.ntp.org 3.flatcar.pool.ntp.org"
|
|
||||||
# Breaks screen, tmux, etc.
|
# Breaks screen, tmux, etc.
|
||||||
-Ddefault-kill-user-processes=false
|
-Ddefault-kill-user-processes=false
|
||||||
# Flatcar: TODO: Investigate if we want this.
|
|
||||||
-Dcreate-log-dirs=false
|
-Dcreate-log-dirs=false
|
||||||
|
|
||||||
# multilib options
|
# multilib options
|
||||||
@ -408,45 +377,16 @@ multilib_src_configure() {
|
|||||||
$(meson_native_true timesyncd)
|
$(meson_native_true timesyncd)
|
||||||
$(meson_native_true tmpfiles)
|
$(meson_native_true tmpfiles)
|
||||||
$(meson_native_true vconsole)
|
$(meson_native_true vconsole)
|
||||||
$(meson_native_enabled vmspawn)
|
|
||||||
# Flatcar: Specify this, or meson breaks due to no
|
|
||||||
# /etc/login.defs.
|
|
||||||
-Dsystem-gid-max=999
|
|
||||||
-Dsystem-uid-max=999
|
|
||||||
|
|
||||||
# Flatcar: DBus paths.
|
|
||||||
-Ddbussessionservicedir="${EPREFIX}/usr/share/dbus-1/services"
|
|
||||||
-Ddbussystemservicedir="${EPREFIX}/usr/share/dbus-1/system-services"
|
|
||||||
|
|
||||||
# Flatcar: PAM config directory.
|
|
||||||
-Dpamconfdir=/usr/share/pam.d
|
|
||||||
|
|
||||||
# Flatcar: The CoreOS epoch, Mon Jul 1 00:00:00 UTC
|
|
||||||
# 2013. Used by timesyncd as a sanity check for the
|
|
||||||
# minimum acceptable time. Explicitly set to avoid
|
|
||||||
# using the current build time.
|
|
||||||
-Dtime-epoch=1372636800
|
|
||||||
|
|
||||||
# Flatcar: No default name servers.
|
|
||||||
-Ddns-servers=
|
|
||||||
|
|
||||||
# Flatcar: Disable the "First Boot Wizard", it isn't
|
|
||||||
# very applicable to us.
|
|
||||||
-Dfirstboot=false
|
|
||||||
|
|
||||||
# Flatcar: Set latest network interface naming scheme
|
|
||||||
# for https://github.com/flatcar/Flatcar/issues/36
|
|
||||||
-Ddefault-net-naming-scheme=latest
|
|
||||||
|
|
||||||
# Flatcar: Combined log format: name plus description
|
|
||||||
-Dstatus-unit-format-default=combined
|
|
||||||
|
|
||||||
# Flatcar: Unported options, still needed?
|
|
||||||
-Dquotaon-path=/usr/sbin/quotaon
|
|
||||||
-Dquotacheck-path=/usr/sbin/quotacheck
|
|
||||||
-Ddefault-mdns=no
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
case $(tc-arch) in
|
||||||
|
amd64|arm|arm64|ppc|ppc64|s390|x86)
|
||||||
|
# src/vmspawn/vmspawn-util.h: QEMU_MACHINE_TYPE
|
||||||
|
myconf+=( $(meson_native_enabled vmspawn) ) ;;
|
||||||
|
*)
|
||||||
|
myconf+=( -Dvmspawn=disabled ) ;;
|
||||||
|
esac
|
||||||
|
|
||||||
meson_src_configure "${myconf[@]}"
|
meson_src_configure "${myconf[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -467,9 +407,7 @@ multilib_src_install_all() {
|
|||||||
mv "${ED}"/usr/share/doc/{systemd,${PF}} || die
|
mv "${ED}"/usr/share/doc/{systemd,${PF}} || die
|
||||||
|
|
||||||
einstalldocs
|
einstalldocs
|
||||||
# Flatcar: Do not install sample nsswitch.conf, we don't
|
dodoc "${FILESDIR}"/nsswitch.conf
|
||||||
# provide it.
|
|
||||||
# dodoc "${FILESDIR}"/nsswitch.conf
|
|
||||||
|
|
||||||
insinto /usr/lib/tmpfiles.d
|
insinto /usr/lib/tmpfiles.d
|
||||||
doins "${FILESDIR}"/legacy.conf
|
doins "${FILESDIR}"/legacy.conf
|
||||||
@ -487,8 +425,6 @@ multilib_src_install_all() {
|
|||||||
# https://bugs.gentoo.org/761763
|
# https://bugs.gentoo.org/761763
|
||||||
rm -r "${ED}"/usr/lib/sysusers.d || die
|
rm -r "${ED}"/usr/lib/sysusers.d || die
|
||||||
|
|
||||||
# Flatcar: Upstream uses keepdir commands to keep some empty
|
|
||||||
# directories. We use tmpfiles.
|
|
||||||
# Preserve empty dirs in /etc & /var, bug #437008
|
# Preserve empty dirs in /etc & /var, bug #437008
|
||||||
keepdir /etc/{binfmt.d,modules-load.d,tmpfiles.d}
|
keepdir /etc/{binfmt.d,modules-load.d,tmpfiles.d}
|
||||||
keepdir /etc/kernel/install.d
|
keepdir /etc/kernel/install.d
|
||||||
@ -497,134 +433,29 @@ multilib_src_install_all() {
|
|||||||
|
|
||||||
keepdir /etc/udev/hwdb.d
|
keepdir /etc/udev/hwdb.d
|
||||||
|
|
||||||
# keepdir /usr/lib/systemd/{system-sleep,system-shutdown}
|
keepdir /usr/lib/systemd/{system-sleep,system-shutdown}
|
||||||
# keepdir /usr/lib/{binfmt.d,modules-load.d}
|
keepdir /usr/lib/{binfmt.d,modules-load.d}
|
||||||
# keepdir /usr/lib/systemd/user-generators
|
keepdir /usr/lib/systemd/user-generators
|
||||||
# keepdir /var/lib/systemd
|
keepdir /var/lib/systemd
|
||||||
# keepdir /var/log/journal
|
keepdir /var/log/journal
|
||||||
|
|
||||||
# if use pam; then
|
if use pam; then
|
||||||
# newpamd "${FILESDIR}"/systemd-user.pam systemd-user
|
if use selinux; then
|
||||||
# fi
|
newpamd "${FILESDIR}"/systemd-user-selinux.pam systemd-user
|
||||||
|
else
|
||||||
|
newpamd "${FILESDIR}"/systemd-user.pam systemd-user
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
if use kernel-install; then
|
if use kernel-install; then
|
||||||
# Dummy config, remove to make room for sys-kernel/installkernel
|
# Dummy config, remove to make room for sys-kernel/installkernel
|
||||||
rm "${ED}/usr/lib/kernel/install.conf" || die
|
rm "${ED}/usr/lib/kernel/install.conf" || die
|
||||||
fi
|
fi
|
||||||
# Flatcar: Ensure journal directory has correct ownership/mode
|
|
||||||
# in inital image. This is fixed by systemd-tmpfiles *but*
|
|
||||||
# journald starts before that and will create the journal if
|
|
||||||
# the filesystem is already read-write. Conveniently the
|
|
||||||
# systemd Makefile sets this up completely wrong.
|
|
||||||
#
|
|
||||||
# Flatcar: TODO: Is this still a problem?
|
|
||||||
dodir /var/log/journal
|
|
||||||
fowners root:systemd-journal /var/log/journal
|
|
||||||
fperms 2755 /var/log/journal
|
|
||||||
|
|
||||||
# Flatcar: Don't prune systemd dirs.
|
|
||||||
dotmpfiles "${FILESDIR}"/systemd-flatcar.conf
|
|
||||||
# Flatcar: Add tmpfiles rule for resolv.conf. This path has
|
|
||||||
# changed after v213 so it must be handled here instead of
|
|
||||||
# baselayout now.
|
|
||||||
dotmpfiles "${FILESDIR}"/systemd-resolv.conf
|
|
||||||
|
|
||||||
# Flatcar: Don't default to graphical.target.
|
|
||||||
local unitdir=$(builddir_systemd_get_systemunitdir)
|
|
||||||
dosym multi-user.target "${unitdir}"/default.target
|
|
||||||
|
|
||||||
# Flatcar: Don't set any extra environment variables by default.
|
|
||||||
rm "${ED}/usr/lib/environment.d/99-environment.conf" || die
|
|
||||||
|
|
||||||
# Flatcar: These lines more or less follow the systemd's
|
|
||||||
# preset file (90-systemd.preset). We do it that way, to avoid
|
|
||||||
# putting symlinks in /etc. Please keep the lines in the same
|
|
||||||
# order as the "enable" lines appear in the preset file. For a
|
|
||||||
# single enable line in preset, there may be more lines if the
|
|
||||||
# unit file had Also: clause which has units we enable here
|
|
||||||
# too.
|
|
||||||
|
|
||||||
# Flatcar: enable remote-fs.target
|
|
||||||
builddir_systemd_enable_service multi-user.target remote-fs.target
|
|
||||||
# Flatcar: enable remote-cryptsetup.target
|
|
||||||
if use cryptsetup; then
|
|
||||||
builddir_systemd_enable_service multi-user.target remote-cryptsetup.target
|
|
||||||
fi
|
|
||||||
# Flatcar: enable machines.target
|
|
||||||
builddir_systemd_enable_service multi-user.target machines.target
|
|
||||||
# Flatcar: enable getty@.service
|
|
||||||
dodir "${unitdir}/getty.target.wants"
|
|
||||||
dosym ../getty@.service "${unitdir}/getty.target.wants/getty@tty1.service"
|
|
||||||
# Flatcar: enable systemd-timesyncd.service
|
|
||||||
builddir_systemd_enable_service sysinit.target systemd-timesyncd.service
|
|
||||||
# Flatcar: enable systemd-networkd.service (Also: systemd-networkd.socket, systemd-networkd-wait-online.service)
|
|
||||||
builddir_systemd_enable_service multi-user.target systemd-networkd.service
|
|
||||||
builddir_systemd_enable_service sockets.target systemd-networkd.socket
|
|
||||||
builddir_systemd_enable_service network-online.target systemd-networkd-wait-online.service
|
|
||||||
# Flatcar: enable systemd-network-generator.service
|
|
||||||
builddir_systemd_enable_service sysinit.target systemd-network-generator.service
|
|
||||||
# Flatcar: enable systemd-resolved.service
|
|
||||||
builddir_systemd_enable_service multi-user.target systemd-resolved.service
|
|
||||||
# Flatcar: enable systemd-homed.service (Also: systemd-userdbd.service [not enabled - has no WantedBy entry])
|
|
||||||
if use homed; then
|
|
||||||
builddir_systemd_enable_service multi-user.target systemd-homed.target
|
|
||||||
fi
|
|
||||||
# Flatcar: enable systemd-userdbd.socket
|
|
||||||
builddir_systemd_enable_service sockets.target systemd-userdbd.socket
|
|
||||||
# Flatcar: enable systemd-pstore.service
|
|
||||||
builddir_systemd_enable_service sysinit.target systemd-pstore.service
|
|
||||||
# Flatcar: enable systemd-boot-update.service
|
|
||||||
if use boot; then
|
|
||||||
builddir_systemd_enable_service sysinit.target systemd-boot-update.service
|
|
||||||
fi
|
|
||||||
# Flatcar: enable reboot.target (not enabled - has no WantedBy
|
|
||||||
# entry)
|
|
||||||
|
|
||||||
# Flatcar: enable systemd-sysext.service by default
|
|
||||||
builddir_systemd_enable_service sysinit.target systemd-sysext.service
|
|
||||||
|
|
||||||
# Flatcar: Use an empty preset file, because systemctl
|
|
||||||
# preset-all puts symlinks in /etc, not in /usr. We don't use
|
|
||||||
# /etc, because it is not autoupdated. We do the "preset" above.
|
|
||||||
rm "${ED}/usr/lib/systemd/system-preset/90-systemd.preset" || die
|
|
||||||
insinto /usr/lib/systemd/system-preset
|
|
||||||
doins "${FILESDIR}"/99-default.preset
|
|
||||||
|
|
||||||
# Flatcar: Do not ship distro-specific files (nsswitch.conf
|
|
||||||
# pam.d). This conflicts with our own configuration provided
|
|
||||||
# by baselayout.
|
|
||||||
rm -rf "${ED}"/usr/share/factory
|
|
||||||
sed -i "${ED}"/usr/lib/tmpfiles.d/etc.conf \
|
|
||||||
-e '/^C!* \/etc\/nsswitch\.conf/d' \
|
|
||||||
-e '/^C!* \/etc\/pam\.d/d' \
|
|
||||||
-e '/^C!* \/etc\/issue/d'
|
|
||||||
|
|
||||||
use ukify && python_fix_shebang "${ED}"
|
use ukify && python_fix_shebang "${ED}"
|
||||||
use boot && secureboot_auto_sign
|
use boot && secureboot_auto_sign
|
||||||
}
|
}
|
||||||
|
|
||||||
# Flatcar: Our own version of systemd_get_systemunitdir, that returns
|
|
||||||
# a path inside /usr, not /etc.
|
|
||||||
builddir_systemd_get_systemunitdir() {
|
|
||||||
echo "$(get_rootprefix)/lib/systemd/system"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Flatcar: Our own version of systemd_enable_service, that does
|
|
||||||
# operations inside /usr, not /etc.
|
|
||||||
builddir_systemd_enable_service() {
|
|
||||||
local target=${1}
|
|
||||||
local service=${2}
|
|
||||||
local ud=$(builddir_systemd_get_systemunitdir)
|
|
||||||
local destname=${service##*/}
|
|
||||||
|
|
||||||
dodir "${ud}"/"${target}".wants && \
|
|
||||||
dosym ../"${service}" "${ud}"/"${target}".wants/"${destname}"
|
|
||||||
|
|
||||||
if use boot; then
|
|
||||||
python_fix_shebang "${ED}"
|
|
||||||
secureboot_auto_sign
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
migrate_locale() {
|
migrate_locale() {
|
||||||
local envd_locale_def="${EROOT}/etc/env.d/02locale"
|
local envd_locale_def="${EROOT}/etc/env.d/02locale"
|
||||||
local envd_locale=( "${EROOT}"/etc/env.d/??locale )
|
local envd_locale=( "${EROOT}"/etc/env.d/??locale )
|
||||||
@ -675,23 +506,6 @@ pkg_preinst() {
|
|||||||
dosym ../../../etc/sysctl.conf /usr/lib/sysctl.d/99-sysctl.conf
|
dosym ../../../etc/sysctl.conf /usr/lib/sysctl.d/99-sysctl.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Flatcar: This used to be in upstream ebuild, but now it's
|
|
||||||
# gone. We should drop it once we get rid of split-usr in SDK.
|
|
||||||
if ! use split-usr; then
|
|
||||||
local dir
|
|
||||||
# Flatcar: We still use separate bin and sbin, so drop usr/sbin from the list.
|
|
||||||
for dir in bin sbin lib; do
|
|
||||||
if [[ ! -L ${EROOT}/${dir} ]]; then
|
|
||||||
eerror "'${EROOT}/${dir}' is not a symbolic link."
|
|
||||||
FAIL=1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ ${FAIL} ]]; then
|
|
||||||
eerror "Migration to system layout with merged directories must be performed before"
|
|
||||||
eerror "installing ${CATEGORY}/${PN} with USE=\"-split-usr\" to avoid run-time breakage."
|
|
||||||
die "System layout with split directories still used"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
if ! use boot && has_version "sys-apps/systemd[gnuefi(-)]"; then
|
if ! use boot && has_version "sys-apps/systemd[gnuefi(-)]"; then
|
||||||
ewarn "The 'gnuefi' USE flag has been renamed to 'boot'."
|
ewarn "The 'gnuefi' USE flag has been renamed to 'boot'."
|
||||||
ewarn "Make sure to enable the 'boot' USE flag if you use systemd-boot."
|
ewarn "Make sure to enable the 'boot' USE flag if you use systemd-boot."
|
||||||
@ -711,15 +525,13 @@ pkg_postinst() {
|
|||||||
# between OpenRC & systemd
|
# between OpenRC & systemd
|
||||||
migrate_locale
|
migrate_locale
|
||||||
|
|
||||||
# Flatcar: We enable getty and remote-fs targets in /usr
|
if [[ -z ${REPLACING_VERSIONS} ]]; then
|
||||||
# ourselves above.
|
if type systemctl &>/dev/null; then
|
||||||
# if [[ -z ${REPLACING_VERSIONS} ]]; then
|
systemctl --root="${ROOT:-/}" enable getty@.service remote-fs.target || FAIL=1
|
||||||
# if type systemctl &>/dev/null; then
|
fi
|
||||||
# systemctl --root="${ROOT:-/}" enable getty@.service remote-fs.target || FAIL=1
|
elog "To enable a useful set of services, run the following:"
|
||||||
# fi
|
elog " systemctl preset-all --preset-mode=enable-only"
|
||||||
# elog "To enable a useful set of services, run the following:"
|
fi
|
||||||
# elog " systemctl preset-all --preset-mode=enable-only"
|
|
||||||
# fi
|
|
||||||
|
|
||||||
if [[ -L ${EROOT}/var/lib/systemd/timesync ]]; then
|
if [[ -L ${EROOT}/var/lib/systemd/timesync ]]; then
|
||||||
rm "${EROOT}/var/lib/systemd/timesync"
|
rm "${EROOT}/var/lib/systemd/timesync"
|
Loading…
x
Reference in New Issue
Block a user