Compare commits
No commits in common. "931687439679b835f6516ad2dbec114d26a05ad7" and "8e9cb4fbe92205d0256bb9bc759f86c5d45ca487" have entirely different histories.
9316874396
...
8e9cb4fbe9
|
@ -3,10 +3,10 @@
|
||||||
"lib": {
|
"lib": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "lib",
|
"dir": "lib",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "9c29945531c58ad81f05cd1f4958c8894a733216-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "9c29945-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1718255029,
|
||||||
"narHash": "sha256-tv/0C7ixH+9Ij+r+5nua48OlXXXnbdEsnenxX4eG/Sk=",
|
"narHash": "sha256-iPMsyNszFA+EzjtIpjmu9EAG7zdjLbuugLtfa64dJos=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=lib"
|
"url": "file:../?dir=lib"
|
||||||
},
|
},
|
||||||
|
|
|
@ -59,34 +59,7 @@ lib: {
|
||||||
};
|
};
|
||||||
|
|
||||||
apply = {
|
apply = {
|
||||||
## Apply a set of defaults to a graph. This will ensure that missing entries are added
|
# defaults = graph: defaults:
|
||||||
## and any entries that do exist are given the appropriate `before` and `after` values.
|
|
||||||
##
|
|
||||||
## @type Dag a -> Dag a -> Dag a
|
|
||||||
defaults = graph: defaults: let
|
|
||||||
result =
|
|
||||||
builtins.mapAttrs
|
|
||||||
(
|
|
||||||
name: entry:
|
|
||||||
if defaults ? ${name}
|
|
||||||
then
|
|
||||||
if builtins.isString entry
|
|
||||||
then {
|
|
||||||
value = entry;
|
|
||||||
before = defaults.${name}.before or [];
|
|
||||||
after = defaults.${name}.after or [];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
entry
|
|
||||||
// {
|
|
||||||
before = (entry.before or []) ++ (defaults.${name}.before or []);
|
|
||||||
after = (entry.after or []) ++ (defaults.${name}.after or []);
|
|
||||||
}
|
|
||||||
else entry
|
|
||||||
)
|
|
||||||
graph;
|
|
||||||
in
|
|
||||||
defaults // result;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
## Map over the entries in a DAG and modify their values.
|
## Map over the entries in a DAG and modify their values.
|
||||||
|
|
|
@ -820,7 +820,6 @@ lib: {
|
||||||
check = value: builtins.isAttrs value || builtins.isFunction value || lib.types.path.check value;
|
check = value: builtins.isAttrs value || builtins.isFunction value || lib.types.path.check value;
|
||||||
merge = location: definitions: let
|
merge = location: definitions: let
|
||||||
result = base.extend {
|
result = base.extend {
|
||||||
prefix = location;
|
|
||||||
modules =
|
modules =
|
||||||
[{config.__module__.args.dynamic.name = lib.lists.last location;}]
|
[{config.__module__.args.dynamic.name = lib.lists.last location;}]
|
||||||
++ getModules definitions;
|
++ getModules definitions;
|
||||||
|
|
|
@ -8,10 +8,10 @@
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "foundation",
|
"dir": "foundation",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "0312e3c4cc261e2384fcf372c766a0cf245f3213-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "0312e3c-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1718460525,
|
||||||
"narHash": "sha256-X1Wd6mDz8GTaoxt1ylkvZfrJOcZtspJrEjXMtJ2ZyG0=",
|
"narHash": "sha256-+ToaXY8ISWLx9AtO/CjfY/6SGuKu8A/d9ncqE4h2H20=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=foundation"
|
"url": "file:../?dir=foundation"
|
||||||
},
|
},
|
||||||
|
@ -24,10 +24,10 @@
|
||||||
"lib": {
|
"lib": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "lib",
|
"dir": "lib",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "0312e3c4cc261e2384fcf372c766a0cf245f3213-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "0312e3c-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1718460525,
|
||||||
"narHash": "sha256-X1Wd6mDz8GTaoxt1ylkvZfrJOcZtspJrEjXMtJ2ZyG0=",
|
"narHash": "sha256-+ToaXY8ISWLx9AtO/CjfY/6SGuKu8A/d9ncqE4h2H20=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=lib"
|
"url": "file:../?dir=lib"
|
||||||
},
|
},
|
||||||
|
|
|
@ -24,10 +24,6 @@ in {
|
||||||
# }))
|
# }))
|
||||||
# .config;
|
# .config;
|
||||||
foundation-gcc = config.packages.foundation.gcc;
|
foundation-gcc = config.packages.foundation.gcc;
|
||||||
foundation-binutils = config.packages.foundation.binutils;
|
|
||||||
foundation-linux-headers = config.packages.foundation.linux-headers.versions.latest.extend {
|
|
||||||
platform.host = lib.modules.overrides.force "x86_64-linux";
|
|
||||||
};
|
|
||||||
# example-x = config.packages.example.x;
|
# example-x = config.packages.example.x;
|
||||||
# cross-example-x-x86_64-linux = config.packages.cross.x86_64-linux.example.x;
|
# cross-example-x-x86_64-linux = config.packages.cross.x86_64-linux.example.x;
|
||||||
};
|
};
|
||||||
|
|
|
@ -24,7 +24,7 @@ in {
|
||||||
builtins.mapAttrs
|
builtins.mapAttrs
|
||||||
(
|
(
|
||||||
name: package: let
|
name: package: let
|
||||||
result = lib'.packages.build package system system system;
|
result = lib'.packages.build package system system;
|
||||||
in
|
in
|
||||||
result
|
result
|
||||||
)
|
)
|
||||||
|
|
|
@ -21,37 +21,37 @@
|
||||||
in
|
in
|
||||||
builtins.head sorted;
|
builtins.head sorted;
|
||||||
|
|
||||||
build = package: build: host: target: let
|
build = package: system: cross: let
|
||||||
resolved =
|
resolved =
|
||||||
if package ? versions
|
if package ? versions
|
||||||
then package.versions.${config.preferences.packages.version} or (package.versions.${lib'.packages.getLatest package})
|
then package.versions.${config.preferences.packages.version} or (package.versions.${lib'.packages.getLatest package})
|
||||||
else package;
|
else package;
|
||||||
|
|
||||||
buildDependencies = build': host': target': builtins.mapAttrs (name: dep: lib'.packages.build dep build' host' target');
|
buildDependencies = builtins.mapAttrs (name: dep: lib'.packages.build dep system cross);
|
||||||
|
|
||||||
result = resolved.extend ({config}: {
|
result = resolved.extend ({config}: {
|
||||||
config = {
|
config = {
|
||||||
platform = {
|
platform = {
|
||||||
build = build;
|
build = system;
|
||||||
host = host;
|
host = cross;
|
||||||
target = lib.modules.override 150 target;
|
target = lib.modules.override 150 cross;
|
||||||
};
|
};
|
||||||
|
|
||||||
deps = {
|
deps = {
|
||||||
build = {
|
build = {
|
||||||
only = buildDependencies build build build resolved.deps.build.only;
|
only = buildDependencies resolved.deps.build.only;
|
||||||
build = buildDependencies build build target resolved.deps.build.build;
|
build = buildDependencies resolved.deps.build.build;
|
||||||
host = buildDependencies build host target resolved.deps.build.host;
|
host = buildDependencies resolved.deps.build.host;
|
||||||
target = buildDependencies build target target resolved.deps.build.target;
|
target = buildDependencies resolved.deps.build.target;
|
||||||
};
|
};
|
||||||
host = {
|
host = {
|
||||||
only = buildDependencies host host host resolved.deps.host.only;
|
only = buildDependencies resolved.deps.host.only;
|
||||||
host = buildDependencies host host target resolved.deps.host.host;
|
host = buildDependencies resolved.deps.host.host;
|
||||||
target = buildDependencies host target target resolved.deps.host.target;
|
target = buildDependencies resolved.deps.host.target;
|
||||||
};
|
};
|
||||||
target = {
|
target = {
|
||||||
only = buildDependencies target target target resolved.deps.target.only;
|
only = buildDependencies resolved.deps.target.only;
|
||||||
target = buildDependencies target target target resolved.deps.target.target;
|
target = buildDependencies resolved.deps.target.target;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
in
|
in
|
||||||
result;
|
result.config;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,13 +14,7 @@
|
||||||
|
|
||||||
matchAnyAttrs = patterns:
|
matchAnyAttrs = patterns:
|
||||||
if builtins.isList patterns
|
if builtins.isList patterns
|
||||||
then
|
then value: builtins.any (pattern: lib.attrs.match pattern value) patterns
|
||||||
value:
|
|
||||||
builtins.any (pattern:
|
|
||||||
if builtins.isFunction pattern
|
|
||||||
then pattern value
|
|
||||||
else matchAnyAttrs pattern value)
|
|
||||||
patterns
|
|
||||||
else lib.attrs.match patterns;
|
else lib.attrs.match patterns;
|
||||||
|
|
||||||
getDoubles = predicate:
|
getDoubles = predicate:
|
||||||
|
@ -1592,8 +1586,8 @@ in {
|
||||||
};
|
};
|
||||||
isArmv7 =
|
isArmv7 =
|
||||||
map ({arch, ...}: {cpu = {inherit arch;};})
|
map ({arch, ...}: {cpu = {inherit arch;};})
|
||||||
(builtins.filter (cpu: lib.strings.hasPrefix "armv7" cpu.arch or "")
|
(lib.filter (cpu: lib.hasPrefix "armv7" cpu.arch or "")
|
||||||
(builtins.attrValues types.cpus));
|
(lib.attrValues types.cpus));
|
||||||
isAarch64 = {
|
isAarch64 = {
|
||||||
cpu = {
|
cpu = {
|
||||||
family = "arm";
|
family = "arm";
|
||||||
|
@ -1932,7 +1926,7 @@ in {
|
||||||
// lib'.systems.platforms.select resolved)
|
// lib'.systems.platforms.select resolved)
|
||||||
linux-kernel
|
linux-kernel
|
||||||
gcc
|
gcc
|
||||||
rustc
|
rust
|
||||||
;
|
;
|
||||||
|
|
||||||
double = lib'.systems.into.double resolved.system;
|
double = lib'.systems.into.double resolved.system;
|
||||||
|
@ -2103,7 +2097,7 @@ in {
|
||||||
then "x86" # not i386
|
then "x86" # not i386
|
||||||
else if resolved.isMips64
|
else if resolved.isMips64
|
||||||
then "mips64" # uboot *does* distinguish between mips32/mips64
|
then "mips64" # uboot *does* distinguish between mips32/mips64
|
||||||
else resolved.linux.arch # other cases appear to agree with linuxArch
|
else resolved.linuxArch; # other cases appear to agree with linuxArch
|
||||||
|
|
||||||
qemu.arch =
|
qemu.arch =
|
||||||
if resolved.isAarch32
|
if resolved.isAarch32
|
||||||
|
@ -2168,7 +2162,7 @@ in {
|
||||||
}
|
}
|
||||||
// builtins.mapAttrs (name: match: match resolved.system) lib'.systems.match
|
// builtins.mapAttrs (name: match: match resolved.system) lib'.systems.match
|
||||||
// builtins.mapAttrs (name: validate: validate (resolved.gcc.arch or "default")) lib'.systems.validate.architecture
|
// builtins.mapAttrs (name: validate: validate (resolved.gcc.arch or "default")) lib'.systems.validate.architecture
|
||||||
// (builtins.removeAttrs settings ["system"]);
|
// settings;
|
||||||
|
|
||||||
assertions =
|
assertions =
|
||||||
builtins.foldl'
|
builtins.foldl'
|
||||||
|
|
|
@ -82,15 +82,13 @@
|
||||||
extend = lib.options.create {
|
extend = lib.options.create {
|
||||||
description = "Extend the package's submodules with additional configuration.";
|
description = "Extend the package's submodules with additional configuration.";
|
||||||
type = lib.types.function lib.types.raw;
|
type = lib.types.function lib.types.raw;
|
||||||
default.value = value: let
|
default.value = value:
|
||||||
result = meta.extend {
|
meta.extend {
|
||||||
modules =
|
modules =
|
||||||
if builtins.isAttrs value
|
if builtins.isAttrs value
|
||||||
then [{config = value;}]
|
then [{config = value;}]
|
||||||
else lib.lists.from.any value;
|
else lib.lists.from.any value;
|
||||||
};
|
};
|
||||||
in
|
|
||||||
result.config;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
name = lib.options.create {
|
name = lib.options.create {
|
||||||
|
@ -174,47 +172,40 @@
|
||||||
default.value = "x86_64-linux";
|
default.value = "x86_64-linux";
|
||||||
apply = raw: let
|
apply = raw: let
|
||||||
system = lib'.systems.from.string raw;
|
system = lib'.systems.from.string raw;
|
||||||
x = lib'.systems.withBuildInfo raw;
|
in {
|
||||||
in
|
inherit raw system;
|
||||||
x;
|
|
||||||
|
double = lib'.systems.into.double system;
|
||||||
|
triple = lib'.systems.into.triple system;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
host = lib.options.create {
|
host = lib.options.create {
|
||||||
description = "The host platform for the package.";
|
description = "The host platform for the package.";
|
||||||
type = lib.types.string;
|
type = lib.types.string;
|
||||||
default.value = "x86_64-linux";
|
default.value = "x86_64-linux";
|
||||||
# apply = raw: let
|
|
||||||
# system = lib'.systems.from.string raw;
|
|
||||||
# in {
|
|
||||||
# inherit raw system;
|
|
||||||
|
|
||||||
# double = lib'.systems.into.double system;
|
|
||||||
# triple = lib'.systems.into.triple system;
|
|
||||||
# };
|
|
||||||
apply = raw: let
|
apply = raw: let
|
||||||
system = lib'.systems.from.string raw;
|
system = lib'.systems.from.string raw;
|
||||||
x = lib'.systems.withBuildInfo raw;
|
in {
|
||||||
in
|
inherit raw system;
|
||||||
x;
|
|
||||||
|
double = lib'.systems.into.double system;
|
||||||
|
triple = lib'.systems.into.triple system;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
target = lib.options.create {
|
target = lib.options.create {
|
||||||
description = "The target platform for the package.";
|
description = "The target platform for the package.";
|
||||||
type = lib.types.string;
|
type = lib.types.string;
|
||||||
default.value = "x86_64-linux";
|
default.value = "x86_64-linux";
|
||||||
# apply = raw: let
|
|
||||||
# system = lib'.systems.from.string raw;
|
|
||||||
# in {
|
|
||||||
# inherit raw system;
|
|
||||||
|
|
||||||
# double = lib'.systems.into.double system;
|
|
||||||
# triple = lib'.systems.into.triple system;
|
|
||||||
# };
|
|
||||||
apply = raw: let
|
apply = raw: let
|
||||||
system = lib'.systems.from.string raw;
|
system = lib'.systems.from.string raw;
|
||||||
x = lib'.systems.withBuildInfo raw;
|
in {
|
||||||
in
|
inherit raw system;
|
||||||
x;
|
|
||||||
|
double = lib'.systems.into.double system;
|
||||||
|
triple = lib'.systems.into.triple system;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,117 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
config,
|
|
||||||
options,
|
|
||||||
}: let
|
|
||||||
inherit
|
|
||||||
(config)
|
|
||||||
mirrors
|
|
||||||
builders
|
|
||||||
# These are the upstream foundational packages exported from the Aux Foundation project.
|
|
||||||
|
|
||||||
foundation
|
|
||||||
;
|
|
||||||
in {
|
|
||||||
config.packages.foundation.binutils = {
|
|
||||||
versions = {
|
|
||||||
"latest" = {
|
|
||||||
config,
|
|
||||||
meta,
|
|
||||||
}: {
|
|
||||||
options = {
|
|
||||||
src = lib.options.create {
|
|
||||||
type = lib.types.derivation;
|
|
||||||
description = "Source for the package.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = {
|
|
||||||
meta = {
|
|
||||||
platforms = ["i686-linux"];
|
|
||||||
};
|
|
||||||
|
|
||||||
pname = "binutils";
|
|
||||||
version = "2.41";
|
|
||||||
|
|
||||||
builder = builders.basic;
|
|
||||||
|
|
||||||
env = {
|
|
||||||
PATH = lib.paths.bin [
|
|
||||||
foundation.stage2-gcc
|
|
||||||
foundation.stage2-binutils
|
|
||||||
foundation.stage2-gnumake
|
|
||||||
foundation.stage2-gnupatch
|
|
||||||
foundation.stage2-gnused
|
|
||||||
foundation.stage2-gnugrep
|
|
||||||
foundation.stage2-gawk
|
|
||||||
foundation.stage2-diffutils
|
|
||||||
foundation.stage2-findutils
|
|
||||||
foundation.stage2-gnutar
|
|
||||||
foundation.stage1-xz
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
phases = let
|
|
||||||
patches = [
|
|
||||||
# Make binutils output deterministic by default.
|
|
||||||
./patches/deterministic.patch
|
|
||||||
];
|
|
||||||
|
|
||||||
configureFlags = [
|
|
||||||
# "CC=musl-gcc"
|
|
||||||
"LDFLAGS=--static"
|
|
||||||
"--prefix=${builtins.placeholder "out"}"
|
|
||||||
"--build=${config.platform.build.triple}"
|
|
||||||
"--host=${config.platform.host.triple}"
|
|
||||||
"--target=${config.platform.target.triple}"
|
|
||||||
|
|
||||||
"--with-sysroot=/"
|
|
||||||
"--enable-deterministic-archives"
|
|
||||||
# depends on bison
|
|
||||||
"--disable-gprofng"
|
|
||||||
|
|
||||||
# Turn on --enable-new-dtags by default to make the linker set
|
|
||||||
# RUNPATH instead of RPATH on binaries. This is important because
|
|
||||||
# RUNPATH can be overridden using LD_LIBRARY_PATH at runtime.
|
|
||||||
"--enable-new-dtags"
|
|
||||||
|
|
||||||
# By default binutils searches $libdir for libraries. This brings in
|
|
||||||
# libbfd and libopcodes into a default visibility. Drop default lib
|
|
||||||
# path to force users to declare their use of these libraries.
|
|
||||||
"--with-lib-path=:"
|
|
||||||
|
|
||||||
"--disable-multilib"
|
|
||||||
];
|
|
||||||
in {
|
|
||||||
unpack = lib.dag.entry.before ["patch"] ''
|
|
||||||
tar xf ${config.src}
|
|
||||||
cd binutils-${config.version}
|
|
||||||
'';
|
|
||||||
|
|
||||||
patch = lib.dag.entry.between ["configure"] ["unpack"] ''
|
|
||||||
${lib.strings.concatMapSep "\n" (file: "patch -Np1 -i ${file}") patches}
|
|
||||||
'';
|
|
||||||
|
|
||||||
configure = lib.dag.entry.between ["build"] ["patch"] ''
|
|
||||||
bash ./configure ${builtins.concatStringsSep " " configureFlags}
|
|
||||||
'';
|
|
||||||
|
|
||||||
build = lib.dag.entry.between ["install"] ["configure"] ''
|
|
||||||
make -j $NIX_BUILD_CORES
|
|
||||||
'';
|
|
||||||
|
|
||||||
install = lib.dag.entry.after ["build"] ''
|
|
||||||
make -j $NIX_BUILD_CORES install-strip
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
src = builtins.fetchurl {
|
|
||||||
url = "${mirrors.gnu}/binutils/binutils-${config.version}.tar.xz";
|
|
||||||
sha256 = "rppXieI0WeWWBuZxRyPy0//DHAMXQZHvDQFb3wYAdFA=";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
diff -ur orig/binutils-2.23.1/ld/ldlang.c binutils-2.23.1/ld/ldlang.c
|
|
||||||
--- orig/ld/ldlang.c
|
|
||||||
+++ new/ld/ldlang.c
|
|
||||||
@@ -3095,6 +3095,8 @@
|
|
||||||
ldfile_output_machine))
|
|
||||||
einfo (_("%P%F:%s: can not set architecture: %E\n"), name);
|
|
||||||
|
|
||||||
+ link_info.output_bfd->flags |= BFD_DETERMINISTIC_OUTPUT;
|
|
||||||
+
|
|
||||||
link_info.hash = bfd_link_hash_table_create (link_info.output_bfd);
|
|
||||||
if (link_info.hash == NULL)
|
|
||||||
einfo (_("%P%F: can not create hash table: %E\n"));
|
|
||||||
|
|
|
@ -6,8 +6,6 @@
|
||||||
}: {
|
}: {
|
||||||
includes = [
|
includes = [
|
||||||
./gcc
|
./gcc
|
||||||
./binutils
|
|
||||||
./linux-headers
|
|
||||||
];
|
];
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
in {
|
in {
|
||||||
config.packages.foundation.gcc = {
|
config.packages.foundation.gcc = {
|
||||||
versions = {
|
versions = {
|
||||||
"latest" = {
|
"13.2.0" = {
|
||||||
config,
|
config,
|
||||||
meta,
|
meta,
|
||||||
}: {
|
}: {
|
||||||
|
@ -98,12 +98,9 @@ in {
|
||||||
then foundation.stage2-gcc
|
then foundation.stage2-gcc
|
||||||
# Otherwise we are going to need a cross-compiler.
|
# Otherwise we are going to need a cross-compiler.
|
||||||
else
|
else
|
||||||
# TODO: Create a gcc-cross package.
|
|
||||||
(meta.extend (args: {
|
(meta.extend (args: {
|
||||||
config = {
|
config = {
|
||||||
platform = {
|
platform = {
|
||||||
build = config.platform.build.triple;
|
|
||||||
host = config.platform.build.triple;
|
|
||||||
target = lib.modules.override.force config.platform.host.triple;
|
target = lib.modules.override.force config.platform.host.triple;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -129,14 +126,6 @@ in {
|
||||||
|
|
||||||
phases = let
|
phases = let
|
||||||
host = lib'.systems.withBuildInfo config.platform.host;
|
host = lib'.systems.withBuildInfo config.platform.host;
|
||||||
|
|
||||||
mbits =
|
|
||||||
if host.system.cpu.family == "x86"
|
|
||||||
then
|
|
||||||
if host.is64bit
|
|
||||||
then "-m64"
|
|
||||||
else "-m32"
|
|
||||||
else "";
|
|
||||||
in {
|
in {
|
||||||
unpack = lib.dag.entry.before ["patch"] ''
|
unpack = lib.dag.entry.before ["patch"] ''
|
||||||
# Unpack
|
# Unpack
|
||||||
|
@ -161,7 +150,7 @@ in {
|
||||||
|
|
||||||
configure = lib.dag.entry.between ["build"] ["patch"] ''
|
configure = lib.dag.entry.between ["build"] ["patch"] ''
|
||||||
# Configure
|
# Configure
|
||||||
export CC="gcc -Wl,-dynamic-linker -march=${host.gcc.arch or host.system.cpu.family} ${mbits} -Wl,${foundation.stage1-musl}/lib/libc.so"
|
export CC="gcc -Wl,-dynamic-linker -march=${host.gcc.arch or host.system.cpu.arch} -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
export CXX="g++ -Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
export CXX="g++ -Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
export LIBRARY_PATH="${foundation.stage1-musl}/lib"
|
export LIBRARY_PATH="${foundation.stage1-musl}/lib"
|
||||||
|
|
|
@ -1,112 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
config,
|
|
||||||
options,
|
|
||||||
}: let
|
|
||||||
inherit
|
|
||||||
(config)
|
|
||||||
mirrors
|
|
||||||
builders
|
|
||||||
# These are the upstream foundational packages exported from the Aux Foundation project.
|
|
||||||
|
|
||||||
foundation
|
|
||||||
;
|
|
||||||
in {
|
|
||||||
config.packages.foundation.glibc = {
|
|
||||||
versions = {
|
|
||||||
"latest" = {
|
|
||||||
config,
|
|
||||||
meta,
|
|
||||||
}: {
|
|
||||||
options = {
|
|
||||||
src = lib.options.create {
|
|
||||||
type = lib.types.derivation;
|
|
||||||
description = "Source for the package.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = {
|
|
||||||
meta = {
|
|
||||||
platforms = ["i686-linux"];
|
|
||||||
};
|
|
||||||
|
|
||||||
pname = "gcc";
|
|
||||||
version = "2.38";
|
|
||||||
|
|
||||||
src = builtins.fetchurl {
|
|
||||||
url = "${mirrors.gnu}/libc/glibc-${config.version}.tar.xz";
|
|
||||||
sha256 = "+4KZiZiyspllRnvBtp0VLpwwfSzzAcnq+0VVt3DvP9I=";
|
|
||||||
};
|
|
||||||
|
|
||||||
builder = builders.basic;
|
|
||||||
|
|
||||||
env = {
|
|
||||||
PATH = let
|
|
||||||
gcc =
|
|
||||||
if config.platform.build.triple == config.platform.host.triple
|
|
||||||
# If we're on the same system then we can use the existing GCC instance.
|
|
||||||
then foundation.stage2-gcc
|
|
||||||
# Otherwise we are going to need a cross-compiler.
|
|
||||||
else
|
|
||||||
(meta.extend (args: {
|
|
||||||
config = {
|
|
||||||
platform = {
|
|
||||||
build = config.platform.build.triple;
|
|
||||||
host = config.platform.build.triple;
|
|
||||||
target = lib.modules.override.force config.platform.host.triple;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}))
|
|
||||||
.config
|
|
||||||
.package;
|
|
||||||
in
|
|
||||||
lib.paths.bin [
|
|
||||||
foundation.stage2-gcc
|
|
||||||
foundation.stage2-binutils
|
|
||||||
foundation.stage2-gnumake
|
|
||||||
foundation.stage2-gnused
|
|
||||||
foundation.stage2-gnugrep
|
|
||||||
foundation.stage2-gawk
|
|
||||||
foundation.stage2-diffutils
|
|
||||||
foundation.stage2-findutils
|
|
||||||
foundation.stage2-gnutar
|
|
||||||
foundation.stage2-gzip
|
|
||||||
foundation.stage2-bzip2
|
|
||||||
foundation.stage1-xz
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
phases = {
|
|
||||||
unpack = lib.dag.entry.before ["patch"] ''
|
|
||||||
tar xf ${config.src}
|
|
||||||
cd glibc-${config.version}
|
|
||||||
'';
|
|
||||||
|
|
||||||
configure = lib.dag.entry.between ["build"] ["patch"] ''
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
# libstdc++.so is built against musl and fails to link
|
|
||||||
export CXX=false
|
|
||||||
bash ../configure \
|
|
||||||
--prefix=$out \
|
|
||||||
--build=${config.platform.build.triple} \
|
|
||||||
--host=${config.platform.host.triple} \
|
|
||||||
--with-headers=${foundation.stage1-linux-headers}/include
|
|
||||||
'';
|
|
||||||
|
|
||||||
build = lib.dag.entry.between ["install"] ["configure"] ''
|
|
||||||
# Build
|
|
||||||
make -j $NIX_BUILD_CORES
|
|
||||||
'';
|
|
||||||
|
|
||||||
install = lib.dag.entry.after ["build"] ''
|
|
||||||
# Install
|
|
||||||
make -j $NIX_BUILD_CORES install-strip
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,89 +0,0 @@
|
||||||
{
|
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
config,
|
|
||||||
options,
|
|
||||||
}: let
|
|
||||||
inherit
|
|
||||||
(config)
|
|
||||||
mirrors
|
|
||||||
builders
|
|
||||||
# These are the upstream foundational packages exported from the Aux Foundation project.
|
|
||||||
|
|
||||||
foundation
|
|
||||||
;
|
|
||||||
in {
|
|
||||||
config.packages.foundation.linux-headers = {
|
|
||||||
versions = {
|
|
||||||
"latest" = {
|
|
||||||
config,
|
|
||||||
meta,
|
|
||||||
}: {
|
|
||||||
options = {
|
|
||||||
src = lib.options.create {
|
|
||||||
type = lib.types.derivation;
|
|
||||||
description = "Source for the package.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = {
|
|
||||||
meta = {
|
|
||||||
platforms = ["i686-linux"];
|
|
||||||
};
|
|
||||||
|
|
||||||
pname = "linux-headers";
|
|
||||||
version = "6.5.6";
|
|
||||||
|
|
||||||
builder = builders.basic;
|
|
||||||
|
|
||||||
env = {
|
|
||||||
PATH = lib.paths.bin [
|
|
||||||
foundation.stage2-gcc
|
|
||||||
foundation.stage1-musl
|
|
||||||
foundation.stage2-binutils
|
|
||||||
foundation.stage2-gnumake
|
|
||||||
foundation.stage2-gnupatch
|
|
||||||
foundation.stage2-gnused
|
|
||||||
foundation.stage2-gnugrep
|
|
||||||
foundation.stage2-gawk
|
|
||||||
foundation.stage2-diffutils
|
|
||||||
foundation.stage2-findutils
|
|
||||||
foundation.stage2-gnutar
|
|
||||||
foundation.stage1-xz
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
phases = {
|
|
||||||
unpack = lib.dag.entry.before ["patch"] ''
|
|
||||||
tar xf ${config.src}
|
|
||||||
cd linux-${config.version}
|
|
||||||
'';
|
|
||||||
|
|
||||||
patch =
|
|
||||||
lib.dag.entry.between ["configure"] ["unpack"] ''
|
|
||||||
'';
|
|
||||||
|
|
||||||
configure =
|
|
||||||
lib.dag.entry.between ["build"] ["patch"] ''
|
|
||||||
'';
|
|
||||||
|
|
||||||
build = lib.dag.entry.between ["install"] ["configure"] ''
|
|
||||||
make -j $NIX_BUILD_CORES CC=musl-gcc HOSTCC=musl-gcc ARCH=${config.platform.host.linux.arch} headers
|
|
||||||
'';
|
|
||||||
|
|
||||||
install = lib.dag.entry.after ["build"] ''
|
|
||||||
find usr/include -name '.*' -exec rm {} +
|
|
||||||
mkdir -p $out
|
|
||||||
cp -rv usr/include $out/
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
src = builtins.fetchurl {
|
|
||||||
url = "https://cdn.kernel.org/pub/linux/kernel/v${lib.versions.major config.version}.x/linux-${config.version}.tar.xz";
|
|
||||||
sha256 = "eONtQhRUcFHCTfIUD0zglCjWxRWtmnGziyjoCUqV0vY=";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
Loading…
Reference in a new issue