xinyangli
f5335c21f1
All checks were successful
Build npc tests / npc-build (flow-simlib) (push) Successful in 2m17s
Build abstract machine with nix / build-packages (abstract-machine) (pull_request) Successful in 9s
Build abstract machine with nix / build-packages (nemu) (pull_request) Successful in 9s
Build abstract machine with nix / build-packages (nemu-lib) (pull_request) Successful in 9s
Build abstract machine with nix / build-packages (rv32Cross.abstract-machine) (pull_request) Successful in 8s
Build npc tests / npc-build (flow) (push) Successful in 3m2s
185 lines
5.3 KiB
Nix
185 lines
5.3 KiB
Nix
{
|
|
inputs = {
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
nixpkgs-circt162.url = "github:NixOS/nixpkgs/7995cae3ad60e3d6931283d650d7f43d31aaa5c7";
|
|
flake-utils.url = "github:numtide/flake-utils";
|
|
pre-commit-hooks = {
|
|
url = "github:cachix/pre-commit-hooks.nix";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
nur-xin = {
|
|
url = "git+https://git.xinyang.life/xin/nur.git";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
diffu.url = "git+https://git.xinyang.life/xin/diffu.git";
|
|
am-kernels.url = "git+https://git.xinyang.life/xin/am-kernels.git?ref=dev";
|
|
spike-diff.url = "git+https://git.xinyang.life/xin/spike-diff.git";
|
|
};
|
|
|
|
outputs =
|
|
{
|
|
self,
|
|
flake-utils,
|
|
nixpkgs,
|
|
nixpkgs-circt162,
|
|
pre-commit-hooks,
|
|
nur-xin,
|
|
diffu,
|
|
am-kernels,
|
|
spike-diff,
|
|
}@inputs:
|
|
flake-utils.lib.eachDefaultSystem (
|
|
system:
|
|
let
|
|
pkgs = import nixpkgs {
|
|
inherit system;
|
|
config.allowUnfree = true;
|
|
overlays = [
|
|
(self: super: {
|
|
nvboard = nur-xin.legacyPackages.${system}.nvboard;
|
|
mini-gdbstub = nur-xin.legacyPackages.${system}.mini-gdbstub;
|
|
})
|
|
];
|
|
};
|
|
|
|
rv32CrossConfig = import nixpkgs {
|
|
localSystem = system;
|
|
crossSystem = {
|
|
config = "riscv32-none-elf";
|
|
gcc = {
|
|
abi = "ilp32";
|
|
arch = "rv32if";
|
|
};
|
|
};
|
|
};
|
|
|
|
am-kernels-nemu = am-kernels.packages.${system}.rv32Cross.am-kernels-nemu;
|
|
in
|
|
{
|
|
checks = {
|
|
pre-commit-check = pre-commit-hooks.lib.${system}.run {
|
|
src = ./.;
|
|
hooks = {
|
|
trim-trailing-whitespace.enable = true;
|
|
end-of-file-fixer.enable = true;
|
|
cmake-format.enable = true;
|
|
clang-format = {
|
|
enable = true;
|
|
types_or = pkgs.lib.mkForce [
|
|
"c"
|
|
"c++"
|
|
];
|
|
};
|
|
scalafmt = {
|
|
enable = true;
|
|
package = pkgs.scalafmt;
|
|
name = "Scalafmt";
|
|
types = [ "scala" ];
|
|
entry = "${pkgs.scalafmt}/bin/scalafmt --non-interactive";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
packages = {
|
|
abstract-machine = pkgs.callPackage ./abstract-machine { isa = "native"; };
|
|
nemu = pkgs.callPackage ./nemu { am-kernels = am-kernels-nemu; };
|
|
nemu-lib = pkgs.callPackage ./nemu { defconfig = "libdefconfig"; };
|
|
|
|
rv32Cross = {
|
|
abstract-machine = rv32CrossConfig.callPackage ./abstract-machine {
|
|
isa = "riscv";
|
|
platform = [
|
|
"nemu"
|
|
"npc"
|
|
];
|
|
};
|
|
};
|
|
};
|
|
|
|
devShells.nemu = pkgs.mkShell {
|
|
packages = with pkgs; [
|
|
clang-tools
|
|
gef
|
|
SDL2
|
|
gnumake
|
|
pkg-config
|
|
flex
|
|
bison
|
|
dtc
|
|
|
|
readline
|
|
libllvm
|
|
mini-gdbstub
|
|
];
|
|
inputsFrom = [
|
|
self.packages.${system}.nemu
|
|
];
|
|
NEMU_HOME = "/home/xin/repo/ysyx-workbench/nemu";
|
|
NEMU_IMAGES_PATH = am-kernels.packages.${system}.rv32Cross.am-kernels-nemu + "/share/am-kernels";
|
|
};
|
|
|
|
devShells.npc = pkgs.mkShell.override { stdenv = pkgs.ccacheStdenv; } {
|
|
inherit (self.checks.${system}.pre-commit-check) shellHook;
|
|
CHISEL_FIRTOOL_PATH = "${nixpkgs-circt162.legacyPackages.${system}.circt}/bin";
|
|
# NPC_IMAGES_PATH = "${self.packages.${system}.rv32Cross.am-kernels-npc}/share/am-kernels";
|
|
packages = with pkgs; [
|
|
clang-tools
|
|
cmake
|
|
coursier
|
|
espresso
|
|
bloop
|
|
|
|
gdb
|
|
jre
|
|
|
|
gtkwave
|
|
];
|
|
|
|
nativeBuildInputs = with pkgs; [
|
|
cmake
|
|
ninja
|
|
sbt
|
|
nvboard
|
|
nixpkgs-circt162.legacyPackages.${system}.circt
|
|
yosys
|
|
cli11
|
|
flex
|
|
bison
|
|
verilator
|
|
];
|
|
|
|
buildInputs =
|
|
with pkgs;
|
|
[
|
|
spdlog
|
|
nvboard
|
|
openssl
|
|
libllvm
|
|
libxml2
|
|
readline
|
|
mini-gdbstub
|
|
]
|
|
++ self.checks.${system}.pre-commit-check.enabledPackages;
|
|
};
|
|
|
|
devShells.default = pkgs.mkShell {
|
|
inherit (self.checks.${system}.pre-commit-check) shellHook;
|
|
buildInputs = self.checks.${system}.pre-commit-check.enabledPackages;
|
|
|
|
packages = [
|
|
diffu.packages.${system}.default
|
|
am-kernels.packages.${system}.rv32Cross.am-kernels-npc
|
|
self.packages.${system}.nemu-lib
|
|
spike-diff.packages.${system}.default
|
|
pkgs.gef
|
|
pkgs.gtkwave
|
|
];
|
|
|
|
DIFFU_IMAGES_PATH = "${am-kernels.packages.${system}.rv32Cross.am-kernels-npc}";
|
|
NEMU_SO = "${self.packages.${system}.nemu-lib}/lib/riscv32-nemu-interpreter-so";
|
|
NPC_SO = "/home/xin/repo/ysyx-workbench/npc/build/csrc/Flow/libFlow.so";
|
|
};
|
|
}
|
|
);
|
|
}
|