diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-04-15 16:59:19 +0200 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-04-15 16:59:19 +0200 |
commit | a37edbbb636d0332592fa8c70e78496c988b49d1 (patch) | |
tree | fb550b666ceb0488add736bb89d438767aa08e05 /pkgs/os-specific/linux/kernel-headers/3.14.nix | |
parent | 0fc9f65ff28abda378e8c7967804e3cf05351ba7 (diff) | |
download | nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar.gz nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar.bz2 nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar.lz nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar.xz nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.tar.zst nixpkgs-a37edbbb636d0332592fa8c70e78496c988b49d1.zip |
linux-headers: Add 3.14
Diffstat (limited to 'pkgs/os-specific/linux/kernel-headers/3.14.nix')
-rw-r--r-- | pkgs/os-specific/linux/kernel-headers/3.14.nix | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/pkgs/os-specific/linux/kernel-headers/3.14.nix b/pkgs/os-specific/linux/kernel-headers/3.14.nix new file mode 100644 index 00000000000..d9d0ce7e3b3 --- /dev/null +++ b/pkgs/os-specific/linux/kernel-headers/3.14.nix @@ -0,0 +1,71 @@ +{ stdenv, fetchurl, perl, cross ? null }: + +assert cross == null -> stdenv.isLinux; + +let + + version = "3.14.1"; + + kernelHeadersBaseConfig = + if cross == null + then stdenv.platform.kernelHeadersBaseConfig + else cross.platform.kernelHeadersBaseConfig; + +in + +stdenv.mkDerivation { + name = "linux-headers-${version}"; + + src = fetchurl { + url = "mirror://kernel/linux/kernel/v3.x/linux-${version}.tar.xz"; + sha256 = "1njm8gvlj7cq0m1051yxszl4f63383a7sv1na13hkqkv36kipgqx"; + }; + + targetConfig = if cross != null then cross.config else null; + + platform = + if cross != null then cross.platform.kernelArch else + if stdenv.system == "i686-linux" then "i386" else + if stdenv.system == "x86_64-linux" then "x86_64" else + if stdenv.system == "powerpc-linux" then "powerpc" else + if stdenv.isArm then "arm" else + if stdenv.platform ? kernelArch then stdenv.platform.kernelArch else + abort "don't know what the kernel include directory is called for this platform"; + + buildInputs = [perl]; + + extraIncludeDirs = + if cross != null then + (if cross.arch == "powerpc" then ["ppc"] else []) + else if stdenv.system == "powerpc-linux" then ["ppc"] else []; + + buildPhase = '' + if test -n "$targetConfig"; then + export ARCH=$platform + fi + make ${kernelHeadersBaseConfig} SHELL=bash + make mrproper headers_check SHELL=bash + ''; + + installPhase = '' + make INSTALL_HDR_PATH=$out headers_install + + # Some builds (e.g. KVM) want a kernel.release. + mkdir -p $out/include/config + echo "${version}-default" > $out/include/config/kernel.release + ''; + + # !!! hacky + fixupPhase = '' + ln -s asm $out/include/asm-$platform + if test "$platform" = "i386" -o "$platform" = "x86_64"; then + ln -s asm $out/include/asm-x86 + fi + ''; + + meta = with stdenv.lib; { + description = "Header files and scripts for Linux kernel"; + license = licenses.gpl2; + platforms = platforms.linux; + }; +} |