-
Notifications
You must be signed in to change notification settings - Fork 59
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: add nix build definitions #745
base: master
Are you sure you want to change the base?
Conversation
6bca13b
to
bdfd488
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nix isn't really my thing, but I have no objection to most of this patch (other than the Libfabric patch I called out below). Other than that, I'm not sure it's a competent review, but I'd be fine approving.
Signed-off-by: Nicholas Sielicki <[email protected]>
bdfd488
to
5e824fc
Compare
@ConnorBaker if you have any free time, any comments or criticisms are much appreciated. |
dirs = { | ||
third-party = ./../../../3rd-party; | ||
docs = ./../../../doc; | ||
headers = ./../../../include; | ||
mfour = ./../../../m4; | ||
nix = ./../../../nix; | ||
tus = ./../../../src; | ||
tests = ./../../../tests; | ||
topologies = ./../../../topology; | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems unused?
cleanRepo = traceVal (gitTracked ../../../.); | ||
cleaned = x: intersection x (gitTracked ../../../.); | ||
sourceFiles = cleaned (sourceFilter ../../../.); | ||
buildFiles = cleaned (buildFileFilter ../../../.); | ||
thirdPartyFiles = cleaned ../../../.; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would recommend adding root = ../../..
to the let in
block here and then using that instead of ../../../.
(which is equivalent) everywhere. At the end of the let in
you can then do inherit root;
in the lib.fileset.toSource
call.
|
||
cudaBuildDepsJoined = symlinkJoin { | ||
name = "cuda-build-deps-joined"; | ||
paths = lib.optionals (cudaSupport) ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
paths = lib.optionals (cudaSupport) ( | |
paths = lib.optionals cudaSupport ( |
Unnecessary parenthesis.
[ | ||
(lib.getDev cudaPackages.cuda_nvcc) | ||
cudaPackages.cuda_cudart.include | ||
] | ||
++ ( | ||
if effectiveStdenv.hostPlatform.isStatic then | ||
[ | ||
(lib.getOutput "static" cudaPackages.cuda_cudart) | ||
] | ||
else | ||
[ | ||
(lib.getLib cudaPackages.cuda_cudart) | ||
] | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[ | |
(lib.getDev cudaPackages.cuda_nvcc) | |
cudaPackages.cuda_cudart.include | |
] | |
++ ( | |
if effectiveStdenv.hostPlatform.isStatic then | |
[ | |
(lib.getOutput "static" cudaPackages.cuda_cudart) | |
] | |
else | |
[ | |
(lib.getLib cudaPackages.cuda_cudart) | |
] | |
) | |
[ | |
(lib.getDev cudaPackages.cuda_nvcc) | |
cudaPackages.cuda_cudart.include | |
( | |
lib.getOutput | |
(if effectiveStdenv.hostPlatform.isStatic then "static" else "lib") | |
cudaPackages.cuda_cudart | |
) | |
] |
(import ./nix/cudaPackagesExtensions/0001-add-latest-nccl.nix { inherit (pkgs) fetchFromGitHub; }) | ||
(import ./nix/cudaPackagesExtensions/0002-use-latest-nccl.nix) | ||
(import ./nix/cudaPackagesExtensions/0003-nccl-tests-use-mpi.nix { inherit config; }) | ||
(import ./nix/cudaPackagesExtensions/0004-add-ncclAws.nix { | ||
inherit lib config; | ||
inherit (pkgs) symlinkJoin patchelf; | ||
}) | ||
(import ./nix/cudaPackagesExtensions/0005-add-nccl-tests-aws.nix { | ||
inherit (pkgs) replaceDependency; | ||
}) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not push the arguments inside the extension? That is, instead of passing pkgs.fetchFromGitHub
to the extension, you should be able to have something like
ffinal:
let
inherit (ffinal.pkgs) fetchFromGitHub;
in
pprev:
...
pkgs
is a member of every cudaPackages
package set; this would also prevent your pkgs
from contaminating the overlays generated by overlayAttrs
(because you're passing things from your pkgs
to them directly instead of allowing the extension to retrieve them from whatever fixed point it is being evaluated within).
I'd recommend changing usages in the extensions of config.packages.blarg
with ffinal.pkgs.blarg
for the same reason; if you're using overlays properly, everything that you'd normally need to pass through directly will be available in the resulting Nixpkgs instantiation which is used to evaluate these extensions.
aws-ofi-nccl = ( | ||
pkgs.callPackage ./nix/pkgs/aws-ofi-nccl { | ||
inherit inputs self; | ||
} | ||
); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
aws-ofi-nccl = ( | |
pkgs.callPackage ./nix/pkgs/aws-ofi-nccl { | |
inherit inputs self; | |
} | |
); | |
aws-ofi-nccl = pkgs.callPackage ./nix/pkgs/aws-ofi-nccl { | |
inherit inputs self; | |
}; |
rev = "v2.23.4-1"; | ||
hash = "sha256-DlMxlLO2F079fBkhORNPVN/ASYiVIRfLJw7bDoiClHw="; | ||
}; | ||
name = "cuda${ffinal.cudaMajorMinorPatchVersion}-nccl-2.23.4-1"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it necessary to change the name? Using backendStdenv
, name
should be the result of ${backendStdenv.cudaNamePrefix}-${pname}-${version}
(https://github.com/ConnorBaker/cuda-packages/blob/bb6bf09b919e8e7dda006bcee9a48675d034850f/cuda-packages/common/backendStdenv.nix#L55) by default, so updating the version should be enough.
@@ -0,0 +1,13 @@ | |||
{ fetchFromGitHub }: | |||
ffinal: pprev: { | |||
nccl_latest = pprev.nccl.overrideAttrs (prevAttrs: { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It doesn't look like prevAttrs
is being used -- remember that overrideAttrs
takes three different types of argument:
- attribute set (unconditional overrides)
- function to attribute set (uses previous values)
- function to function to attribute set (uses previous and final values)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nix code looks good to me, left a few comments/nits -- do note that I'm not able to test it at the moment.
Thank you for taking the time, I really appreciate it. Taking every change. |
Should this definition not live upstream with Nix instead of in our package? |
Issue #, if available:
Description of changes:
This adds a nix flake for aws-ofi-nccl.
Usage:
.envrc
with contents:This will create a .clangd file which can be used for IDE-like features atop clangd. Individual editor configuration varies. Example emacs configuration using doom emacs:
To build aws-ofi-nccl, libfabric, openmpi, etc.:
nix build .#default
.To build wrappers for nccl-tests that run atop ubuntu, run:
nix build .#ubuntu-test-runners
../result/bin/
will contain shell scripts that LD_PRELOAD nvidia libraries from ubuntu expected locations, then forwards args to the nccl-test in question.By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.