2019-08-17 17:42:22 +01:00
|
|
|
{ stdenv, lib, buildPackages, fetchFromGitHub, perl, buildLinux, rpiVersion, ... } @ args:
|
2012-12-27 21:29:56 +00:00
|
|
|
|
2013-08-27 11:05:13 +01:00
|
|
|
let
|
2019-08-17 17:42:22 +01:00
|
|
|
modDirVersion = "4.19.71";
|
|
|
|
tag = "1.20190906";
|
2016-07-03 23:50:37 +01:00
|
|
|
in
|
2019-08-13 22:52:01 +01:00
|
|
|
lib.overrideDerivation (buildLinux (args // {
|
2016-07-03 23:50:37 +01:00
|
|
|
version = "${modDirVersion}-${tag}";
|
|
|
|
inherit modDirVersion;
|
2013-01-28 23:42:36 +00:00
|
|
|
|
2016-07-03 23:50:37 +01:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "raspberrypi";
|
|
|
|
repo = "linux";
|
2019-08-17 17:42:22 +01:00
|
|
|
rev = "9532eb3c84d8d952ef28da3d135683ac01adc9b8";
|
|
|
|
sha256 = "0168wz8kkdzbyha41iqlgn1z1kcy4smg89rgxkgadzq78y7fglpl";
|
2013-07-31 22:56:48 +01:00
|
|
|
};
|
2012-12-27 21:29:56 +00:00
|
|
|
|
2017-11-03 13:50:19 +00:00
|
|
|
defconfig = {
|
2019-08-17 17:42:22 +01:00
|
|
|
"1" = "bcmrpi_defconfig";
|
|
|
|
"2" = "bcm2709_defconfig";
|
|
|
|
"3" = "bcmrpi3_defconfig";
|
|
|
|
"4" = "bcm2711_defconfig";
|
|
|
|
}.${toString rpiVersion};
|
2017-11-03 13:50:19 +00:00
|
|
|
|
2017-09-15 22:07:14 +01:00
|
|
|
features = {
|
|
|
|
efiBootStub = false;
|
|
|
|
} // (args.features or {});
|
2012-12-27 21:29:56 +00:00
|
|
|
|
2019-08-17 17:42:22 +01:00
|
|
|
extraMeta = if (rpiVersion < 3) then {
|
|
|
|
platforms = with lib.platforms; [ arm ];
|
|
|
|
hydraPlatforms = [];
|
|
|
|
} else {
|
|
|
|
platforms = with lib.platforms; [ arm aarch64 ];
|
|
|
|
hydraPlatforms = [ "aarch64-linux" ];
|
|
|
|
};
|
|
|
|
})) (oldAttrs: {
|
2016-07-03 23:50:37 +01:00
|
|
|
postConfigure = ''
|
|
|
|
# The v7 defconfig has this set to '-v7' which screws up our modDirVersion.
|
|
|
|
sed -i $buildRoot/.config -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/'
|
2019-08-17 17:42:22 +01:00
|
|
|
sed -i $buildRoot/include/config/auto.conf -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/'
|
2016-07-03 23:50:37 +01:00
|
|
|
'';
|
|
|
|
|
2018-09-10 05:15:51 +01:00
|
|
|
# Make copies of the DTBs named after the upstream names so that U-Boot finds them.
|
|
|
|
# This is ugly as heck, but I don't know a better solution so far.
|
2018-09-20 14:41:04 +01:00
|
|
|
postFixup = ''
|
|
|
|
dtbDir=${if stdenv.isAarch64 then "$out/dtbs/broadcom" else "$out/dtbs"}
|
|
|
|
rm $dtbDir/bcm283*.dtb
|
2018-09-10 05:15:51 +01:00
|
|
|
copyDTB() {
|
2018-09-20 14:41:04 +01:00
|
|
|
cp -v "$dtbDir/$1" "$dtbDir/$2"
|
2018-09-10 05:15:51 +01:00
|
|
|
}
|
2018-09-20 14:41:04 +01:00
|
|
|
'' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv6l-linux"]) ''
|
2018-05-07 19:59:15 +01:00
|
|
|
copyDTB bcm2708-rpi-0-w.dtb bcm2835-rpi-zero.dtb
|
|
|
|
copyDTB bcm2708-rpi-0-w.dtb bcm2835-rpi-zero-w.dtb
|
2016-07-03 23:50:37 +01:00
|
|
|
copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-a.dtb
|
|
|
|
copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b.dtb
|
|
|
|
copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b-rev2.dtb
|
|
|
|
copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-a-plus.dtb
|
|
|
|
copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-b-plus.dtb
|
|
|
|
copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-zero.dtb
|
|
|
|
copyDTB bcm2708-rpi-cm.dtb bcm2835-rpi-cm.dtb
|
2018-09-20 14:41:04 +01:00
|
|
|
'' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv7l-linux"]) ''
|
2016-07-03 23:50:37 +01:00
|
|
|
copyDTB bcm2709-rpi-2-b.dtb bcm2836-rpi-2-b.dtb
|
2018-09-20 14:41:04 +01:00
|
|
|
'' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv7l-linux" "aarch64-linux"]) ''
|
2016-07-03 23:50:37 +01:00
|
|
|
copyDTB bcm2710-rpi-3-b.dtb bcm2837-rpi-3-b.dtb
|
2019-09-22 00:51:04 +01:00
|
|
|
copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-a-plus.dtb
|
2018-05-07 19:59:15 +01:00
|
|
|
copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-b-plus.dtb
|
|
|
|
copyDTB bcm2710-rpi-cm3.dtb bcm2837-rpi-cm3.dtb
|
2019-08-17 17:42:22 +01:00
|
|
|
copyDTB bcm2711-rpi-4-b.dtb bcm2838-rpi-4-b.dtb
|
2016-07-03 23:50:37 +01:00
|
|
|
'';
|
2013-07-31 22:56:48 +01:00
|
|
|
})
|