585ba8c27f
- Before this changes, cflags and ldflags for the native and the cross compiler got mixed. Not all the gcc-wrapper/gcc-cross-wrapper variables are independant now, but enough, I think. - Fixed the generic stdenv expression, which did a big mess on buildInputs and buildNativeInputs. Now it distinguishes when there is a stdenvCross or not. Maybe we should have a single stdenv and forget about the stdenvCross adapter - this could end in a stdenv a bit complex, but simpler than the generic stdenv + adapter. - Added basic support in pkgconfig for cross-builds: a single PKG_CONFIG_PATH now works for both the cross and the native compilers, but I think this should work well for most cases I can think of. - I tried to fix the guile expression to cross-biuld; guile is built, but not its manual, so the derivation still fails. Guile requires patching to cross-build, as far as I understnad. - Made the glibcCross build to be done through the usage of a gcc-cross-wrapper over the gcc-cross-stage-static, instead of using it directly. - Trying to make physfs (a neverball dependency) cross build. - Updated the gcc expression to support building a cross compiler without getting derivation variables mixed with those of the stdenvCross. svn path=/nixpkgs/branches/stdenv-updates/; revision=18534
61 lines
1.5 KiB
Nix
61 lines
1.5 KiB
Nix
{stdenv, fetchurl, perl, cross ? null}:
|
|
|
|
assert stdenv.isLinux;
|
|
|
|
let
|
|
version = "2.6.28.5";
|
|
in
|
|
|
|
stdenv.mkDerivation {
|
|
name = "linux-headers-${version}";
|
|
|
|
src = fetchurl {
|
|
url = "mirror://kernel/linux/kernel/v2.6/linux-${version}.tar.bz2";
|
|
sha256 = "0hifjh75sinifr5138v22zwbpqln6lhn65k8b57a1dyzlqca7cl9";
|
|
};
|
|
|
|
targetConfig = if (cross != null) then cross.config else null;
|
|
|
|
platform =
|
|
if cross != null then cross.arch 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.system == "armv5tel-linux" then "arm" 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 [];
|
|
|
|
patchPhase = ''
|
|
sed -i '/scsi/d' include/Kbuild
|
|
'';
|
|
|
|
buildPhase = ''
|
|
if test -n "$targetConfig"; then
|
|
export ARCH=$platform
|
|
fi
|
|
make mrproper headers_check
|
|
'';
|
|
|
|
installPhase = ''
|
|
make INSTALL_HDR_PATH=$out headers_install
|
|
|
|
# Some builds (e.g. KVM) want a kernel.release.
|
|
ensureDir $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
|
|
'';
|
|
}
|