2009-11-19 18:19:39 +01:00
|
|
|
# Define the list of system with their properties. Only systems tested for
|
|
|
|
# Nixpkgs are listed below
|
|
|
|
|
|
|
|
with import ./lists.nix;
|
|
|
|
with import ./types.nix;
|
|
|
|
with import ./attrsets.nix;
|
|
|
|
|
|
|
|
let
|
|
|
|
lib = import ./default.nix;
|
|
|
|
setTypes = type:
|
|
|
|
mapAttrs (name: value:
|
|
|
|
setType type ({inherit name;} // value)
|
|
|
|
);
|
|
|
|
in
|
|
|
|
|
|
|
|
rec {
|
|
|
|
|
2013-03-13 15:05:30 +01:00
|
|
|
isSignificantByte = isType "significant-byte";
|
2009-11-19 18:19:39 +01:00
|
|
|
significantBytes = setTypes "significant-byte" {
|
|
|
|
bigEndian = {};
|
|
|
|
littleEndian = {};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-10-28 01:24:30 +01:00
|
|
|
isCpuType = x: isType "cpu-type" x
|
2009-11-19 18:19:39 +01:00
|
|
|
&& elem x.bits [8 16 32 64 128]
|
2014-10-04 17:02:29 +02:00
|
|
|
&& (8 < x.bits -> isSignificantByte x.significantByte);
|
2009-11-19 18:19:39 +01:00
|
|
|
|
|
|
|
cpuTypes = with significantBytes;
|
|
|
|
setTypes "cpu-type" {
|
|
|
|
arm = { bits = 32; significantByte = littleEndian; };
|
|
|
|
armv5tel = { bits = 32; significantByte = littleEndian; };
|
2012-04-16 01:41:25 +02:00
|
|
|
armv7l = { bits = 32; significantByte = littleEndian; };
|
2009-11-19 18:19:39 +01:00
|
|
|
i686 = { bits = 32; significantByte = littleEndian; };
|
|
|
|
powerpc = { bits = 32; significantByte = bigEndian; };
|
|
|
|
x86_64 = { bits = 64; significantByte = littleEndian; };
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-03-13 15:05:30 +01:00
|
|
|
isExecFormat = isType "exec-format";
|
2009-11-19 18:19:39 +01:00
|
|
|
execFormats = setTypes "exec-format" {
|
|
|
|
aout = {}; # a.out
|
|
|
|
elf = {};
|
|
|
|
macho = {};
|
|
|
|
pe = {};
|
|
|
|
unknow = {};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-03-13 15:05:30 +01:00
|
|
|
isKernel = isType "kernel";
|
2009-11-19 18:19:39 +01:00
|
|
|
kernels = with execFormats;
|
|
|
|
setTypes "kernel" {
|
|
|
|
cygwin = { execFormat = pe; };
|
|
|
|
darwin = { execFormat = macho; };
|
|
|
|
freebsd = { execFormat = elf; };
|
|
|
|
linux = { execFormat = elf; };
|
|
|
|
netbsd = { execFormat = elf; };
|
|
|
|
none = { execFormat = unknow; };
|
|
|
|
openbsd = { execFormat = elf; };
|
|
|
|
win32 = { execFormat = pe; };
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-03-13 15:05:30 +01:00
|
|
|
isArchitecture = isType "architecture";
|
2009-11-19 18:19:39 +01:00
|
|
|
architectures = setTypes "architecture" {
|
|
|
|
apple = {};
|
|
|
|
pc = {};
|
|
|
|
unknow = {};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-10-28 01:24:30 +01:00
|
|
|
isSystem = x: isType "system" x
|
2009-11-19 18:19:39 +01:00
|
|
|
&& isCpuType x.cpu
|
|
|
|
&& isArchitecture x.arch
|
|
|
|
&& isKernel x.kernel;
|
|
|
|
|
|
|
|
mkSystem = {
|
|
|
|
cpu ? cpuTypes.i686,
|
|
|
|
arch ? architectures.pc,
|
|
|
|
kernel ? kernels.linux,
|
|
|
|
name ? "${cpu.name}-${arch.name}-${kernel.name}"
|
|
|
|
}: setType "system" {
|
|
|
|
inherit name cpu arch kernel;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
isDarwin = matchAttrs { kernel = kernels.darwin; };
|
|
|
|
isLinux = matchAttrs { kernel = kernels.linux; };
|
|
|
|
isi686 = matchAttrs { cpu = cpuTypes.i686; };
|
|
|
|
is64Bit = matchAttrs { cpu = { bits = 64; }; };
|
|
|
|
|
|
|
|
|
|
|
|
# This should revert the job done by config.guess from the gcc compiler.
|
|
|
|
mkSystemFromString = s: let
|
|
|
|
l = lib.splitString "-" s;
|
|
|
|
|
|
|
|
getCpu = name:
|
|
|
|
attrByPath [name] (throw "Unknow cpuType `${name}'.")
|
|
|
|
cpuTypes;
|
|
|
|
getArch = name:
|
|
|
|
attrByPath [name] (throw "Unknow architecture `${name}'.")
|
|
|
|
architectures;
|
|
|
|
getKernel = name:
|
|
|
|
attrByPath [name] (throw "Unknow kernel `${name}'.")
|
|
|
|
kernels;
|
|
|
|
|
|
|
|
system =
|
|
|
|
if builtins.length l == 2 then
|
|
|
|
mkSystem rec {
|
|
|
|
name = s;
|
|
|
|
cpu = getCpu (head l);
|
|
|
|
arch =
|
|
|
|
if isDarwin system
|
|
|
|
then architectures.apple
|
|
|
|
else architectures.pc;
|
|
|
|
kernel = getKernel (head (tail l));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
mkSystem {
|
|
|
|
name = s;
|
|
|
|
cpu = getCpu (head l);
|
|
|
|
arch = getArch (head (tail l));
|
|
|
|
kernel = getKernel (head (tail (tail l)));
|
|
|
|
};
|
|
|
|
in assert isSystem system; system;
|
|
|
|
}
|