Merge pull request #60422 from kwohlfahrt/device-tree
nixos/hardware.deviceTree: new module
This commit is contained in:
commit
b750ebf1b3
56
nixos/modules/hardware/device-tree.nix
Normal file
56
nixos/modules/hardware/device-tree.nix
Normal file
@ -0,0 +1,56 @@
|
||||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
cfg = config.hardware.deviceTree;
|
||||
in {
|
||||
options = {
|
||||
hardware.deviceTree = {
|
||||
enable = mkOption {
|
||||
default = pkgs.stdenv.hostPlatform.platform.kernelDTB or false;
|
||||
type = types.bool;
|
||||
description = ''
|
||||
Build device tree files. These are used to describe the
|
||||
non-discoverable hardware of a system.
|
||||
'';
|
||||
};
|
||||
|
||||
base = mkOption {
|
||||
default = "${config.boot.kernelPackages.kernel}/dtbs";
|
||||
defaultText = "\${config.boot.kernelPackages.kernel}/dtbs";
|
||||
example = literalExample "pkgs.deviceTree_rpi";
|
||||
type = types.path;
|
||||
description = ''
|
||||
The package containing the base device-tree (.dtb) to boot. Contains
|
||||
device trees bundled with the Linux kernel by default.
|
||||
'';
|
||||
};
|
||||
|
||||
overlays = mkOption {
|
||||
default = [];
|
||||
example = literalExample
|
||||
"[\"\${pkgs.deviceTree_rpi.overlays}/w1-gpio.dtbo\"]";
|
||||
type = types.listOf types.path;
|
||||
description = ''
|
||||
A path containing device tree overlays (.dtbo) to be applied to all
|
||||
base device-trees.
|
||||
'';
|
||||
};
|
||||
|
||||
package = mkOption {
|
||||
default = null;
|
||||
type = types.nullOr types.path;
|
||||
internal = true;
|
||||
description = ''
|
||||
A path containing the result of applying `overlays` to `base`.
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf (cfg.enable) {
|
||||
hardware.deviceTree.package = if (cfg.overlays != [])
|
||||
then pkgs.deviceTree.applyOverlays cfg.base cfg.overlays else cfg.base;
|
||||
};
|
||||
}
|
@ -46,6 +46,7 @@
|
||||
./hardware/cpu/amd-microcode.nix
|
||||
./hardware/cpu/intel-microcode.nix
|
||||
./hardware/digitalbitbox.nix
|
||||
./hardware/device-tree.nix
|
||||
./hardware/sensor/iio.nix
|
||||
./hardware/ksm.nix
|
||||
./hardware/ledger.nix
|
||||
|
@ -46,8 +46,8 @@ let
|
||||
|
||||
ln -s ${kernelPath} $out/kernel
|
||||
ln -s ${config.system.modulesTree} $out/kernel-modules
|
||||
${optionalString (pkgs.stdenv.hostPlatform.platform.kernelDTB or false) ''
|
||||
ln -s ${config.boot.kernelPackages.kernel}/dtbs $out/dtbs
|
||||
${optionalString (config.hardware.deviceTree.package != null) ''
|
||||
ln -s ${config.hardware.deviceTree.package} $out/dtbs
|
||||
''}
|
||||
|
||||
echo -n "$kernelParams" > $out/kernel-params
|
||||
|
@ -75,9 +75,8 @@ addEntry() {
|
||||
|
||||
copyToKernelsDir "$path/kernel"; kernel=$result
|
||||
copyToKernelsDir "$path/initrd"; initrd=$result
|
||||
# XXX UGLY: maybe the system config should have a top-level "dtbs" entry?
|
||||
dtbDir=$(readlink -m "$path/kernel/../dtbs")
|
||||
if [ -d "$dtbDir" ]; then
|
||||
dtbDir=$(readlink -m "$path/dtbs")
|
||||
if [ -e "$dtbDir" ]; then
|
||||
copyToKernelsDir "$dtbDir"; dtbs=$result
|
||||
fi
|
||||
|
||||
|
17
pkgs/os-specific/linux/device-tree/default.nix
Normal file
17
pkgs/os-specific/linux/device-tree/default.nix
Normal file
@ -0,0 +1,17 @@
|
||||
{ stdenvNoCC, dtc, findutils }:
|
||||
|
||||
with stdenvNoCC.lib; {
|
||||
applyOverlays = (base: overlays: stdenvNoCC.mkDerivation {
|
||||
name = "device-tree-overlays";
|
||||
nativeBuildInputs = [ dtc findutils ];
|
||||
buildCommand = let
|
||||
quotedDtbos = concatMapStringsSep " " (o: "\"${toString o}\"") (toList overlays);
|
||||
in ''
|
||||
for dtb in $(find ${base} -name "*.dtb" ); do
|
||||
outDtb=$out/$(realpath --relative-to "${base}" "$dtb")
|
||||
mkdir -p "$(dirname "$outDtb")"
|
||||
fdtoverlay -o "$outDtb" -i "$dtb" ${quotedDtbos};
|
||||
done
|
||||
'';
|
||||
});
|
||||
}
|
32
pkgs/os-specific/linux/device-tree/raspberrypi.nix
Normal file
32
pkgs/os-specific/linux/device-tree/raspberrypi.nix
Normal file
@ -0,0 +1,32 @@
|
||||
{ stdenvNoCC, raspberrypifw }:
|
||||
|
||||
stdenvNoCC.mkDerivation {
|
||||
name = "raspberrypi-dtbs-${raspberrypifw.version}";
|
||||
nativeBuildInputs = [ raspberrypifw ];
|
||||
|
||||
# Rename DTBs so u-boot finds them, like linux-rpi.nix
|
||||
buildCommand = ''
|
||||
mkdir -p $out/broadcom/
|
||||
cd $out/broadcom/
|
||||
|
||||
cp ${raspberrypifw}/share/raspberrypi/boot/bcm*.dtb .
|
||||
|
||||
cp bcm2708-rpi-0-w.dtb bcm2835-rpi-zero-w.dtb
|
||||
cp bcm2708-rpi-b.dtb bcm2835-rpi-a.dtb
|
||||
cp bcm2708-rpi-b.dtb bcm2835-rpi-b.dtb
|
||||
cp bcm2708-rpi-b.dtb bcm2835-rpi-b-rev2.dtb
|
||||
cp bcm2708-rpi-b-plus.dtb bcm2835-rpi-a-plus
|
||||
cp bcm2708-rpi-b-plus.dtb bcm2835-rpi-b-plus
|
||||
cp bcm2708-rpi-b-plus.dtb bcm2835-rpi-zero.dtb
|
||||
cp bcm2708-rpi-cm.dtb bcm2835-rpi-cm.dtb
|
||||
cp bcm2709-rpi-2-b.dtb bcm2836-rpi-2-b.dtb
|
||||
cp bcm2710-rpi-3-b.dtb bcm2837-rpi-3-b.dtb
|
||||
cp bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-b-plus.dtb
|
||||
cp bcm2710-rpi-cm3.dtb bcm2837-rpi-cm3.dtb
|
||||
'';
|
||||
|
||||
passthru = {
|
||||
# Compatible overlays that may be used
|
||||
overlays = "${raspberrypifw}/share/raspberrypi/boot/overlays";
|
||||
};
|
||||
}
|
@ -169,6 +169,10 @@ in
|
||||
|
||||
demoit = callPackage ../servers/demoit { };
|
||||
|
||||
deviceTree = callPackage ../os-specific/linux/device-tree {};
|
||||
|
||||
device-tree_rpi = callPackage ../os-specific/linux/device-tree/raspberrypi.nix {};
|
||||
|
||||
diffPlugins = (callPackage ../build-support/plugins.nix {}).diffPlugins;
|
||||
|
||||
dieHook = makeSetupHook {} ../build-support/setup-hooks/die.sh;
|
||||
|
Loading…
Reference in New Issue
Block a user