Compare commits

...

5 commits

Author SHA1 Message Date
d9c4552d8d running 2025-08-27 01:19:50 +03:00
eacee11566 its working now 2025-08-27 01:18:05 +03:00
347d5c6554 update 2025-08-27 00:34:21 +03:00
4bab842687 update flake.lock 2025-08-26 23:38:25 +03:00
2fad5418cc update flake.lock 2025-05-04 15:42:48 +03:00
4 changed files with 55 additions and 28 deletions

8
README.md Normal file
View file

@ -0,0 +1,8 @@
Example cuda code compilation in nix.
```bash
$ nix run github:osbm/cuda-kernel-nix
Free mem: 22112 MB Total mem: 24078 MB
Free mem: 21 GB Total mem: 23 GB
```

6
flake.lock generated
View file

@ -2,11 +2,11 @@
"nodes": { "nodes": {
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1734988233, "lastModified": 1756159630,
"narHash": "sha256-Ucfnxq1rF/GjNP3kTL+uTfgdoE9a3fxDftSfeLIS8mA=", "narHash": "sha256-ohMvsjtSVdT/bruXf5ClBh8ZYXRmD4krmjKrXhEvwMg=",
"owner": "nixos", "owner": "nixos",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "de1864217bfa9b5845f465e771e0ecb48b30e02d", "rev": "84c256e42600cb0fdf25763b48d28df2f25a0c8b",
"type": "github" "type": "github"
}, },
"original": { "original": {

View file

@ -29,21 +29,40 @@
packages."${system}" = { packages."${system}" = {
# just one main.cu file for now # just one main.cu file for now
# compile it and place it to $out/bin/cuda-kernel # compile it and place it to $out/bin/cuda-kernel
cuda-kernel = pkgs.stdenv.mkDerivation { cuda-kernel = let
name = "cuda-kernel"; # Use CUDA 12.0 which should be compatible with driver 580.76.05
src = ./.; cudaPackages = pkgs.cudaPackages;
buildInputs = with pkgs; [ cudatoolkit = cudaPackages.cudatoolkit;
cudatoolkit in
cudaPackages.cuda_cudart cudaPackages.backendStdenv.mkDerivation {
linuxPackages.nvidia_x11 name = "cuda";
]; src = ./main.cu;
LD_LIBRARY_PATH = "${pkgs.linuxPackages.nvidia_x11}/lib"; unpackPhase = "true";
buildPhase = '' buildInputs = [
nvcc -o main main.cu cudatoolkit
mkdir -p $out/bin cudaPackages.cuda_cudart
mv main $out/bin/cuda-kernel ];
''; nativeBuildInputs = [
}; cudatoolkit
pkgs.autoAddDriverRunpath
];
LD_LIBRARY_PATH = "${cudatoolkit}/lib:${cudaPackages.cuda_cudart}/lib";
buildPhase = ''
echo "GCC Version:"
gcc --version
echo "NVCC Version:"
nvcc --version
echo "Building CUDA program..."
nvcc -arch=sm_89 -o main $src
mkdir -p $out/bin
cp main $out/bin/
'';
meta = {
mainProgram = "main";
platforms = ["x86_64-linux"];
};
};
default = self.packages."${system}".cuda-kernel; default = self.packages."${system}".cuda-kernel;
}; };
}; };

20
main.cu
View file

@ -1,13 +1,13 @@
#include <unistd.h>
#include <iostream> #include <iostream>
#include "cuda.h"
int main() {
int main(){ size_t free_t, total_t;
cudaError_t err;
size_t mf, ma; err = cudaMemGetInfo(&free_t, &total_t);
cudaMemGetInfo(&mf, &ma); if (err != cudaSuccess) { printf("cudaMalloc d_steps_arr error: %s\n", cudaGetErrorString(err)); return 1; }
std::cout << "Free memory (mb): " << mf/1024/1024 << std::endl; std::cout << "Free mem: " << free_t / (1024 * 1024) << " MB Total mem: " << total_t / (1024 * 1024) << " MB" << std::endl;
std::cout << "Total memory (mb): " << ma/1024/1024 << std::endl; std::cout << "Free mem: " << free_t / (1024 * 1024 * 1024) << " GB Total mem: " << total_t / (1024 * 1024 * 1024) << " GB" << std::endl;
return 0;
return 0;
} }