-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathflake.nix
More file actions
172 lines (151 loc) · 4.11 KB
/
flake.nix
File metadata and controls
172 lines (151 loc) · 4.11 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
{
description = "YSYX (one student one chip) develop environments";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
flake-utils.url = "github:numtide/flake-utils";
rust-overlay = {
url = "github:oxalica/rust-overlay";
inputs.nixpkgs.follows = "nixpkgs";
};
espresso.url = "github:KINGFIOX/espresso";
fixdep.url = "github:KINGFIOX/fixdep";
nvboard.url = "github:KINGFIOX/nvboard";
spike.url = "github:KINGFIOX/riscv-isa-sim";
};
outputs =
{
self,
nixpkgs,
flake-utils,
rust-overlay,
espresso,
fixdep,
nvboard,
spike,
}:
flake-utils.lib.eachDefaultSystem (
system:
let
pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true;
overlays = [
(import ./nix/overlay.nix)
rust-overlay.overlays.default
];
};
stubsIlp32Fix = pkgs.writeTextDir "include/gnu/stubs-ilp32.h"
"/* Empty stub for rv32 ilp32 ABI compatibility */";
buildTools = with pkgs; [
gnumake
cmake
ninja
pkg-config
autoconf
automake
];
cppToolchain = with pkgs; [
clang
clang-tools
gdb
lldb
bear
scons
];
nemuDeps = with pkgs; [
flex
bison
readline
ncurses
llvmPackages.libllvm
libelf
capstone
kconfig-frontends
];
chiselDeps = with pkgs; [
jdk21
circt
metals
scalafix
mill_0_12_4
];
verilogTools = with pkgs; [
verilator
iverilog
gtkwave
];
sdlDeps = with pkgs; [
SDL2
SDL2_image
SDL2_ttf
ffmpeg
];
riscvToolchain = [
pkgs.pkgsCross.riscv32.buildPackages.gcc
stubsIlp32Fix
];
rustToolchain = [
(pkgs.rust-bin.stable.latest.default.override {
extensions = [ "rust-src" "rust-analyzer" ];
})
];
pythonTools = with pkgs; [
python3
ruff
];
miscTools = with pkgs; [
git
ccache
];
externalPkgs = [
espresso.packages.${system}.default
fixdep.packages.${system}.default
];
in
{
devShells.default = pkgs.mkShell {
name = "ysyx-dev";
packages = pkgs.lib.concatLists [
buildTools
cppToolchain
nemuDeps
chiselDeps
verilogTools
sdlDeps
riscvToolchain
rustToolchain
pythonTools
miscTools
externalPkgs
];
# mkShell would export the same name of env var to shell
STUBS_ILP32_FIX = "${stubsIlp32Fix}/include";
LIBCLANG_PATH = "${pkgs.llvmPackages.libclang.lib}/lib";
VERILATOR_ROOT = "${pkgs.verilator}/share/verilator";
NVBOARD_HOME = nvboard.packages.${system}.default;
SPIKE_HOME = spike.packages.${system}.default;
JAVA_HOME = pkgs.jdk21;
CHISEL_FIRTOOL_PATH = "${pkgs.circt}/bin";
SDL2_CONFIG = "${pkgs.SDL2}/bin/sdl2-config";
CROSS_COMPILE = "riscv32-unknown-linux-gnu-";
ARCH = "riscv32-npc";
shellHook = ''
export CC=clang
export CXX=clang++
export YSYX_HOME="$(pwd)"
export NEMU_HOME="$YSYX_HOME/nemu"
export AM_HOME="$YSYX_HOME/abstract-machine"
export NPC_HOME="$YSYX_HOME/npc"
export CARGO_HOME="$NPC_HOME/.cargo"
export PATH="$CARGO_HOME/bin:$PATH"
echo "🚀 YSYX develop environment loaded!"
echo " NEMU_HOME: $NEMU_HOME"
echo " AM_HOME: $AM_HOME"
echo " NPC_HOME: $NPC_HOME"
echo " NVBOARD_HOME: $NVBOARD_HOME"
echo " SPIKE_HOME: $SPIKE_HOME"
'';
};
}
);
}