2024-01-31 05:20:40 +00:00
|
|
|
{
|
|
|
|
description = "Tenstorrent software stack.";
|
|
|
|
|
|
|
|
inputs = {
|
|
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
2024-10-01 18:45:13 +00:00
|
|
|
utils.url = "github:numtide/flake-utils";
|
2024-10-01 20:56:48 +00:00
|
|
|
flake-compat = {
|
|
|
|
url = "github:edolstra/flake-compat";
|
|
|
|
flake = false;
|
|
|
|
};
|
2024-01-31 05:20:40 +00:00
|
|
|
};
|
|
|
|
|
2024-10-01 18:41:35 +00:00
|
|
|
outputs =
|
2024-10-01 18:45:13 +00:00
|
|
|
inputs:
|
2024-10-01 18:41:35 +00:00
|
|
|
let
|
2024-10-01 18:45:13 +00:00
|
|
|
inherit (inputs) self;
|
|
|
|
inherit (inputs.nixpkgs) lib;
|
2024-10-01 18:41:35 +00:00
|
|
|
in
|
2024-10-01 18:45:13 +00:00
|
|
|
inputs.utils.lib.eachDefaultSystem (
|
|
|
|
system:
|
|
|
|
let
|
|
|
|
pkgs = inputs.nixpkgs.legacyPackages.${system};
|
2024-10-01 21:06:25 +00:00
|
|
|
scope = lib.makeScope pkgs.newScope (
|
|
|
|
self:
|
|
|
|
let
|
|
|
|
inherit (self) callPackage;
|
2024-10-03 23:52:00 +00:00
|
|
|
# so `kmd.kmd` gets its own `.override`
|
|
|
|
callPackages = lib.callPackagesWith (pkgs // self);
|
2024-10-14 00:17:41 +00:00
|
|
|
kernel = pkgs.linux_latest;
|
2024-10-01 21:06:25 +00:00
|
|
|
in
|
|
|
|
{
|
2024-10-14 00:17:41 +00:00
|
|
|
kmd = callPackages ./pkgs/kmd { inherit kernel; };
|
2024-10-07 14:51:52 +00:00
|
|
|
sfpi = callPackages ./pkgs/sfpi { };
|
2024-10-01 21:06:25 +00:00
|
|
|
luwen = callPackage ./pkgs/luwen { };
|
2024-10-01 21:13:25 +00:00
|
|
|
tools-common = callPackage ./pkgs/tools-common { };
|
2024-10-14 00:08:50 +00:00
|
|
|
system-tools = callPackage ./pkgs/system-tools { };
|
2024-10-01 21:06:25 +00:00
|
|
|
flash = callPackage ./pkgs/flash {
|
|
|
|
pyluwen = self.luwen.pyluwen_0_1;
|
|
|
|
};
|
|
|
|
smi = callPackage ./pkgs/smi {
|
|
|
|
pyluwen = self.luwen.pyluwen;
|
|
|
|
};
|
|
|
|
umd = callPackage ./pkgs/umd { };
|
2024-10-07 14:51:52 +00:00
|
|
|
metal = callPackage ./pkgs/metal { };
|
2024-10-01 21:06:25 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
);
|
2024-10-01 18:45:13 +00:00
|
|
|
in
|
|
|
|
{
|
|
|
|
packages = {
|
2024-10-01 21:06:25 +00:00
|
|
|
kmd = scope.kmd.kmd;
|
|
|
|
udev-rules = scope.kmd.udev-rules;
|
|
|
|
kmd-test = scope.kmd.test;
|
|
|
|
sfpi = scope.sfpi.sfpi;
|
|
|
|
tt-gcc = scope.sfpi.tt-gcc;
|
|
|
|
smi = scope.smi;
|
|
|
|
luwen = scope.luwen.luwen;
|
|
|
|
pyluwen = scope.luwen.pyluwen;
|
2024-10-01 21:13:25 +00:00
|
|
|
tools-common = scope.tools-common;
|
2024-10-14 00:08:50 +00:00
|
|
|
system-tools = scope.system-tools;
|
2024-10-01 21:06:25 +00:00
|
|
|
flash = scope.flash;
|
|
|
|
umd = scope.umd;
|
2024-10-07 14:51:52 +00:00
|
|
|
metal = scope.metal;
|
2024-10-01 18:45:13 +00:00
|
|
|
default = self.packages.${system}.smi;
|
|
|
|
};
|
2024-01-31 05:20:40 +00:00
|
|
|
|
2024-10-01 19:46:35 +00:00
|
|
|
checks = {
|
|
|
|
simple =
|
|
|
|
pkgs.runCommand "test"
|
|
|
|
{
|
|
|
|
# Goes up to 7
|
|
|
|
NIX_DEBUG = 0;
|
|
|
|
}
|
|
|
|
''
|
|
|
|
mkdir -p $out
|
|
|
|
${self.packages.${system}.tt-gcc}/bin/riscv32-unknown-elf-gcc ${./tests/test.c} -o $out/test
|
|
|
|
${self.packages.${system}.tt-gcc}/bin/riscv32-unknown-elf-gcc -mblackhole ${./tests/test.c} -o $out/test-wormhole
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-10-01 18:45:13 +00:00
|
|
|
formatter = pkgs.nixfmt-rfc-style;
|
|
|
|
}
|
|
|
|
);
|
2024-01-31 05:20:40 +00:00
|
|
|
}
|