2020-04-24 23:36:52 +00:00
|
|
|
|
# Updating? Keep $out/etc synchronized with passthru keys
|
|
|
|
|
|
2021-12-06 16:07:01 +00:00
|
|
|
|
{ stdenv
|
|
|
|
|
, lib
|
2020-11-12 09:05:59 +00:00
|
|
|
|
, fetchFromGitHub
|
2022-08-12 12:06:08 +00:00
|
|
|
|
, gi-docgen
|
2020-09-25 04:45:31 +00:00
|
|
|
|
, pkg-config
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, gobject-introspection
|
2020-09-25 04:45:31 +00:00
|
|
|
|
, gettext
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, libgudev
|
2023-11-16 04:20:00 +00:00
|
|
|
|
, libdrm
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, polkit
|
|
|
|
|
, libxmlb
|
|
|
|
|
, gusb
|
|
|
|
|
, sqlite
|
|
|
|
|
, libarchive
|
2023-02-02 18:25:31 +00:00
|
|
|
|
, libredirect
|
2020-12-25 13:55:36 +00:00
|
|
|
|
, curl
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, libjcat
|
|
|
|
|
, elfutils
|
|
|
|
|
, valgrind
|
|
|
|
|
, meson
|
|
|
|
|
, libuuid
|
|
|
|
|
, ninja
|
2021-02-05 17:12:51 +00:00
|
|
|
|
, gnutls
|
2021-12-06 16:07:01 +00:00
|
|
|
|
, protobufc
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, python3
|
2022-08-12 12:06:08 +00:00
|
|
|
|
, wrapGAppsNoGuiHook
|
2023-02-02 18:25:31 +00:00
|
|
|
|
, ensureNewerSourcesForZipFilesHook
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, json-glib
|
|
|
|
|
, bash-completion
|
|
|
|
|
, shared-mime-info
|
|
|
|
|
, umockdev
|
|
|
|
|
, vala
|
|
|
|
|
, makeFontsConf
|
|
|
|
|
, freefont_ttf
|
|
|
|
|
, pango
|
|
|
|
|
, tpm2-tss
|
|
|
|
|
, bubblewrap
|
|
|
|
|
, efibootmgr
|
|
|
|
|
, flashrom
|
|
|
|
|
, tpm2-tools
|
2021-12-06 16:07:01 +00:00
|
|
|
|
, fwupd-efi
|
2020-04-24 23:36:52 +00:00
|
|
|
|
, nixosTests
|
2020-06-18 07:06:33 +00:00
|
|
|
|
, runCommand
|
2021-12-06 16:07:01 +00:00
|
|
|
|
, unstableGitUpdater
|
2022-03-10 19:12:11 +00:00
|
|
|
|
, modemmanager
|
|
|
|
|
, libqmi
|
|
|
|
|
, libmbim
|
2022-04-27 09:35:20 +00:00
|
|
|
|
, libcbor
|
|
|
|
|
, xz
|
2023-02-02 18:25:31 +00:00
|
|
|
|
, enableFlashrom ? false
|
2023-10-09 19:29:22 +00:00
|
|
|
|
, enablePassim ? false
|
2020-04-24 23:36:52 +00:00
|
|
|
|
}:
|
|
|
|
|
|
|
|
|
|
let
|
|
|
|
|
python = python3.withPackages (p: with p; [
|
2023-07-15 17:15:38 +00:00
|
|
|
|
jinja2
|
2020-04-24 23:36:52 +00:00
|
|
|
|
pygobject3
|
|
|
|
|
setuptools
|
|
|
|
|
]);
|
|
|
|
|
|
2021-12-06 16:07:01 +00:00
|
|
|
|
isx86 = stdenv.hostPlatform.isx86;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
|
|
# Dell isn't supported on Aarch64
|
|
|
|
|
haveDell = isx86;
|
|
|
|
|
|
|
|
|
|
# only redfish for x86_64
|
|
|
|
|
haveRedfish = stdenv.isx86_64;
|
|
|
|
|
|
2021-02-16 17:04:54 +00:00
|
|
|
|
# only use msr if x86 (requires cpuid)
|
|
|
|
|
haveMSR = isx86;
|
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
|
# # Currently broken on Aarch64
|
|
|
|
|
# haveFlashrom = isx86;
|
|
|
|
|
# Experimental
|
2023-02-02 18:25:31 +00:00
|
|
|
|
haveFlashrom = isx86 && enableFlashrom;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
runPythonCommand =
|
|
|
|
|
name:
|
|
|
|
|
buildCommandPython:
|
|
|
|
|
|
|
|
|
|
runCommand
|
|
|
|
|
name
|
|
|
|
|
{
|
|
|
|
|
nativeBuildInputs = [ python3 ];
|
|
|
|
|
inherit buildCommandPython;
|
|
|
|
|
}
|
|
|
|
|
''
|
|
|
|
|
exec python3 -c "$buildCommandPython"
|
|
|
|
|
'';
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2021-12-06 16:07:01 +00:00
|
|
|
|
test-firmware =
|
|
|
|
|
let
|
2024-05-15 15:35:15 +00:00
|
|
|
|
version = "0-unstable-2022-04-02";
|
2021-12-06 16:07:01 +00:00
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
|
name = "fwupd-test-firmware-${version}";
|
|
|
|
|
owner = "fwupd";
|
|
|
|
|
repo = "fwupd-test-firmware";
|
2023-02-02 18:25:31 +00:00
|
|
|
|
rev = "39954e434d63e20e85870dd1074818f48a0c08b7";
|
|
|
|
|
hash = "sha256-d4qG3fKyxkfN91AplRYqARFz+aRr+R37BpE450bPxi0=";
|
2021-12-06 16:07:01 +00:00
|
|
|
|
passthru = {
|
|
|
|
|
inherit src version; # For update script
|
|
|
|
|
updateScript = unstableGitUpdater {
|
|
|
|
|
url = "${test-firmware.meta.homepage}.git";
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
in
|
2023-03-04 12:14:45 +00:00
|
|
|
|
src // {
|
|
|
|
|
meta = src.meta // {
|
|
|
|
|
# For update script
|
|
|
|
|
position =
|
|
|
|
|
let
|
|
|
|
|
pos = builtins.unsafeGetAttrPos "updateScript" test-firmware;
|
|
|
|
|
in
|
|
|
|
|
pos.file + ":" + toString pos.line;
|
2021-12-06 16:07:01 +00:00
|
|
|
|
};
|
2020-09-25 04:45:31 +00:00
|
|
|
|
};
|
2023-03-04 12:14:45 +00:00
|
|
|
|
in
|
|
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
|
|
|
|
pname = "fwupd";
|
2024-06-05 15:53:02 +00:00
|
|
|
|
version = "1.9.20";
|
2023-03-04 12:14:45 +00:00
|
|
|
|
|
|
|
|
|
# libfwupd goes to lib
|
|
|
|
|
# daemon, plug-ins and libfwupdplugin go to out
|
|
|
|
|
# CLI programs go to out
|
|
|
|
|
outputs = [ "out" "lib" "dev" "devdoc" "man" "installedTests" ];
|
|
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
|
owner = "fwupd";
|
|
|
|
|
repo = "fwupd";
|
|
|
|
|
rev = finalAttrs.version;
|
2024-06-05 15:53:02 +00:00
|
|
|
|
hash = "sha256-uPHZtl1jzx3rRHADXcQmpXwQrbUbIXuoww3fN4BUviE=";
|
2023-03-04 12:14:45 +00:00
|
|
|
|
};
|
2020-09-25 04:45:31 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
patches = [
|
|
|
|
|
# Since /etc is the domain of NixOS, not Nix,
|
|
|
|
|
# we cannot install files there.
|
|
|
|
|
# Let’s install the files to $prefix/etc
|
|
|
|
|
# while still reading them from /etc.
|
|
|
|
|
# NixOS module for fwupd will take take care of copying the files appropriately.
|
|
|
|
|
./add-option-for-installation-sysconfdir.patch
|
|
|
|
|
|
|
|
|
|
# Install plug-ins and libfwupdplugin to $out output,
|
|
|
|
|
# they are not really part of the library.
|
|
|
|
|
./install-fwupdplugin-to-out.patch
|
|
|
|
|
|
|
|
|
|
# Installed tests are installed to different output
|
|
|
|
|
# we also cannot have fwupd-tests.conf in $out/etc since it would form a cycle.
|
|
|
|
|
./installed-tests-path.patch
|
|
|
|
|
|
|
|
|
|
# EFI capsule is located in fwupd-efi now.
|
|
|
|
|
./efi-app-path.patch
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
|
# required for firmware zipping
|
|
|
|
|
ensureNewerSourcesForZipFilesHook
|
|
|
|
|
meson
|
|
|
|
|
ninja
|
|
|
|
|
gi-docgen
|
|
|
|
|
pkg-config
|
|
|
|
|
gobject-introspection
|
|
|
|
|
gettext
|
|
|
|
|
shared-mime-info
|
|
|
|
|
valgrind
|
|
|
|
|
gnutls
|
|
|
|
|
protobufc # for protoc
|
|
|
|
|
python
|
|
|
|
|
wrapGAppsNoGuiHook
|
|
|
|
|
vala
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
buildInputs = [
|
|
|
|
|
polkit
|
|
|
|
|
libxmlb
|
|
|
|
|
gusb
|
|
|
|
|
sqlite
|
|
|
|
|
libarchive
|
2023-11-16 04:20:00 +00:00
|
|
|
|
libdrm
|
2023-03-04 12:14:45 +00:00
|
|
|
|
curl
|
|
|
|
|
elfutils
|
|
|
|
|
libgudev
|
|
|
|
|
libjcat
|
|
|
|
|
libuuid
|
|
|
|
|
json-glib
|
|
|
|
|
umockdev
|
|
|
|
|
bash-completion
|
|
|
|
|
pango
|
|
|
|
|
tpm2-tss
|
|
|
|
|
fwupd-efi
|
|
|
|
|
protobufc
|
|
|
|
|
modemmanager
|
|
|
|
|
libmbim
|
|
|
|
|
libcbor
|
|
|
|
|
libqmi
|
|
|
|
|
xz # for liblzma
|
|
|
|
|
] ++ lib.optionals haveFlashrom [
|
|
|
|
|
flashrom
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
mesonFlags = [
|
|
|
|
|
"-Ddocs=enabled"
|
|
|
|
|
# We are building the official releases.
|
|
|
|
|
"-Dsupported_build=enabled"
|
2023-10-09 19:29:22 +00:00
|
|
|
|
"-Dlaunchd=disabled"
|
2023-03-04 12:14:45 +00:00
|
|
|
|
"-Dudevdir=lib/udev"
|
|
|
|
|
"-Dsystemd_root_prefix=${placeholder "out"}"
|
|
|
|
|
"-Dinstalled_test_prefix=${placeholder "installedTests"}"
|
|
|
|
|
"--localstatedir=/var"
|
|
|
|
|
"--sysconfdir=/etc"
|
|
|
|
|
"-Dsysconfdir_install=${placeholder "out"}/etc"
|
|
|
|
|
"-Defi_os_dir=nixos"
|
|
|
|
|
"-Dplugin_modem_manager=enabled"
|
2024-02-29 20:09:43 +00:00
|
|
|
|
"-Dvendor_metadata=true"
|
2023-03-04 12:14:45 +00:00
|
|
|
|
# We do not want to place the daemon into lib (cyclic reference)
|
|
|
|
|
"--libexecdir=${placeholder "out"}/libexec"
|
2023-10-09 19:29:22 +00:00
|
|
|
|
] ++ lib.optionals (!enablePassim) [
|
|
|
|
|
"-Dpassim=disabled"
|
2023-03-04 12:14:45 +00:00
|
|
|
|
] ++ lib.optionals (!haveDell) [
|
|
|
|
|
"-Dplugin_synaptics_mst=disabled"
|
|
|
|
|
] ++ lib.optionals (!haveRedfish) [
|
|
|
|
|
"-Dplugin_redfish=disabled"
|
|
|
|
|
] ++ lib.optionals (!haveFlashrom) [
|
|
|
|
|
"-Dplugin_flashrom=disabled"
|
|
|
|
|
] ++ lib.optionals (!haveMSR) [
|
|
|
|
|
"-Dplugin_msr=disabled"
|
|
|
|
|
];
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
# TODO: wrapGAppsHook3 wraps efi capsule even though it is not ELF
|
2023-03-04 12:14:45 +00:00
|
|
|
|
dontWrapGApps = true;
|
|
|
|
|
|
|
|
|
|
doCheck = true;
|
|
|
|
|
|
|
|
|
|
# Environment variables
|
|
|
|
|
|
|
|
|
|
# Fontconfig error: Cannot load default config file
|
|
|
|
|
FONTCONFIG_FILE =
|
|
|
|
|
let
|
|
|
|
|
fontsConf = makeFontsConf {
|
|
|
|
|
fontDirectories = [ freefont_ttf ];
|
|
|
|
|
};
|
|
|
|
|
in
|
|
|
|
|
fontsConf;
|
|
|
|
|
|
|
|
|
|
# error: “PolicyKit files are missing”
|
|
|
|
|
# https://github.com/NixOS/nixpkgs/pull/67625#issuecomment-525788428
|
|
|
|
|
PKG_CONFIG_POLKIT_GOBJECT_1_ACTIONDIR = "/run/current-system/sw/share/polkit-1/actions";
|
|
|
|
|
|
|
|
|
|
# Phase hooks
|
|
|
|
|
|
|
|
|
|
postPatch = ''
|
|
|
|
|
patchShebangs \
|
|
|
|
|
contrib/generate-version-script.py \
|
2023-07-15 17:15:38 +00:00
|
|
|
|
contrib/generate-man.py \
|
2023-03-04 12:14:45 +00:00
|
|
|
|
po/test-deps
|
|
|
|
|
|
|
|
|
|
# tests fail with: Failed to load SMBIOS: neither SMBIOS or DT found
|
|
|
|
|
sed -i 's/test(.*)//' plugins/lenovo-thinklmi/meson.build
|
|
|
|
|
sed -i 's/test(.*)//' plugins/mtd/meson.build
|
|
|
|
|
# fails on amd cpu
|
|
|
|
|
sed -i 's/test(.*)//' libfwupdplugin/meson.build
|
|
|
|
|
# in nixos test tries to chmod 0777 $out/share/installed-tests/fwupd/tests/redfish.conf
|
|
|
|
|
sed -i "s/get_option('tests')/false/" plugins/redfish/meson.build
|
|
|
|
|
|
|
|
|
|
# Device tests use device emulation and need to download emulation data from
|
|
|
|
|
# the internet, which does not work on our test VMs.
|
|
|
|
|
# It's probably better to disable these tests for NixOS by setting
|
|
|
|
|
# the device-tests directory to /dev/null.
|
|
|
|
|
# For more info on device emulation, see:
|
|
|
|
|
# https://github.com/fwupd/fwupd/blob/eeeac4e9ba8a6513428b456a551bffd95d533e50/docs/device-emulation.md
|
|
|
|
|
substituteInPlace data/installed-tests/meson.build \
|
|
|
|
|
--replace "join_paths(datadir, 'fwupd', 'device-tests')" "'/dev/null'"
|
|
|
|
|
'';
|
2020-06-18 07:06:33 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
preBuild = ''
|
|
|
|
|
# jcat-tool at buildtime requires a home directory
|
|
|
|
|
export HOME="$(mktemp -d)"
|
|
|
|
|
'';
|
2022-08-12 12:06:08 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
preCheck = ''
|
|
|
|
|
addToSearchPath XDG_DATA_DIRS "${shared-mime-info}/share"
|
2023-02-02 18:25:31 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
echo "12345678901234567890123456789012" > machine-id
|
|
|
|
|
export NIX_REDIRECTS=/etc/machine-id=$(realpath machine-id) \
|
|
|
|
|
LD_PRELOAD=${libredirect}/lib/libredirect.so
|
|
|
|
|
'';
|
2020-06-18 07:06:33 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
postInstall = ''
|
|
|
|
|
# These files have weird licenses so they are shipped separately.
|
|
|
|
|
cp --recursive --dereference "${test-firmware}/installed-tests/tests" "$installedTests/libexec/installed-tests/fwupd"
|
|
|
|
|
'';
|
2020-11-12 09:05:59 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
preFixup =
|
|
|
|
|
let
|
2020-09-25 04:45:31 +00:00
|
|
|
|
binPath = [
|
|
|
|
|
efibootmgr
|
|
|
|
|
bubblewrap
|
|
|
|
|
tpm2-tools
|
2022-04-27 09:35:20 +00:00
|
|
|
|
];
|
2023-03-04 12:14:45 +00:00
|
|
|
|
in
|
|
|
|
|
''
|
2020-09-25 04:45:31 +00:00
|
|
|
|
gappsWrapperArgs+=(
|
|
|
|
|
--prefix XDG_DATA_DIRS : "${shared-mime-info}/share"
|
|
|
|
|
# See programs reached with fu_common_find_program_in_path in source
|
2021-02-05 17:12:51 +00:00
|
|
|
|
--prefix PATH : "${lib.makeBinPath binPath}"
|
2020-09-25 04:45:31 +00:00
|
|
|
|
)
|
|
|
|
|
'';
|
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
postFixup = ''
|
|
|
|
|
# Since we had to disable wrapGAppsHook, we need to wrap the executables manually.
|
|
|
|
|
find -L "$out/bin" "$out/libexec" -type f -executable -print0 \
|
|
|
|
|
| while IFS= read -r -d ''' file; do
|
|
|
|
|
if [[ "$file" != *.efi ]]; then
|
|
|
|
|
echo "Wrapping program $file"
|
|
|
|
|
wrapGApp "$file"
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# Cannot be in postInstall, otherwise _multioutDocs hook in preFixup will move right back.
|
|
|
|
|
moveToOutput "share/doc" "$devdoc"
|
|
|
|
|
'';
|
2020-06-18 07:06:33 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
separateDebugInfo = true;
|
|
|
|
|
|
|
|
|
|
passthru = {
|
|
|
|
|
filesInstalledToEtc = [
|
|
|
|
|
"fwupd/bios-settings.d/README.md"
|
2023-07-15 17:15:38 +00:00
|
|
|
|
"fwupd/fwupd.conf"
|
2023-03-04 12:14:45 +00:00
|
|
|
|
"fwupd/remotes.d/lvfs-testing.conf"
|
|
|
|
|
"fwupd/remotes.d/lvfs.conf"
|
|
|
|
|
"fwupd/remotes.d/vendor.conf"
|
|
|
|
|
"fwupd/remotes.d/vendor-directory.conf"
|
|
|
|
|
"pki/fwupd/GPG-KEY-Linux-Foundation-Firmware"
|
|
|
|
|
"pki/fwupd/GPG-KEY-Linux-Vendor-Firmware-Service"
|
|
|
|
|
"pki/fwupd/LVFS-CA.pem"
|
|
|
|
|
"pki/fwupd-metadata/GPG-KEY-Linux-Foundation-Metadata"
|
|
|
|
|
"pki/fwupd-metadata/GPG-KEY-Linux-Vendor-Firmware-Service"
|
|
|
|
|
"pki/fwupd-metadata/LVFS-CA.pem"
|
|
|
|
|
"grub.d/35_fwupd"
|
|
|
|
|
];
|
2020-06-18 07:06:33 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
# For updating.
|
|
|
|
|
inherit test-firmware;
|
2021-12-06 16:07:01 +00:00
|
|
|
|
|
2023-03-15 16:39:30 +00:00
|
|
|
|
# For downstream consumers that need the fwupd-efi this was built with.
|
|
|
|
|
inherit fwupd-efi;
|
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
tests =
|
|
|
|
|
let
|
2021-02-05 17:12:51 +00:00
|
|
|
|
listToPy = list: "[${lib.concatMapStringsSep ", " (f: "'${f}'") list}]";
|
2023-03-04 12:14:45 +00:00
|
|
|
|
in
|
|
|
|
|
{
|
2020-06-18 07:06:33 +00:00
|
|
|
|
installedTests = nixosTests.installed-tests.fwupd;
|
|
|
|
|
|
|
|
|
|
passthruMatches = runPythonCommand "fwupd-test-passthru-matches" ''
|
|
|
|
|
import itertools
|
|
|
|
|
import configparser
|
|
|
|
|
import os
|
|
|
|
|
import pathlib
|
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
etc = '${finalAttrs.finalPackage}/etc'
|
2020-06-18 07:06:33 +00:00
|
|
|
|
package_etc = set(itertools.chain.from_iterable([[os.path.relpath(os.path.join(prefix, file), etc) for file in files] for (prefix, dirs, files) in os.walk(etc)]))
|
2023-03-04 12:14:45 +00:00
|
|
|
|
passthru_etc = set(${listToPy finalAttrs.passthru.filesInstalledToEtc})
|
2020-06-18 07:06:33 +00:00
|
|
|
|
assert len(package_etc - passthru_etc) == 0, f'fwupd package contains the following paths in /etc that are not listed in passthru.filesInstalledToEtc: {package_etc - passthru_etc}'
|
|
|
|
|
assert len(passthru_etc - package_etc) == 0, f'fwupd package lists the following paths in passthru.filesInstalledToEtc that are not contained in /etc: {passthru_etc - package_etc}'
|
|
|
|
|
|
|
|
|
|
pathlib.Path(os.getenv('out')).touch()
|
|
|
|
|
'';
|
|
|
|
|
};
|
2020-04-24 23:36:52 +00:00
|
|
|
|
};
|
2020-06-18 07:06:33 +00:00
|
|
|
|
|
2023-03-04 12:14:45 +00:00
|
|
|
|
meta = with lib; {
|
|
|
|
|
homepage = "https://fwupd.org/";
|
2023-10-09 19:29:22 +00:00
|
|
|
|
maintainers = with maintainers; [ rvdp ];
|
2023-03-04 12:14:45 +00:00
|
|
|
|
license = licenses.lgpl21Plus;
|
|
|
|
|
platforms = platforms.linux;
|
|
|
|
|
};
|
|
|
|
|
})
|