]> git.ipfire.org Git - thirdparty/dracut.git/log
thirdparty/dracut.git
3 years agoci: install sudo for the debian container 1744/head
Laszlo Gombos [Mon, 2 May 2022 01:22:55 +0000 (01:22 +0000)] 
ci: install sudo for the debian container

3 years agodocs(dracut.usage): fix dracut.cmdline reference from section 5 to 7
Morten Linderud [Mon, 14 Mar 2022 09:02:15 +0000 (10:02 +0100)] 
docs(dracut.usage): fix dracut.cmdline reference from section 5 to 7

Signed-off-by: Morten Linderud <morten@linderud.pw>
3 years agofix(dmsquash-live): mount live device with the correct type
Laszlo Gombos [Sat, 12 Mar 2022 18:01:49 +0000 (18:01 +0000)] 
fix(dmsquash-live): mount live device with the correct type

fstype is not the correct type for the live device.

3 years agoci: add Debian Linux to limited tests
Laszlo Gombos [Sat, 12 Mar 2022 15:06:45 +0000 (15:06 +0000)] 
ci: add Debian Linux to limited tests

3 years agofix(dracut.sh): avoid calling dfatal before dracut-logger is sourced
Antonio Alvarez Feijoo [Wed, 30 Mar 2022 07:27:17 +0000 (09:27 +0200)] 
fix(dracut.sh): avoid calling dfatal before dracut-logger is sourced

dracut-logger is sourced in dracut-init, so any earlier calls to logger
functions before dracut-init is sourced fail.

Fix issue #1758

3 years agofix(dracut.spec): add connman module
Jóhann B. Guðmundsson [Tue, 26 Apr 2022 06:58:04 +0000 (06:58 +0000)] 
fix(dracut.spec): add connman module

Add the connman module to the spec file

3 years agofeat(dracut-systemd): use Documentation= to point to man page
David Tardon [Mon, 25 Apr 2022 14:45:20 +0000 (16:45 +0200)] 
feat(dracut-systemd): use Documentation= to point to man page

3 years agofix(dracut-systemd): drop misleading man page reference
David Tardon [Mon, 25 Apr 2022 14:52:26 +0000 (16:52 +0200)] 
fix(dracut-systemd): drop misleading man page reference

dracut-shutdown.service is not a part of the boot process, therefore the
reference to dracut.bootup(7) is misleading.

3 years agofix(fedora.conf): vi binary is missing
Masahiro Matsuya [Tue, 15 Feb 2022 09:09:43 +0000 (18:09 +0900)] 
fix(fedora.conf): vi binary is missing

/usr/bin/vi is just a wrapper shell script to run /usr/libexec/vi which is the vi binary.
/usr/bin/vi is available in initrd.img, but /usr/libexec/vi is missing.
As as result, vi command never works.
This PR is to add /usr/libexec/vi.

3 years agofix(man): add missing default paths
Antonio Alvarez Feijoo [Fri, 22 Apr 2022 16:23:01 +0000 (18:23 +0200)] 
fix(man): add missing default paths

3 years agofix(lsinitrd.sh): add missing default paths
Antonio Alvarez Feijoo [Fri, 22 Apr 2022 16:22:25 +0000 (18:22 +0200)] 
fix(lsinitrd.sh): add missing default paths

3 years agofix(dracut.sh): add missing default output file paths
Antonio Alvarez Feijoo [Fri, 22 Apr 2022 16:21:45 +0000 (18:21 +0200)] 
fix(dracut.sh): add missing default output file paths

3 years agofix(kernel-network-modules): allow specifying empty --hostonly-nics
Coiby Xu [Sun, 24 Apr 2022 02:52:33 +0000 (10:52 +0800)] 
fix(kernel-network-modules): allow specifying empty --hostonly-nics

Commit 1e92f728 ("Add a --hostonly-nics option") allows only installing
the network drivers for specified NICs. But it doesn't allow an emtpy
--hostonly-nics. Specifying empty hostonly-nics is needed to address the
following use cases,
 - drivers/s390/net is installed regardless of --hostonly-nics. There is
   no need to repeat it.
 - get_dev_module couldn't find the driver for a bond or a bridge
   network interface so it's better for a module to install a bond
   or bridge driver itself
 - dracut kdump module wants to install the needed network drivers by
   itself because it can't add the --hostonly-nics option to dracut when
   itself is a dracut module

This patch distinguishes between an empty --hostonly-nics and --hostonly-nics
not added so a user can pass an empty --hostonly-nics option.

3 years agofix(nfs): give /run/rpcbind ownership to rpc user
Antonio Alvarez Feijoo [Wed, 20 Apr 2022 13:33:51 +0000 (15:33 +0200)] 
fix(nfs): give /run/rpcbind ownership to rpc user

Avoid errors when rpcbind tries to write to the /run/rpcbind directory.

3 years agofix(nfs): require and install needed binaries
Antonio Alvarez Feijoo [Wed, 20 Apr 2022 13:32:54 +0000 (15:32 +0200)] 
fix(nfs): require and install needed binaries

parse-nfsroot.sh requires sed, chmod and chown.

3 years agofix(lvm): add missing grep requirement
Antonio Alvarez Feijoo [Mon, 11 Apr 2022 06:33:17 +0000 (08:33 +0200)] 
fix(lvm): add missing grep requirement

Since commit https://github.com/dracutdevs/dracut/commit/7ffc5e38
lvm_scan.sh needs grep.

3 years agofix(resume): correct call to block_is_netdevice function
Antonio Alvarez Feijoo [Fri, 1 Apr 2022 08:04:30 +0000 (10:04 +0200)] 
fix(resume): correct call to block_is_netdevice function

The block_is_netdevice function requires the device in <maj:min>
format, but the swap_devs array is populated with the content of
/proc/swaps, which prints the devices using their paths from /dev.

This causes the check method to never detect if swap is mounted on a
network device.

3 years agofix(dracut-functions.sh): correct wrong comment
Antonio Alvarez Feijoo [Fri, 1 Apr 2022 07:28:16 +0000 (09:28 +0200)] 
fix(dracut-functions.sh): correct wrong comment

3 years agofix(dracut.cmdline.7): {=> must} also be specified
наб [Mon, 4 Apr 2022 15:44:46 +0000 (17:44 +0200)] 
fix(dracut.cmdline.7): {=> must} also be specified

3 years agofix(ifcfg): avoid calling unavailable dracut-logger functions
Antonio Alvarez Feijoo [Wed, 6 Apr 2022 08:25:23 +0000 (10:25 +0200)] 
fix(ifcfg): avoid calling unavailable dracut-logger functions

The dracut-logger functions are only available during the initrd
generation. For internal initrd scripts that run at boot,
dracut-lib provides warn() and info().

3 years agofix(network-manager): avoid calling unavailable dracut-logger functions
Antonio Alvarez Feijoo [Wed, 6 Apr 2022 08:23:53 +0000 (10:23 +0200)] 
fix(network-manager): avoid calling unavailable dracut-logger functions

The dracut-logger functions are only available during the initrd
generation. For internal initrd scripts that run at boot,
dracut-lib provides warn() and info().

3 years agofeat(man): add documentation for rd.luks.key.tout
Nicolas Porcel [Mon, 28 Feb 2022 19:31:56 +0000 (19:31 +0000)] 
feat(man): add documentation for rd.luks.key.tout

3 years agofix(crypt): add missing is_keysource parameter to cryptroot-ask
Nicolas Porcel [Mon, 28 Feb 2022 18:48:04 +0000 (18:48 +0000)] 
fix(crypt): add missing is_keysource parameter to cryptroot-ask

Without this change, rd.luks.key.tout is used, which is the number of
times cryptroot tries to find the key.

3 years agofix(man): add missing --libdirs section
Antonio Alvarez Feijoo [Mon, 4 Apr 2022 16:01:05 +0000 (18:01 +0200)] 
fix(man): add missing --libdirs section

3 years agofix(dracut.sh): add missing --libdirs usage
Antonio Alvarez Feijoo [Mon, 4 Apr 2022 15:50:23 +0000 (17:50 +0200)] 
fix(dracut.sh): add missing --libdirs usage

3 years agofix(nvmf): set executable bit on nvmf-autoconnect.sh
Benjamin Gilbert [Thu, 7 Apr 2022 22:10:35 +0000 (18:10 -0400)] 
fix(nvmf): set executable bit on nvmf-autoconnect.sh

It's installed in /sbin, and run via initqueue in the special case of FC
transport without a discovery.conf and without kernel arguments.  If the
executable bit is not set, initqueue fails with "Invalid command".

Caught by CI checking for non-executable files in binary directories.

3 years agofeat(url-lib.sh): add --retry-connrefused to default curl arguments
James Morris [Thu, 7 Apr 2022 16:57:48 +0000 (17:57 +0100)] 
feat(url-lib.sh): add --retry-connrefused to default curl arguments

Trigger the existing retry condition on connection refused
to mitigate transient connectivity issues.

3 years agofix(dracut-install): copy files preserving ownership attributes
Antonio Alvarez Feijoo [Mon, 4 Apr 2022 09:55:59 +0000 (11:55 +0200)] 
fix(dracut-install): copy files preserving ownership attributes

While the "clone copy" operation changes the ownership of the cloned
files, the "normal copy" using cp does not preserve it.

3 years agodocs: do not mention nullglob in cases where it's not needed
Pavel Valena [Fri, 25 Mar 2022 16:39:04 +0000 (17:39 +0100)] 
docs: do not mention nullglob in cases where it's not needed

3 years agofix(10i18n): stop leaking shell options
Pavel Valena [Fri, 25 Mar 2022 16:26:19 +0000 (17:26 +0100)] 
fix(10i18n): stop leaking shell options

Avoid using shell options in findkeymap, instead of using a wrapper[*]
to restore the previous options. Using mapfile and find to generate the list
of files also has the benefit of being more readable in this case.

[*] Reverted commit 35064768ebf14d3ec6bf3f7df52580fb4920ea3d
Original issue description from Michal Hecko <mhecko@redhat.com>:

The findkeymap function manipulates the shell options and relies on
restoring them using the trap. However, as the function might be called
recursively, each recursive invocation changes the signal handler to its
own. As the recursion is entered with shell options already modified,
the changed trap handler is replaced with restoration to the modified
shell options, not the original ones.

3 years agorevert(10i18n): stop leaking shell options
Pavel Valena [Fri, 25 Mar 2022 16:00:53 +0000 (17:00 +0100)] 
revert(10i18n): stop leaking shell options

This reverts commit 35064768ebf14d3ec6bf3f7df52580fb4920ea3d, to replace
the implementation.

3 years agofix(test): nullglob should not be needed
Pavel Valena [Fri, 25 Mar 2022 15:57:28 +0000 (16:57 +0100)] 
fix(test): nullglob should not be needed

3 years agofix(dracut-install): do not fail when SOURCE is optional and missing
Pavel Valena [Fri, 25 Mar 2022 15:20:16 +0000 (16:20 +0100)] 
fix(dracut-install): do not fail when SOURCE is optional and missing

When running dracut-install with '-o' (optional source), and nullglob
at the same time, when all of the arguments evaluate <null>, dracut-install
should not fail even when the source is not specified.

3 years agofix(bluetooth): nullglob should not be needed
Pavel Valena [Fri, 25 Mar 2022 15:39:55 +0000 (16:39 +0100)] 
fix(bluetooth): nullglob should not be needed

3 years agoci: obsolete Dockerfile with Fedora 33
Pavel Valena [Mon, 4 Apr 2022 04:40:26 +0000 (06:40 +0200)] 
ci: obsolete Dockerfile with Fedora 33

3 years agoci: add Dockerfile for Fedora 35
Pavel Valena [Mon, 4 Apr 2022 04:40:08 +0000 (06:40 +0200)] 
ci: add Dockerfile for Fedora 35

3 years agofix(dracut-initramfs-restore.sh): unpack uncompressed initrd as last option
Antonio Alvarez Feijoo [Fri, 18 Mar 2022 14:42:42 +0000 (15:42 +0100)] 
fix(dracut-initramfs-restore.sh): unpack uncompressed initrd as last option

Attempting to unpack the initrd assuming it is uncompressed when
it is delays the shutdown process by several seconds. This must
be the last check.

3 years agofix(configure): check for SYS-gettid during configure
Shreenidhi Shedi [Tue, 15 Mar 2022 11:30:14 +0000 (17:00 +0530)] 
fix(configure): check for SYS-gettid during configure

Signed-off-by: Shreenidhi Shedi <sshedi@vmware.com>
3 years agofix(lvm): ignore expected error message from lvm config
David Teigland [Mon, 28 Mar 2022 14:35:11 +0000 (09:35 -0500)] 
fix(lvm): ignore expected error message from lvm config

The "lvm config" commands that check the filter settings will
often find nothing set and report an error message:
"Configuration node devices/filter not found"
Direct these messages to /dev/null so they do not appear as
noise in system logs.

3 years agofix(connman): copy netroot.sh from the network module and install it
Zoltán Böszörményi [Sat, 26 Mar 2022 11:36:05 +0000 (12:36 +0100)] 
fix(connman): copy netroot.sh from the network module and install it

As requested by johannbg.

Signed-off-by: Zoltán Böszörményi <zboszor@gmail.com>
3 years agofeat(connman): introduce connman support module
Zoltán Böszörményi [Thu, 24 Mar 2022 09:48:00 +0000 (10:48 +0100)] 
feat(connman): introduce connman support module

Signed-off-by: Zoltán Böszörményi <zboszor@gmail.com>
3 years agofix(plymouth): hide dpkg-architecture stderr messages
Antonio Alvarez Feijoo [Wed, 16 Mar 2022 16:01:37 +0000 (17:01 +0100)] 
fix(plymouth): hide dpkg-architecture stderr messages

dpkg-architecture prints warnings and errors to stderr. If the system does
not have gcc installed, it issues a warning:

dpkg-architecture: warning: cannot determine CC system type, falling back to default (native compilation)

This fix checks only the value of the queried variable.

3 years agostyle: remove accidental whitespace in front of comment line
nkraetzschmar [Wed, 23 Mar 2022 08:44:45 +0000 (09:44 +0100)] 
style: remove accidental whitespace in front of comment line

3 years agofeat: add aarch64 uefi support
nkraetzschmar [Tue, 22 Mar 2022 19:52:46 +0000 (20:52 +0100)] 
feat: add aarch64 uefi support

3 years agofix(udev-rules): add cdrom udev rules by default
Laszlo Gombos [Mon, 14 Mar 2022 16:56:04 +0000 (16:56 +0000)] 
fix(udev-rules): add cdrom udev rules by default

Include cdrom udev rules by default, even if
systemd-udevd or dmsquash-live dracut modules
are not installed.

3 years agofix(dracut-initramfs-restore.sh): check if SELINUXTYPE is set
David Tardon [Fri, 11 Mar 2022 13:04:16 +0000 (14:04 +0100)] 
fix(dracut-initramfs-restore.sh): check if SELINUXTYPE is set

It can happen that SELINUXTYPE is not set, e.g., in Fedora/RHEL
installation images /etc/selinux/config is an empty file. That means
that setfiles fails, which makes dracut-initramfs-restore fail too
because it uses "set -x", which means that dracut-shutdown.service
fails. But, after commit 7ab1d00227cad6f1b86ba01fdc766769faebb031, a
failure of dracut-shutdown.service means that the final switch back into
initrd is skipped. Let's just add an additional sanity check to
workaround that.

3 years agofix(bluetooth): make $dbussystem/bluetooth.conf optional
Antonio Alvarez Feijoo [Wed, 16 Mar 2022 08:08:34 +0000 (09:08 +0100)] 
fix(bluetooth): make $dbussystem/bluetooth.conf optional

Do not display an error message if $dbussystem/bluetooth.conf file don't exist.

3 years agofix(dracut-systemd): correct service dependencies
David Tardon [Mon, 14 Mar 2022 09:48:44 +0000 (10:48 +0100)] 
fix(dracut-systemd): correct service dependencies

dracut-systemd.service is not an early boot service, therefore it should
not use DefaultDependencies=no. This also fixes the service's ordering
dependencies, as in its current state it is missing
Before=shutdown.target umount.target

3 years agofix(10i18n): stop leaking shell options
Michal Hecko [Mon, 21 Feb 2022 09:59:27 +0000 (10:59 +0100)] 
fix(10i18n): stop leaking shell options

The findkeymap function manipulates the shell options and relies on
restoring them using the trap. However, as the function might be called
recursively, each recursive invocation changes the signal handler to its
own. As the recursion is entered with shell options already modified,
the changed trap handler is replaced with restoration to the modified
shell options, not the original ones. This patch wraps the findkeymap
function so that the shellopts are manipulated and restored outside the
recursion.

3 years agofix(dracut.sh): drop restorecon call
David Tardon [Thu, 3 Mar 2022 09:47:46 +0000 (10:47 +0100)] 
fix(dracut.sh): drop restorecon call

AFAICT there is no need for it. cp already applies appropriate label on
the target file (unless --preserve=context is used).

3 years agofix(dmsquash-live): permanent overlay on the same drive as LiveCD .iso
Laszlo Gombos [Fri, 18 Feb 2022 01:49:31 +0000 (20:49 -0500)] 
fix(dmsquash-live): permanent overlay on the same drive as LiveCD .iso

An example kernel command line arguments for this configuration
iso-scan/filename=distro.iso root=live:CDLABEL=ISO
rd.live.image rd.live.overlay=/dev/sda:/overlay.img

iso-scan would mount /dev/sda first and keep it mounted. The change
allows detecting if the permanent overlay drive is already mounted.
It also ensures that the mount is writable, as permanent overlay
requires writable storage.

3 years agofix(install): restore musl support
Laszlo Gombos [Mon, 21 Feb 2022 03:23:49 +0000 (22:23 -0500)] 
fix(install): restore musl support

__GLIBC_PREREQ is only defined in glibc.

3 years agofix(github): remove packit
Jóhann B. Guðmundsson [Sat, 19 Feb 2022 16:53:48 +0000 (16:53 +0000)] 
fix(github): remove packit

It's been a year since I initially made the PR to include packit.

Having it has resulted in increasing the project's cost of development
( CoD ) thus defeating the initial purpose of including it, which was an attempt
to do the opposite as in to reduce it, thus removing it.

My take on this after a year in use is that the concept is flawed,
limited to a single distribution and cannot work in practice without
adding to upstreams and it's contributors CoD but other projects milage
may vary.

3 years agofeat(dracut): add zfs detection
Savyasachee Jha [Thu, 17 Feb 2022 19:26:03 +0000 (00:56 +0530)] 
feat(dracut): add zfs detection

zfs detection is currently done by the zfs dracut module installed by
downstream, resulting in a lot of duplicated code. This commit puts zfs
detection into the core dracut logic, allowing for detection of zfs
partitions to be done at the same time as all others. It also allows for
dracut to correctly create a `root=` cmdline parameter for zfs.

Signed-off-by: Savyasachee Jha <hi@savyasacheejha.com>
3 years agofix(dracut.sh): error exporting sysctl variables
Antonio Alvarez Feijoo [Thu, 24 Feb 2022 08:36:02 +0000 (09:36 +0100)] 
fix(dracut.sh): error exporting sysctl variables

- Typo assigning depmodd and depmodconfdir.
- Typo exporting a variable called sysctl instead of sysctld.

3 years agofix(iscsi): remove unneeded iscsi NOP-disable code
Lee Duncan [Thu, 24 Feb 2022 17:22:23 +0000 (09:22 -0800)] 
fix(iscsi): remove unneeded iscsi NOP-disable code

Commit 7374943ae3d06 ("fix(iscsi): add support for the new iscsiadm
"no-wait" (-W) command") added some code to try to disable iscsi's
NOPs, since they are considered "bad" for an iscsi root disc,
but that code doesn't work because the session is already established
at this point. Open-iscsi will change so that it automatically
disables NOPs for the root disc, so this code can just go away.

3 years agofix(systemd-journald): remove duplicate entry in inst_multiple
Antonio Alvarez Feijoo [Mon, 21 Feb 2022 14:15:54 +0000 (15:15 +0100)] 
fix(systemd-journald): remove duplicate entry in inst_multiple

3 years agofix(systemd-timesyncd): add systemd-sysusers dependency
Antonio Alvarez Feijoo [Tue, 22 Feb 2022 14:53:09 +0000 (15:53 +0100)] 
fix(systemd-timesyncd): add systemd-sysusers dependency

This systemd-timesyncd module depends on systemd-sysusers after the split of
systemd sysuser configs (https://github.com/dracutdevs/dracut/commit/fec93bb22181f80056b40231fca36c422248ade0).

3 years agofix(systemd-coredump): add systemd-sysusers dependency
Antonio Alvarez Feijoo [Tue, 22 Feb 2022 14:46:25 +0000 (15:46 +0100)] 
fix(systemd-coredump): add systemd-sysusers dependency

The systemd-coredump module depends on systemd-sysusers after the split of
systemd sysuser configs (https://github.com/dracutdevs/dracut/commit/fec93bb22181f80056b40231fca36c422248ade0).

3 years agofeat(squash): add shell completion for --squash-compressor option
Tao Liu [Mon, 14 Feb 2022 07:13:27 +0000 (15:13 +0800)] 
feat(squash): add shell completion for --squash-compressor option

Signed-off-by: Tao Liu <ltao@redhat.com>
3 years agofeat(squash): update the manual page for --squash-compressor
Tao Liu [Mon, 14 Feb 2022 07:12:47 +0000 (15:12 +0800)] 
feat(squash): update the manual page for --squash-compressor

Signed-off-by: Tao Liu <ltao@redhat.com>
3 years agofeat(squash): decouple the compressor for dracut and dracut-squash
Tao Liu [Mon, 14 Feb 2022 07:11:35 +0000 (15:11 +0800)] 
feat(squash): decouple the compressor for dracut and dracut-squash

Previously dracut-squash module inherits the compressor
name from dracut, but actually the compressors are totally
different. For dracut, the compressor is zstd/gzip/lzop
cmdline tools, for dracut-squash, the compressor is the
libzstd/libz/liblzo libraries integrated by mksquashfs.

However mksquashfs support less compressors than dracut,
such as bzip2, which is not supported by mksquashfs, so
compressor decoupling seems to be a good idea to handle this.

This patch introduces a new dracut cmdline argument
--squash-compressor, by which the compressor and compressor
specific options can be passed to mksquashfs as
--squash-compressor "lzo -Xalgorithm lzo1x_1_15".

Signed-off-by: Tao Liu <ltao@redhat.com>
3 years agodocs: update NEWS.md and AUTHORS 056
Harald Hoyer [Fri, 18 Feb 2022 11:32:53 +0000 (12:32 +0100)] 
docs: update NEWS.md and AUTHORS

Signed-off-by: Harald Hoyer <harald@profian.com>
3 years agofix(cpio): correct dev_t -> rmajor/rminor mapping
David Disseldorp [Thu, 10 Feb 2022 19:08:11 +0000 (20:08 +0100)] 
fix(cpio): correct dev_t -> rmajor/rminor mapping

dev_t -> major/minor number mapping is more complicated than the
incorrect major=(dev_t >> 8) minor=(dev_t & 0xff) mapping that we
currently perform. Fix mapping to match Linux / glibc behaviour.

Fixes: https://github.com/dracutdevs/dracut/issues/1695
Reported-by: Ethan Wu <ethanwu10@gmail.com>
Signed-off-by: David Disseldorp <ddiss@suse.de>
3 years agoci(cpio): add test_archive_dev_maj_min
David Disseldorp [Thu, 10 Feb 2022 17:05:21 +0000 (18:05 +0100)] 
ci(cpio): add test_archive_dev_maj_min

This tests dracut-cpio's handling of rmajor / rminor values compared to
GNU cpio. The test requires root, due to mknod invocation for block
device node creation.

Signed-off-by: David Disseldorp <ddiss@suse.de>
3 years agoci(cpio): add TempWorkDir.create_tmp_mknod helper
David Disseldorp [Mon, 7 Feb 2022 22:04:29 +0000 (23:04 +0100)] 
ci(cpio): add TempWorkDir.create_tmp_mknod helper

This will be used for future device major/minor testing. Convert the
current fifo test to use it.

Signed-off-by: David Disseldorp <ddiss@suse.de>
3 years agofix(dasd_rules): correct udev dasd rules parsing
Thomas Blume [Mon, 7 Feb 2022 08:56:42 +0000 (09:56 +0100)] 
fix(dasd_rules): correct udev dasd rules parsing

3 years agofix(zfcp_rules): correct udev zfcp rules parsing
Thomas Blume [Mon, 7 Feb 2022 08:58:32 +0000 (09:58 +0100)] 
fix(zfcp_rules): correct udev zfcp rules parsing

3 years agofeat(pcsc): introducing the pcsc module
Jóhann B. Guðmundsson [Sat, 1 Jan 2022 03:00:15 +0000 (03:00 +0000)] 
feat(pcsc): introducing the pcsc module

3 years agofix(bluetooth): make hostonly configuration files optional
Antonio Alvarez Feijoo [Mon, 31 Jan 2022 11:09:02 +0000 (12:09 +0100)] 
fix(bluetooth): make hostonly configuration files optional

Do not fail if any of the expected configuration files don't exist.

3 years agofix(bluetooth): dbus configuration path fixes
Jóhann B. Guðmundsson [Sat, 11 Dec 2021 22:28:45 +0000 (22:28 +0000)] 
fix(bluetooth): dbus configuration path fixes

Add a missing /usr/share path ( fixes #1627 )
Use variable instead of hard path

3 years agofix(img-lib): install rmdir
Henrik Gombos [Thu, 25 Nov 2021 23:08:57 +0000 (18:08 -0500)] 
fix(img-lib): install rmdir

rmdir is used in img-lib module.

3 years agofix(fido2): add a missing library
Jóhann B. Guðmundsson [Wed, 29 Dec 2021 00:19:09 +0000 (00:19 +0000)] 
fix(fido2): add a missing library

3 years agofix(tpm2-tss): add a missing library
Jóhann B. Guðmundsson [Wed, 29 Dec 2021 00:16:56 +0000 (00:16 +0000)] 
fix(tpm2-tss): add a missing library

3 years agofix(dracut-functions.sh): ip route parsing
Martin Wilck [Fri, 21 Jan 2022 20:25:54 +0000 (21:25 +0100)] 
fix(dracut-functions.sh): ip route parsing

The code for determining local interface and address works
only for peers that are reachable in a single hop.

This is parsed correctly:
192.168.110.1 dev br0 src 192.168.110.160 uid 0 \    cache

But this isn't:
192.168.1.4 via 192.168.110.1 dev br0 src 192.168.110.160 uid 0 \    cache

Fix it.

Fixes: ceca74cc ("dracut-functions: add ip_params_for_remote_addr() helper")
3 years agofix(fedora.conf.example): rename misspelled variable
Antonio Alvarez Feijoo [Mon, 31 Jan 2022 14:24:51 +0000 (15:24 +0100)] 
fix(fedora.conf.example): rename misspelled variable

There is a typo in the dbussystemconfdir variable.

3 years agofix(dracut): be more robust when using 'set -u'
Renaud Métrich [Thu, 6 Jan 2022 18:50:28 +0000 (19:50 +0100)] 
fix(dracut): be more robust when using 'set -u'

From bash manpage, FUNCNAME exists only inside functions. When in debug
mode, make sure to use an empty default value as FUNCNAME[0] when
outside of functions.

With bash4 this wasn't an issue, but is with bash5 with hardening option
'set -u' used, as shown in the example below:

Incorrect:

$ bash -u -c 'echo -n ${FUNCNAME[0]}'
bash: line 1: FUNCNAME[0]: unbound variable
$

Correct:

$ bash -u -c 'echo -n ${FUNCNAME[0]-}'
$

This hardening enables sourcing dracut-lib.sh from external utilities
executing in the initramfs such as clevis-luks-askpass, which uses
hardening option 'set -u' internally.
(see Clevis PR https://github.com/latchset/clevis/pull/340)

Signed-off-by: Renaud Métrich <rmetrich@redhat.com>
3 years agofeat(pkcs11): include the module in the spec file
Jóhann B. Guðmundsson [Fri, 31 Dec 2021 10:32:25 +0000 (10:32 +0000)] 
feat(pkcs11): include the module in the spec file

Adding the module to the spec file

3 years agofeat(pkcs11): introducing the pkcs11 module
Jóhann B. Guðmundsson [Wed, 29 Dec 2021 13:03:16 +0000 (13:03 +0000)] 
feat(pkcs11): introducing the pkcs11 module

This module allows unlocking of an encrypted filesystem using pkcs11.

3 years agofeat(crypt): check if pkcs11 module is needed in hostonly mode
Jóhann B. Guðmundsson [Wed, 29 Dec 2021 09:55:02 +0000 (09:55 +0000)] 
feat(crypt): check if pkcs11 module is needed in hostonly mode

In hostonly mode, include the pkcs11 module if any encrypted volumes
are configured to be decrypted using pkcs11.

3 years agofix(fips): missing sourcing of dracut-lib
Antonio Alvarez Feijoo [Tue, 14 Dec 2021 11:18:07 +0000 (12:18 +0100)] 
fix(fips): missing sourcing of dracut-lib

Make sure dracut-lib is sourced inside the fips-noboot script.

3 years agofix(fips): add and remove local variables
Antonio Alvarez Feijoo [Tue, 14 Dec 2021 11:15:41 +0000 (12:15 +0100)] 
fix(fips): add and remove local variables

3 years agofix(fips): wrong error message
Antonio Alvarez Feijoo [Tue, 14 Dec 2021 11:14:41 +0000 (12:14 +0100)] 
fix(fips): wrong error message

When /dev/urandom cannot be created, the error message displays /dev/random instead.

3 years agofix(dracut-init): unbreak a comment
Lubomir Rintel [Wed, 5 Jan 2022 10:10:27 +0000 (11:10 +0100)] 
fix(dracut-init): unbreak a comment

A dreadful copy & paste or kill-ring-save & yank error, most surely.

3 years agofeat(dracut.sh): add --aggresive-strip option
Kairui Song [Fri, 7 Jan 2022 06:03:20 +0000 (14:03 +0800)] 
feat(dracut.sh): add --aggresive-strip option

Dracut currently calls `eu-strip` or `strip` with -g, which only strips
out .debug_* sections. symtab and strtab are kept, but are not required
for runtime, and people will rarely need to do binary level debugging
work in initramfs.

So introduce a --aggresive-strip options, try strip out all sections
that are not required for runtime. This can help reduce the binary size
by a lot.

For example, the size of libc.so is reduced by a lot when stripped
with no option than with -g.

    3014184 libc-2.28.orig.so
    2970920 libc-2.28.strip-g.so
    1460904 libc-2.28.strip.so

Signed-off-by: Kairui Song <kasong@tencent.com>
3 years agofix(network): wrong test of wicked unit
Antonio Alvarez Feijoo [Mon, 10 Jan 2022 10:46:41 +0000 (11:46 +0100)] 
fix(network): wrong test of wicked unit

The test for the wicked service is never met because it
does not have execute permission.

3 years agofix(dracut-initramfs-restore.sh): add missing compression options
Antonio Alvarez Feijoo [Mon, 24 Jan 2022 15:38:45 +0000 (16:38 +0100)] 
fix(dracut-initramfs-restore.sh): add missing compression options

The unpack fails if the initrd is not compressed or compressed with
bzip2 or LZO.

Fix issue #1463

3 years agofix(dracut-shutdown): add cleanup handler on failure
Renaud Métrich [Thu, 13 Jan 2022 16:35:59 +0000 (17:35 +0100)] 
fix(dracut-shutdown): add cleanup handler on failure

It may happen that dracut-shutdown.service fails, for example on timeout
due to very low bandwidth.
In such case, for hardening purposes, a new dracut-shutdown-onfailure.service
unit doing dracut-shutdown.service cleanup needs to execute to make sure
switching root to an incomplete initramfs won't occur later.

See also RHBZ #1924587 (https://bugzilla.redhat.com/show_bug.cgi?id=1924587).

3 years agofix(zfcp_rules): remove collect based udev rule creators
Thomas Blume [Fri, 14 Jan 2022 09:40:17 +0000 (10:40 +0100)] 
fix(zfcp_rules): remove collect based udev rule creators

The collect binary has been removed, so the rules are broken

3 years agofix(dasd_rules): remove collect based udev rule creators
Thomas Blume [Fri, 14 Jan 2022 09:39:30 +0000 (10:39 +0100)] 
fix(dasd_rules): remove collect based udev rule creators

The collect binary has been removed, so the rules are broken

3 years agofix(memstrack): drop bash runtime requirement
Kairui Song [Thu, 6 Jan 2022 05:39:30 +0000 (13:39 +0800)] 
fix(memstrack): drop bash runtime requirement

Use nohup instead of disown, and let systemd track the service properly.
This makes the scripts POSIX compatible and bash is no longer needed.

Signed-off-by: Kairui Song <kasong@tencent.com>
3 years agofix(kernel-modules-extra): handle zstd module extension
Dirk Müller [Thu, 23 Dec 2021 09:23:59 +0000 (10:23 +0100)] 
fix(kernel-modules-extra): handle zstd module extension

The regular expression here is trying to handle various kernel
module compression schemas and was missing the zst extension
which indicates use of zstd.

3 years agofix(kernel-modules): add mailbox drivers for arm
Adrien Thierry [Mon, 20 Dec 2021 14:41:07 +0000 (09:41 -0500)] 
fix(kernel-modules): add mailbox drivers for arm

Mailbox drivers might be needed by some of the devices used in the
initrd. For example, on the Raspberry Pi 4, the MMC 'sdhci-iproc' driver
depends on 'bcm2835-mailbox'.

Signed-off-by: Adrien Thierry <athierry@redhat.com>
3 years agofix(lvm): restore setting LVM_MD_PV_ACTIVATED
David Teigland [Fri, 17 Dec 2021 18:14:51 +0000 (12:14 -0600)] 
fix(lvm): restore setting LVM_MD_PV_ACTIVATED

The 69-dm-lvm-metad.rules udev rule has been removed from
the initrd, because it's been dropped by recent upstream
lvm versions, and it never performed any primary function
within the initrd.  But, it did have the job of setting
LVM_MD_PV_ACTIVATED=1 for active md devices used by PVs.
That step needs to be restored, and is now included in
64-lvm.rules.

3 years agofeat(lvm): only run lvchange for LV that is seen on devices
David Teigland [Fri, 10 Dec 2021 18:51:26 +0000 (12:51 -0600)] 
feat(lvm): only run lvchange for LV that is seen on devices

Change the command listing LVs from lvscan to lvs, and list
only the LV names that are being activated.  Before attempting
to activate an LV, check that that LV name appears in the
lvs command output.  This avoids wasting time running an
lvchange command that we know will fail.

3 years agofeat(lvm): use generated filter when none is set
David Teigland [Wed, 8 Dec 2021 21:16:03 +0000 (15:16 -0600)] 
feat(lvm): use generated filter when none is set

Previously, the lvm device filter generated by dracut
would not be used if any lvm.conf file existed in the
initrd.  Change this so that the generated filter will
be used when the included lvm.conf has no filter set.

3 years agofeat(lvm): update lvm command options
David Teigland [Wed, 8 Dec 2021 20:43:58 +0000 (14:43 -0600)] 
feat(lvm): update lvm command options

Drop checking for options that have been available for
at least ten years.  This simplifies code maintenance.

Add the new --nohints option (when available) to disable
the use of hints which is not useful during startup.

3 years agofix(lvm): replace --partial option
David Teigland [Wed, 8 Dec 2021 20:14:27 +0000 (14:14 -0600)] 
fix(lvm): replace --partial option

The --partial option will activate a linear (or other) LV
without segments for missing devices, which is unlikely to
be useful. The intention was to activate raid LVs in a useful
form while missing devices, which is specified with the option
--activationmode degraded.

3 years agorevert(lvm): remove 69-dm-lvm-metad.rules
David Teigland [Wed, 8 Dec 2021 20:11:13 +0000 (14:11 -0600)] 
revert(lvm): remove 69-dm-lvm-metad.rules

This udev rule runs pvscan to autoactivate VGs, which dracut
does not want to do, and previously disabled by editing the
rule file and commenting out lines.

This also stops /dev/disk/by-id/lvm-pv-uuid-* symlinks from
being created in the initrd.

3 years agorevert(lvm): remove lvmetad config changes
David Teigland [Wed, 8 Dec 2021 20:07:42 +0000 (14:07 -0600)] 
revert(lvm): remove lvmetad config changes

Remove support for modifying use_lvmetad and locking_type
settings in lvm.conf for lvm versions 2.2.*.  Recent lvm
versions (2.3.*) do not include lvmetad or locking_type.
This cleanup simplifies code maintenance.

To use the lvm module with older versions (2.2), a user
would need to ensure that lvmetad settings are disabled
in the initrd's lvm.conf rather than relying on the lvm
dracut mode to modify their lvm.conf.