-
Notifications
You must be signed in to change notification settings - Fork 182
Expand file tree
/
Copy pathshell.nix
More file actions
192 lines (170 loc) · 7.03 KB
/
shell.nix
File metadata and controls
192 lines (170 loc) · 7.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
let
# Pinned nixpkgs in 25.11 branch
nixpkgs = fetchTarball {
url = "https://github.com/NixOS/nixpkgs/archive/50ab793786d9de88ee30ec4e4c24fb4236fc2674.tar.gz";
sha256 = "1s2gr5rcyqvpr58vxdcb095mdhblij9bfzaximrva2243aal3dgx";
};
# Latest rust overlay from master - we should pin this to a specific commit and hash when we fork release branches
rust_overlay = import (builtins.fetchTarball {
url = "https://github.com/oxalica/rust-overlay/archive/master.tar.gz";
});
pkgs = import nixpkgs { overlays = [ rust_overlay ]; };
# Detect host architecture
hostArch = if pkgs.system == "aarch64-linux" then "aarch64" else "x86_64";
# Host tools
mdbook = pkgs.callPackage ./nix/mdbook.nix { };
mdbook_admonish = pkgs.callPackage ./nix/mdbook_admonish.nix { };
mdbook_mermaid = pkgs.callPackage ./nix/mdbook_mermaid.nix { };
protoc = pkgs.callPackage ./nix/protoc.nix { };
# Helper to get openvmm_deps and uefi_mu_msvm by architecture
mkBaseDepsForArch = arch: {
openvmm_deps = pkgs.callPackage ./nix/openvmm_deps.nix { targetArch = arch; };
uefi_mu_msvm = pkgs.callPackage ./nix/uefi_mu_msvm.nix { targetArch = arch; };
};
# Helper to get kernel package for specific arch and variant
mkKernel = { arch, is_dev ? false, is_cvm ? false }: pkgs.callPackage ./nix/openhcl_kernel.nix {
targetArch = arch;
inherit is_dev is_cvm;
};
# Base deps for both architectures
x64BaseDeps = mkBaseDepsForArch "x86_64";
aarch64BaseDeps = mkBaseDepsForArch "aarch64";
# Kernel variants for x64
x64Kernel = mkKernel { arch = "x86_64"; };
x64KernelCvm = mkKernel { arch = "x86_64"; is_cvm = true; };
x64KernelDev = mkKernel { arch = "x86_64"; is_dev = true; };
x64KernelCvmDev = mkKernel { arch = "x86_64"; is_dev = true; is_cvm = true; };
# Kernel variants for aarch64
aarch64Kernel = mkKernel { arch = "aarch64"; };
aarch64KernelDev = mkKernel { arch = "aarch64"; is_dev = true; };
# Cross-compilers based on host architecture
# On x64 host: provide aarch64 cross-compiler
# On aarch64 host: provide x64 cross-compiler
aarch64CrossGcc = pkgs.pkgsCross.aarch64-multiplatform.buildPackages.gcc;
x64CrossGcc = pkgs.pkgsCross.gnu64.buildPackages.gcc;
# Native gcc (for native architecture builds)
nativeGcc = pkgs.gcc;
crossCompilers =
if hostArch == "x86_64" then [ aarch64CrossGcc ]
else [ x64CrossGcc ];
# Rust configuration — update this version manually when upgrading rustc
rustVersion = "1.94.0";
rust = pkgs.rust-bin.stable.${rustVersion}.default.override {
extensions = [
"rust-src" # for rust-analyzer
"rust-analyzer"
];
# Include both musl targets for cross-compilation
targets = [
"x86_64-unknown-linux-musl"
"x86_64-unknown-none"
"aarch64-unknown-linux-musl"
"aarch64-unknown-none"
];
};
# Build CARGO_BUILD_ARGS for specific architecture and kernel
# x86_64 uses vmlinux, aarch64 uses Image
mkCargoBuildArgs = { arch, baseDeps, kernel }:
let kernelFile = if arch == "x86_64" then "vmlinux" else "Image";
in "--use-local-deps --custom-openvmm-deps ${baseDeps.openvmm_deps} --custom-uefi=${baseDeps.uefi_mu_msvm}/MSVM.fd --custom-kernel ${kernel}/${kernelFile} --custom-kernel-modules ${kernel}/modules --custom-protoc ${protoc}";
in pkgs.mkShell {
nativeBuildInputs = [
rust
mdbook
mdbook_admonish
mdbook_mermaid
protoc
nativeGcc
] ++ crossCompilers ++ (with pkgs; [
libarchive
git
perl
python3
pkg-config
binutils
]);
buildInputs = [
pkgs.openssl.dev
];
# Sysroot paths for linker wrappers (used by build_support/underhill_cross/*-underhill-musl-gcc)
X86_64_SYSROOT = "${x64BaseDeps.openvmm_deps}";
AARCH64_SYSROOT = "${aarch64BaseDeps.openvmm_deps}";
# x64 recipe variants
CARGO_BUILD_ARGS_X64 = mkCargoBuildArgs {
arch = "x86_64";
baseDeps = x64BaseDeps;
kernel = x64Kernel;
};
CARGO_BUILD_ARGS_X64_CVM = mkCargoBuildArgs {
arch = "x86_64";
baseDeps = x64BaseDeps;
kernel = x64KernelCvm;
};
CARGO_BUILD_ARGS_X64_DEVKERN = mkCargoBuildArgs {
arch = "x86_64";
baseDeps = x64BaseDeps;
kernel = x64KernelDev;
};
CARGO_BUILD_ARGS_X64_CVM_DEVKERN = mkCargoBuildArgs {
arch = "x86_64";
baseDeps = x64BaseDeps;
kernel = x64KernelCvmDev;
};
# aarch64 recipe variants
CARGO_BUILD_ARGS_AARCH64 = mkCargoBuildArgs {
arch = "aarch64";
baseDeps = aarch64BaseDeps;
kernel = aarch64Kernel;
};
CARGO_BUILD_ARGS_AARCH64_DEVKERN = mkCargoBuildArgs {
arch = "aarch64";
baseDeps = aarch64BaseDeps;
kernel = aarch64KernelDev;
};
# Expose deps for reference in update-rootfs.py
OPENVMM_DEPS_X64 = x64BaseDeps.openvmm_deps;
OPENVMM_DEPS_AARCH64 = aarch64BaseDeps.openvmm_deps;
# Export dep paths so that flowey can find them at runtime
NIX_PROTOC = "${protoc}";
NIX_UEFI_X64 = "${x64BaseDeps.uefi_mu_msvm}/MSVM.fd";
NIX_UEFI_AARCH64 = "${aarch64BaseDeps.uefi_mu_msvm}/MSVM.fd";
NIX_KERNEL_X64 = "${x64Kernel}";
NIX_KERNEL_X64_CVM = "${x64KernelCvm}";
NIX_KERNEL_X64_DEV = "${x64KernelDev}";
NIX_KERNEL_X64_CVM_DEV = "${x64KernelCvmDev}";
NIX_KERNEL_AARCH64 = "${aarch64Kernel}";
NIX_KERNEL_AARCH64_DEV = "${aarch64KernelDev}";
RUST_BACKTRACE = 1;
SOURCE_DATE_EPOCH = 12345;
# Need the unstable trim-paths feature on the stable toolchain to strip paths from the output binary
RUSTC_BOOTSTRAP = 1;
# Enable path trimming
CARGO_UNSTABLE_TRIM_PATHS = "true";
CARGO_PROFILE_DEV_TRIM_PATHS = "object";
CARGO_PROFILE_RELEASE_TRIM_PATHS = "object";
CARGO_PROFILE_UNDERHILL_SHIP_TRIM_PATHS = "object";
CARGO_PROFILE_BOOT_DEV_TRIM_PATHS = "object";
CARGO_PROFILE_BOOT_RELEASE_TRIM_PATHS = "object";
shellHook = ''
# Create a temp bin directory with symlinks using the expected gcc names.
# The linker wrappers (build_support/underhill_cross/*-underhill-musl-gcc) expect
# aarch64-linux-gnu-gcc and x86_64-linux-gnu-gcc, but nixpkgs provides
# aarch64-unknown-linux-gnu-gcc and x86_64-unknown-linux-gnu-gcc (for cross)
# and just gcc (for native). objcopy is needed by run_split_debug_info.rs.
export NIX_CC_WRAPPER_DIR=$(mktemp -d)
${if hostArch == "x86_64" then ''
# On x64 host: native x64 + cross aarch64
ln -sf ${nativeGcc}/bin/gcc $NIX_CC_WRAPPER_DIR/x86_64-linux-gnu-gcc
ln -sf ${pkgs.binutils}/bin/objcopy $NIX_CC_WRAPPER_DIR/x86_64-linux-gnu-objcopy
ln -sf ${aarch64CrossGcc}/bin/aarch64-unknown-linux-gnu-gcc $NIX_CC_WRAPPER_DIR/aarch64-linux-gnu-gcc
ln -sf ${aarch64CrossGcc}/bin/aarch64-unknown-linux-gnu-objcopy $NIX_CC_WRAPPER_DIR/aarch64-linux-gnu-objcopy
'' else ''
# On aarch64 host: native aarch64 + cross x64
ln -sf ${nativeGcc}/bin/gcc $NIX_CC_WRAPPER_DIR/aarch64-linux-gnu-gcc
ln -sf ${pkgs.binutils}/bin/objcopy $NIX_CC_WRAPPER_DIR/aarch64-linux-gnu-objcopy
ln -sf ${x64CrossGcc}/bin/x86_64-unknown-linux-gnu-gcc $NIX_CC_WRAPPER_DIR/x86_64-linux-gnu-gcc
ln -sf ${x64CrossGcc}/bin/x86_64-unknown-linux-gnu-objcopy $NIX_CC_WRAPPER_DIR/x86_64-linux-gnu-objcopy
''}
export PATH="$NIX_CC_WRAPPER_DIR:$PATH"
'';
}