* Linux 2.6.27.4. Not tested yet.
svn path=/nixpkgs/trunk/; revision=13144
This commit is contained in:
parent
964b969066
commit
dbc520876d
4052
pkgs/os-specific/linux/kernel/config-2.6.27-i686-smp
Normal file
4052
pkgs/os-specific/linux/kernel/config-2.6.27-i686-smp
Normal file
File diff suppressed because it is too large
Load Diff
3818
pkgs/os-specific/linux/kernel/config-2.6.27-x86_64-smp
Normal file
3818
pkgs/os-specific/linux/kernel/config-2.6.27-x86_64-smp
Normal file
File diff suppressed because it is too large
Load Diff
95
pkgs/os-specific/linux/kernel/linux-2.6.27.nix
Normal file
95
pkgs/os-specific/linux/kernel/linux-2.6.27.nix
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
{ stdenv, fetchurl, perl, mktemp, module_init_tools
|
||||||
|
|
||||||
|
# A list of patches to apply to the kernel. Each element of this list
|
||||||
|
# should be an attribute set {name, patch} where `name' is a
|
||||||
|
# symbolic name and `patch' is the actual patch. The patch may
|
||||||
|
# optionally be compressed with gzip or bzip2.
|
||||||
|
, kernelPatches ? []
|
||||||
|
|
||||||
|
, # Whether to build a User-Mode Linux kernel.
|
||||||
|
userModeLinux ? false
|
||||||
|
|
||||||
|
, # Allows you to set your own kernel version suffix (e.g.,
|
||||||
|
# "-my-kernel").
|
||||||
|
localVersion ? ""
|
||||||
|
|
||||||
|
, # Your own kernel configuration file, if you don't want to use the
|
||||||
|
# default.
|
||||||
|
kernelConfig ? null
|
||||||
|
|
||||||
|
, # A list of additional statements to be appended to the
|
||||||
|
# configuration file.
|
||||||
|
extraConfig ? []
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux";
|
||||||
|
|
||||||
|
let
|
||||||
|
|
||||||
|
lib = stdenv.lib;
|
||||||
|
|
||||||
|
version = "2.6.27.4";
|
||||||
|
|
||||||
|
baseFeatures = {
|
||||||
|
iwlwifi = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
in
|
||||||
|
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = if userModeLinux then "user-mode-linux-${version}" else "linux-${version}";
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
inherit version;
|
||||||
|
# Combine the `features' attribute sets of all the kernel patches.
|
||||||
|
features = lib.fold (x: y: (if x ? features then x.features else {}) // y) baseFeatures kernelPatches;
|
||||||
|
};
|
||||||
|
|
||||||
|
builder = ./builder.sh;
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "mirror://kernel/linux/kernel/v2.6/linux-${version}.tar.bz2";
|
||||||
|
sha256 = "1910dzmm37lfs1z5c01dyga16c8z8b86ivwgzr9nbd1l6rrndixb";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = map (p: p.patch) kernelPatches;
|
||||||
|
extraConfig =
|
||||||
|
let addNewlines = map (s: "\n" + s + "\n");
|
||||||
|
configFromPatches =
|
||||||
|
map (p: if p ? extraConfig then p.extraConfig else "") kernelPatches;
|
||||||
|
in lib.concatStrings (addNewlines (configFromPatches ++ extraConfig));
|
||||||
|
|
||||||
|
config =
|
||||||
|
if kernelConfig != null then kernelConfig else
|
||||||
|
if userModeLinux then ./config-2.6.27-uml else
|
||||||
|
if stdenv.system == "i686-linux" then ./config-2.6.27-i686-smp else
|
||||||
|
if stdenv.system == "x86_64-linux" then ./config-2.6.27-x86_64-smp else
|
||||||
|
abort "No kernel configuration for your platform!";
|
||||||
|
|
||||||
|
buildInputs = [perl mktemp];
|
||||||
|
|
||||||
|
arch =
|
||||||
|
if userModeLinux then "um" else
|
||||||
|
if stdenv.system == "i686-linux" then "i386" else
|
||||||
|
if stdenv.system == "x86_64-linux" then "x86_64" else
|
||||||
|
abort "Platform ${stdenv.system} is not supported.";
|
||||||
|
|
||||||
|
makeFlags = if userModeLinux then "ARCH=um SHELL=bash" else "";
|
||||||
|
|
||||||
|
inherit module_init_tools;
|
||||||
|
|
||||||
|
allowLocalVersion = false; # don't allow patches to set a suffix
|
||||||
|
inherit localVersion; # but do allow the user to set one.
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description =
|
||||||
|
(if userModeLinux then
|
||||||
|
"User-Mode Linux"
|
||||||
|
else
|
||||||
|
"The Linux kernel") +
|
||||||
|
(if kernelPatches == [] then "" else
|
||||||
|
" (with patches: "
|
||||||
|
+ lib.concatStrings (lib.intersperse ", " (map (x: x.name) kernelPatches))
|
||||||
|
+ ")");
|
||||||
|
};
|
||||||
|
}
|
@ -6144,6 +6144,27 @@ let
|
|||||||
[(getConfig ["kernel" "addConfig"] "")];
|
[(getConfig ["kernel" "addConfig"] "")];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
kernel_2_6_27 = import ../os-specific/linux/kernel/linux-2.6.27.nix {
|
||||||
|
inherit fetchurl stdenv perl mktemp module_init_tools;
|
||||||
|
kernelPatches = [
|
||||||
|
{ name = "fbcondecor-0.9.4-2.6.27";
|
||||||
|
patch = fetchurl {
|
||||||
|
url = http://dev.gentoo.org/~spock/projects/fbcondecor/archive/fbcondecor-0.9.4-2.6.27.patch;
|
||||||
|
sha256 = "170l9l5fvbgjrr4klqcwbgjg4kwvrrhjpmgbfpqj0scq0s4q4vk6";
|
||||||
|
};
|
||||||
|
extraConfig = "CONFIG_FB_CON_DECOR=y";
|
||||||
|
features = { fbConDecor = true; };
|
||||||
|
}
|
||||||
|
{ name = "sec_perm-2.6.24";
|
||||||
|
patch = ../os-specific/linux/kernel/sec_perm-2.6.24.patch;
|
||||||
|
features = { secPermPatch = true; };
|
||||||
|
}
|
||||||
|
];
|
||||||
|
extraConfig =
|
||||||
|
lib.optional (getConfig ["kernel" "no_irqbalance"] false) "# CONFIG_IRQBALANCE is not set" ++
|
||||||
|
[(getConfig ["kernel" "addConfig"] "")];
|
||||||
|
};
|
||||||
|
|
||||||
/* Kernel modules are inherently tied to a specific kernel. So
|
/* Kernel modules are inherently tied to a specific kernel. So
|
||||||
rather than provide specific instances of those packages for a
|
rather than provide specific instances of those packages for a
|
||||||
specific kernel, we have a function that builds those packages
|
specific kernel, we have a function that builds those packages
|
||||||
@ -6252,6 +6273,7 @@ let
|
|||||||
kernelPackages_2_6_23 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_23);
|
kernelPackages_2_6_23 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_23);
|
||||||
kernelPackages_2_6_25 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_25);
|
kernelPackages_2_6_25 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_25);
|
||||||
kernelPackages_2_6_26 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_26);
|
kernelPackages_2_6_26 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_26);
|
||||||
|
kernelPackages_2_6_27 = recurseIntoAttrs (kernelPackagesFor kernel_2_6_27);
|
||||||
|
|
||||||
# The current default kernel / kernel modules.
|
# The current default kernel / kernel modules.
|
||||||
kernelPackages = kernelPackages_2_6_25;
|
kernelPackages = kernelPackages_2_6_25;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user