2024-05-01 22:14:04 +00:00
|
|
|
{ lib }:
|
|
|
|
|
|
|
|
let
|
|
|
|
inherit (lib)
|
|
|
|
any
|
|
|
|
attrValues
|
|
|
|
concatMap
|
|
|
|
filter
|
|
|
|
hasPrefix
|
|
|
|
isList
|
|
|
|
mapAttrs
|
|
|
|
matchAttrs
|
|
|
|
recursiveUpdateUntil
|
|
|
|
toList
|
|
|
|
;
|
|
|
|
|
|
|
|
inherit (lib.strings) toJSON;
|
|
|
|
|
|
|
|
inherit (lib.systems.parse)
|
|
|
|
kernels
|
|
|
|
kernelFamilies
|
|
|
|
significantBytes
|
|
|
|
cpuTypes
|
|
|
|
execFormats
|
|
|
|
;
|
|
|
|
|
|
|
|
abis = mapAttrs (_: abi: removeAttrs abi [ "assertions" ]) lib.systems.parse.abis;
|
|
|
|
in
|
|
|
|
|
|
|
|
rec {
|
|
|
|
# these patterns are to be matched against {host,build,target}Platform.parsed
|
|
|
|
patterns = rec {
|
|
|
|
# The patterns below are lists in sum-of-products form.
|
|
|
|
#
|
|
|
|
# Each attribute is list of product conditions; non-list values are treated
|
|
|
|
# as a singleton list. If *any* product condition in the list matches then
|
|
|
|
# the predicate matches. Each product condition is tested by
|
|
|
|
# `lib.attrsets.matchAttrs`, which requires a match on *all* attributes of
|
|
|
|
# the product.
|
|
|
|
|
|
|
|
isi686 = {
|
|
|
|
cpu = cpuTypes.i686;
|
|
|
|
};
|
|
|
|
isx86_32 = {
|
|
|
|
cpu = {
|
|
|
|
family = "x86";
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isx86_64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "x86";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isPower = {
|
|
|
|
cpu = {
|
|
|
|
family = "power";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isPower64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "power";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
# This ABI is the default in NixOS PowerPC64 BE, but not on mainline GCC,
|
|
|
|
# so it sometimes causes issues in certain packages that makes the wrong
|
|
|
|
# assumption on the used ABI.
|
|
|
|
isAbiElfv2 = [
|
|
|
|
{
|
|
|
|
abi = {
|
|
|
|
abi = "elfv2";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
abi = {
|
|
|
|
name = "musl";
|
|
|
|
};
|
|
|
|
cpu = {
|
|
|
|
family = "power";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
];
|
|
|
|
isx86 = {
|
|
|
|
cpu = {
|
|
|
|
family = "x86";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isAarch32 = {
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isArmv7 = map (
|
|
|
|
{ arch, ... }:
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
inherit arch;
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
}
|
2024-05-01 22:14:04 +00:00
|
|
|
) (filter (cpu: hasPrefix "armv7" cpu.arch or "") (attrValues cpuTypes));
|
|
|
|
isAarch64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isAarch = {
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMicroBlaze = {
|
|
|
|
cpu = {
|
|
|
|
family = "microblaze";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMips = {
|
2024-06-30 08:12:46 +00:00
|
|
|
cpu = {
|
2024-05-01 22:14:04 +00:00
|
|
|
family = "mips";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMips32 = {
|
|
|
|
cpu = {
|
|
|
|
family = "mips";
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMips64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "mips";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMips64n32 = {
|
|
|
|
cpu = {
|
|
|
|
family = "mips";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
abi = {
|
|
|
|
abi = "n32";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMips64n64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "mips";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
abi = {
|
|
|
|
abi = "64";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMmix = {
|
|
|
|
cpu = {
|
|
|
|
family = "mmix";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isRiscV = {
|
|
|
|
cpu = {
|
|
|
|
family = "riscv";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isRiscV32 = {
|
|
|
|
cpu = {
|
|
|
|
family = "riscv";
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isRiscV64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "riscv";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
isRx = {
|
2024-05-01 22:14:04 +00:00
|
|
|
cpu = {
|
|
|
|
family = "rx";
|
2024-06-30 08:12:46 +00:00
|
|
|
};
|
|
|
|
};
|
2024-05-01 22:14:04 +00:00
|
|
|
isSparc = {
|
2024-06-30 08:12:46 +00:00
|
|
|
cpu = {
|
2024-05-01 22:14:04 +00:00
|
|
|
family = "sparc";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isSparc64 = {
|
|
|
|
cpu = {
|
|
|
|
family = "sparc";
|
|
|
|
bits = 64;
|
2024-06-30 08:12:46 +00:00
|
|
|
};
|
|
|
|
};
|
2024-05-01 22:14:04 +00:00
|
|
|
isWasm = {
|
2024-06-30 08:12:46 +00:00
|
|
|
cpu = {
|
2024-05-01 22:14:04 +00:00
|
|
|
family = "wasm";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isMsp430 = {
|
|
|
|
cpu = {
|
|
|
|
family = "msp430";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isVc4 = {
|
|
|
|
cpu = {
|
|
|
|
family = "vc4";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isAvr = {
|
|
|
|
cpu = {
|
|
|
|
family = "avr";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isAlpha = {
|
|
|
|
cpu = {
|
|
|
|
family = "alpha";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isOr1k = {
|
|
|
|
cpu = {
|
|
|
|
family = "or1k";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isM68k = {
|
|
|
|
cpu = {
|
|
|
|
family = "m68k";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isS390 = {
|
|
|
|
cpu = {
|
|
|
|
family = "s390";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isS390x = {
|
|
|
|
cpu = {
|
|
|
|
family = "s390";
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isLoongArch64 = {
|
2024-06-30 08:12:46 +00:00
|
|
|
cpu = {
|
2024-05-01 22:14:04 +00:00
|
|
|
family = "loongarch";
|
|
|
|
bits = 64;
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
};
|
2024-05-01 22:14:04 +00:00
|
|
|
isJavaScript = {
|
|
|
|
cpu = cpuTypes.javascript;
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
|
2024-05-01 22:14:04 +00:00
|
|
|
is32bit = {
|
|
|
|
cpu = {
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
is64bit = {
|
|
|
|
cpu = {
|
|
|
|
bits = 64;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isILP32 =
|
|
|
|
[
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "wasm";
|
|
|
|
bits = 32;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
]
|
|
|
|
++ map
|
|
|
|
(a: {
|
|
|
|
abi = {
|
|
|
|
abi = a;
|
|
|
|
};
|
|
|
|
})
|
|
|
|
[
|
|
|
|
"n32"
|
|
|
|
"ilp32"
|
|
|
|
"x32"
|
|
|
|
];
|
|
|
|
isBigEndian = {
|
|
|
|
cpu = {
|
|
|
|
significantByte = significantBytes.bigEndian;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isLittleEndian = {
|
|
|
|
cpu = {
|
|
|
|
significantByte = significantBytes.littleEndian;
|
|
|
|
};
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
|
2024-05-01 22:14:04 +00:00
|
|
|
isBSD = {
|
|
|
|
kernel = {
|
|
|
|
families = {
|
|
|
|
inherit (kernelFamilies) bsd;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
isDarwin = {
|
|
|
|
kernel = {
|
|
|
|
families = {
|
|
|
|
inherit (kernelFamilies) darwin;
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
};
|
|
|
|
};
|
2024-05-01 22:14:04 +00:00
|
|
|
isUnix = [
|
|
|
|
isBSD
|
|
|
|
isDarwin
|
|
|
|
isLinux
|
|
|
|
isSunOS
|
|
|
|
isCygwin
|
|
|
|
isRedox
|
|
|
|
];
|
2024-06-30 08:12:46 +00:00
|
|
|
|
2024-05-01 22:14:04 +00:00
|
|
|
isMacOS = {
|
|
|
|
kernel = kernels.macos;
|
|
|
|
};
|
|
|
|
isiOS = {
|
|
|
|
kernel = kernels.ios;
|
|
|
|
};
|
|
|
|
isLinux = {
|
|
|
|
kernel = kernels.linux;
|
|
|
|
};
|
|
|
|
isSunOS = {
|
|
|
|
kernel = kernels.solaris;
|
|
|
|
};
|
|
|
|
isFreeBSD = {
|
|
|
|
kernel = {
|
|
|
|
name = "freebsd";
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
};
|
2024-05-01 22:14:04 +00:00
|
|
|
isNetBSD = {
|
|
|
|
kernel = kernels.netbsd;
|
|
|
|
};
|
|
|
|
isOpenBSD = {
|
|
|
|
kernel = kernels.openbsd;
|
|
|
|
};
|
|
|
|
isWindows = {
|
|
|
|
kernel = kernels.windows;
|
|
|
|
};
|
|
|
|
isCygwin = {
|
|
|
|
kernel = kernels.windows;
|
|
|
|
abi = abis.cygnus;
|
|
|
|
};
|
|
|
|
isMinGW = {
|
|
|
|
kernel = kernels.windows;
|
|
|
|
abi = abis.gnu;
|
|
|
|
};
|
|
|
|
isWasi = {
|
|
|
|
kernel = kernels.wasi;
|
|
|
|
};
|
|
|
|
isRedox = {
|
|
|
|
kernel = kernels.redox;
|
|
|
|
};
|
|
|
|
isGhcjs = {
|
|
|
|
kernel = kernels.ghcjs;
|
|
|
|
};
|
|
|
|
isGenode = {
|
|
|
|
kernel = kernels.genode;
|
|
|
|
};
|
|
|
|
isNone = {
|
|
|
|
kernel = kernels.none;
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
|
2024-05-01 22:14:04 +00:00
|
|
|
isAndroid = [
|
|
|
|
{ abi = abis.android; }
|
|
|
|
{ abi = abis.androideabi; }
|
|
|
|
];
|
|
|
|
isGnu =
|
|
|
|
with abis;
|
|
|
|
map (a: { abi = a; }) [
|
|
|
|
gnuabi64
|
|
|
|
gnuabin32
|
|
|
|
gnu
|
|
|
|
gnueabi
|
|
|
|
gnueabihf
|
|
|
|
gnuabielfv1
|
|
|
|
gnuabielfv2
|
2024-06-30 08:12:46 +00:00
|
|
|
];
|
|
|
|
isMusl =
|
2024-05-01 22:14:04 +00:00
|
|
|
with abis;
|
|
|
|
map (a: { abi = a; }) [
|
|
|
|
musl
|
|
|
|
musleabi
|
|
|
|
musleabihf
|
|
|
|
muslabin32
|
|
|
|
muslabi64
|
|
|
|
];
|
|
|
|
isUClibc =
|
|
|
|
with abis;
|
|
|
|
map (a: { abi = a; }) [
|
|
|
|
uclibc
|
|
|
|
uclibceabi
|
|
|
|
uclibceabihf
|
|
|
|
];
|
|
|
|
|
|
|
|
isEfi = [
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
version = "6";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
version = "7";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "arm";
|
|
|
|
version = "8";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "riscv";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
cpu = {
|
|
|
|
family = "x86";
|
|
|
|
};
|
2024-06-30 08:12:46 +00:00
|
|
|
}
|
2024-05-01 22:14:04 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
isElf = {
|
|
|
|
kernel.execFormat = execFormats.elf;
|
|
|
|
};
|
|
|
|
isMacho = {
|
|
|
|
kernel.execFormat = execFormats.macho;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# given two patterns, return a pattern which is their logical AND.
|
|
|
|
# Since a pattern is a list-of-disjuncts, this needs to
|
|
|
|
patternLogicalAnd =
|
|
|
|
pat1_: pat2_:
|
|
|
|
let
|
|
|
|
# patterns can be either a list or a (bare) singleton; turn
|
|
|
|
# them into singletons for uniform handling
|
|
|
|
pat1 = toList pat1_;
|
|
|
|
pat2 = toList pat2_;
|
|
|
|
in
|
|
|
|
concatMap (
|
|
|
|
attr1:
|
|
|
|
map (
|
|
|
|
attr2:
|
|
|
|
recursiveUpdateUntil (
|
|
|
|
path: subattr1: subattr2:
|
|
|
|
if (builtins.intersectAttrs subattr1 subattr2) == { } || subattr1 == subattr2 then
|
|
|
|
true
|
|
|
|
else
|
|
|
|
throw ''
|
|
|
|
pattern conflict at path ${toString path}:
|
|
|
|
${toJSON subattr1}
|
|
|
|
${toJSON subattr2}
|
|
|
|
''
|
|
|
|
) attr1 attr2
|
|
|
|
) pat2
|
|
|
|
) pat1;
|
2024-06-30 08:12:46 +00:00
|
|
|
|
2024-05-01 22:14:04 +00:00
|
|
|
matchAnyAttrs =
|
|
|
|
patterns:
|
|
|
|
if isList patterns then
|
|
|
|
attrs: any (pattern: matchAttrs pattern attrs) patterns
|
|
|
|
else
|
|
|
|
matchAttrs patterns;
|
|
|
|
|
|
|
|
predicates = mapAttrs (_: matchAnyAttrs) patterns;
|
|
|
|
|
|
|
|
# these patterns are to be matched against the entire
|
|
|
|
# {host,build,target}Platform structure; they include a `parsed={}` marker so
|
|
|
|
# that `lib.meta.availableOn` can distinguish them from the patterns which
|
|
|
|
# apply only to the `parsed` field.
|
|
|
|
|
|
|
|
platformPatterns = mapAttrs (_: p: { parsed = { }; } // p) {
|
|
|
|
isStatic = {
|
|
|
|
isStatic = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|