forked from rarias/bscpkgs
		
	Compare commits
	
		
			29 Commits
		
	
	
		
			cd61d6691f
			...
			f809c65bd0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| f809c65bd0 | |||
| caac03cec5 | |||
| 9519a6bacc | |||
| 6b430a5a3f | |||
| 9143b335c3 | |||
| 801a9f20d9 | |||
| 95ad400991 | |||
| b90f4ccbe8 | |||
| f9aa83dc47 | |||
| 2b646706ca | |||
| b8c97e7abb | |||
| 762a455589 | |||
| 5869ad06c2 | |||
| 7d1a312e7d | |||
| 974bb56dc3 | |||
| 88d4d8e317 | |||
| 885e04e446 | |||
| 26f52aa27d | |||
| 52fe43bfe1 | |||
| f0637b4569 | |||
| 6ddfea0a3a | |||
| e7adef1ffa | |||
| e82d3c3b9f | |||
| 4442b6a706 | |||
| 2d0b014dc7 | |||
| 867ba3ec5a | |||
| 2cacc2b265 | |||
| e4abd8d8f6 | |||
| a87b99d0a4 | 
							
								
								
									
										8
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										8
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @ -2,10 +2,10 @@ | |||||||
|   "nodes": { |   "nodes": { | ||||||
|     "nixpkgs": { |     "nixpkgs": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1736867362, |         "lastModified": 1752436162, | ||||||
|         "narHash": "sha256-i/UJ5I7HoqmFMwZEH6vAvBxOrjjOJNU739lnZnhUln8=", |         "narHash": "sha256-Kt1UIPi7kZqkSc5HVj6UY5YLHHEzPBkgpNUByuyxtlw=", | ||||||
|         "path": "/nix/store/2csx2kkb2hxyxhhmg2xs9jfyypikwwk6-source", |         "path": "/nix/store/zk8v61cpk1wprp9ld5ayc1g5fq4pdkwv-source", | ||||||
|         "rev": "9c6b49aeac36e2ed73a8c472f1546f6d9cf1addc", |         "rev": "dfcd5b901dbab46c9c6e80b265648481aafb01f8", | ||||||
|         "type": "path" |         "type": "path" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								overlay.nix
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								overlay.nix
									
									
									
									
									
								
							| @ -18,8 +18,13 @@ let | |||||||
|     clangOmpss2NodesOmpv = callPackage ./pkgs/llvm-ompss2/default.nix { ompss2rt = final.nodes; openmp = final.openmpv; }; |     clangOmpss2NodesOmpv = callPackage ./pkgs/llvm-ompss2/default.nix { ompss2rt = final.nodes; openmp = final.openmpv; }; | ||||||
|     clangOmpss2Unwrapped = callPackage ./pkgs/llvm-ompss2/clang.nix { }; |     clangOmpss2Unwrapped = callPackage ./pkgs/llvm-ompss2/clang.nix { }; | ||||||
|     #extrae = callPackage ./pkgs/extrae/default.nix { }; # Broken and outdated |     #extrae = callPackage ./pkgs/extrae/default.nix { }; # Broken and outdated | ||||||
|     gpi-2 = callPackage ./pkgs/gpi-2/default.nix { }; |     #gpi-2 = callPackage ./pkgs/gpi-2/default.nix { }; # Broken: https://jungle.bsc.es/git/rarias/bscpkgs/issues/7 | ||||||
|  |     intel-apt = callPackage ./pkgs/intel-oneapi/packages.nix { }; | ||||||
|     intelPackages_2023 = callPackage ./pkgs/intel-oneapi/2023.nix { }; |     intelPackages_2023 = callPackage ./pkgs/intel-oneapi/2023.nix { }; | ||||||
|  |     intelPackages_2024 = final.intel-apt.hpckit_2024; | ||||||
|  |     intelPackages_2025 = final.intel-apt.hpckit_2025; | ||||||
|  |     intelPackages = final.intelPackages_2025; | ||||||
|  |     oneMath = callPackage ./pkgs/onemath/default.nix { }; | ||||||
|     jemallocNanos6 = callPackage ./pkgs/nanos6/jemalloc.nix { }; |     jemallocNanos6 = callPackage ./pkgs/nanos6/jemalloc.nix { }; | ||||||
|     lmbench = callPackage ./pkgs/lmbench/default.nix { }; |     lmbench = callPackage ./pkgs/lmbench/default.nix { }; | ||||||
|     mcxx = callPackage ./pkgs/mcxx/default.nix { }; |     mcxx = callPackage ./pkgs/mcxx/default.nix { }; | ||||||
| @ -44,8 +49,10 @@ let | |||||||
|     stdenvClangOmpss2Nanos6 = final.stdenv.override { cc = final.clangOmpss2Nanos6; allowedRequisites = null; }; |     stdenvClangOmpss2Nanos6 = final.stdenv.override { cc = final.clangOmpss2Nanos6; allowedRequisites = null; }; | ||||||
|     stdenvClangOmpss2Nodes = final.stdenv.override { cc = final.clangOmpss2Nodes; allowedRequisites = null; }; |     stdenvClangOmpss2Nodes = final.stdenv.override { cc = final.clangOmpss2Nodes; allowedRequisites = null; }; | ||||||
|     stdenvClangOmpss2NodesOmpv = final.stdenv.override { cc = final.clangOmpss2NodesOmpv; allowedRequisites = null; }; |     stdenvClangOmpss2NodesOmpv = final.stdenv.override { cc = final.clangOmpss2NodesOmpv; allowedRequisites = null; }; | ||||||
|     tagaspi = callPackage ./pkgs/tagaspi/default.nix { }; |     #tagaspi = callPackage ./pkgs/tagaspi/default.nix { }; # Broken due gpi-2 | ||||||
|     tampi = callPackage ./pkgs/tampi/default.nix { }; |     tampi = callPackage ./pkgs/tampi/default.nix { }; | ||||||
|  |     tasycl = callPackage ./pkgs/tasycl/default.nix { }; | ||||||
|  |     tasycl-acpp = callPackage ./pkgs/tasycl/default.nix { useIntel = false; }; | ||||||
|     wxparaver = callPackage ./pkgs/paraver/default.nix { }; |     wxparaver = callPackage ./pkgs/paraver/default.nix { }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
| @ -60,6 +67,8 @@ in bscPkgs // { | |||||||
|       #sigsegv = callPackage ./test/reproducers/sigsegv.nix { }; |       #sigsegv = callPackage ./test/reproducers/sigsegv.nix { }; | ||||||
|       hello-c = callPackage ./test/compilers/hello-c.nix { }; |       hello-c = callPackage ./test/compilers/hello-c.nix { }; | ||||||
|       hello-cpp = callPackage ./test/compilers/hello-cpp.nix { }; |       hello-cpp = callPackage ./test/compilers/hello-cpp.nix { }; | ||||||
|  |       hello-sycl = callPackage ./test/compilers/hello-sycl.nix { }; | ||||||
|  |       hello-syclompss = callPackage ./test/compilers/icpx-ompss2.nix { }; | ||||||
|       lto = callPackage ./test/compilers/lto.nix { }; |       lto = callPackage ./test/compilers/lto.nix { }; | ||||||
|       asan = callPackage ./test/compilers/asan.nix { }; |       asan = callPackage ./test/compilers/asan.nix { }; | ||||||
|       intel2023-icx-c   = hello-c.override   { stdenv = final.intelPackages_2023.stdenv; }; |       intel2023-icx-c   = hello-c.override   { stdenv = final.intelPackages_2023.stdenv; }; | ||||||
| @ -69,6 +78,15 @@ in bscPkgs // { | |||||||
|       intel2023-ifort   = callPackage ./test/compilers/hello-f.nix { |       intel2023-ifort   = callPackage ./test/compilers/hello-f.nix { | ||||||
|         stdenv = final.intelPackages_2023.stdenv-ifort; |         stdenv = final.intelPackages_2023.stdenv-ifort; | ||||||
|       }; |       }; | ||||||
|  | 
 | ||||||
|  |       intel2024-icx-c   = hello-c.override   { stdenv = final.intelPackages_2024.stdenv; }; | ||||||
|  |       intel2025-icx-c   = hello-c.override   { stdenv = final.intelPackages_2025.stdenv; }; | ||||||
|  |       intel2024-icx-cpp = hello-cpp.override { stdenv = final.intelPackages_2024.stdenv; }; | ||||||
|  |       intel2025-icx-cpp = hello-cpp.override { stdenv = final.intelPackages_2025.stdenv; }; | ||||||
|  |       intel2023-sycl    = hello-sycl.override { intelPackages = final.intelPackages_2023; }; | ||||||
|  |       intel2024-sycl    = hello-sycl.override { intelPackages = final.intelPackages_2024; }; | ||||||
|  |       intel2025-sycl    = hello-sycl.override { intelPackages = final.intelPackages_2025; }; | ||||||
|  | 
 | ||||||
|       clangOmpss2-lto   = lto.override       { stdenv = final.stdenvClangOmpss2Nanos6; }; |       clangOmpss2-lto   = lto.override       { stdenv = final.stdenvClangOmpss2Nanos6; }; | ||||||
|       clangOmpss2-asan  = asan.override      { stdenv = final.stdenvClangOmpss2Nanos6; }; |       clangOmpss2-asan  = asan.override      { stdenv = final.stdenvClangOmpss2Nanos6; }; | ||||||
|       clangOmpss2-task  = callPackage ./test/compilers/ompss2.nix { |       clangOmpss2-task  = callPackage ./test/compilers/ompss2.nix { | ||||||
|  | |||||||
| @ -1,14 +1,20 @@ | |||||||
| { | { | ||||||
|   stdenv |   stdenv | ||||||
|  | , bigotes | ||||||
| , cmake | , cmake | ||||||
| , clangOmpss2 | , clangOmpss2 | ||||||
|  | , openmp | ||||||
|  | , openmpv | ||||||
| , nanos6 | , nanos6 | ||||||
| , nodes | , nodes | ||||||
|  | , nosv | ||||||
| , mpi | , mpi | ||||||
| , tampi | , tampi | ||||||
|  | , openblas | ||||||
|  | , ovni | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitURL ? "ssh://git@bscpm04.bsc.es/rarias/bench6.git" | , gitURL ? "ssh://git@bscpm04.bsc.es/rarias/bench6.git" | ||||||
| , gitCommit ? "1e6ce2aa8ad7b4eef38df1581d7ec48a8815f85d" | , gitCommit ? "bf29a53113737c3aa74d2fe3d55f59868faea7b4" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
| @ -21,9 +27,28 @@ stdenv.mkDerivation rec { | |||||||
|     rev = gitCommit; |     rev = gitCommit; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   buildInputs = [ cmake clangOmpss2 nanos6 nodes mpi tampi ]; |   buildInputs = [ | ||||||
|  |     bigotes | ||||||
|  |     cmake | ||||||
|  |     clangOmpss2 | ||||||
|  |     openmp | ||||||
|  |     openmpv | ||||||
|  |     nanos6 | ||||||
|  |     nodes | ||||||
|  |     nosv | ||||||
|  |     mpi | ||||||
|  |     tampi | ||||||
|  |     openblas | ||||||
|  |     openblas.dev | ||||||
|  |     ovni | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   env = { | ||||||
|  |     NANOS6_HOME = nanos6; | ||||||
|  |     NODES_HOME = nodes; | ||||||
|  |     NOSV_HOME = nosv; | ||||||
|  |   }; | ||||||
| 
 | 
 | ||||||
|   enableParallelBuilding = false; |  | ||||||
|   cmakeFlags = [ |   cmakeFlags = [ | ||||||
|     "-DCMAKE_C_COMPILER=clang" |     "-DCMAKE_C_COMPILER=clang" | ||||||
|     "-DCMAKE_CXX_COMPILER=clang++" |     "-DCMAKE_CXX_COMPILER=clang++" | ||||||
|  | |||||||
| @ -1,6 +1,5 @@ | |||||||
| { stdenv | { stdenv | ||||||
| , fetchurl | , fetchurl | ||||||
| , ncurses |  | ||||||
| , lib | , lib | ||||||
| , dpkg | , dpkg | ||||||
| , rsync | , rsync | ||||||
| @ -10,12 +9,9 @@ | |||||||
| , hwloc | , hwloc | ||||||
| , zlib | , zlib | ||||||
| , autoPatchelfHook | , autoPatchelfHook | ||||||
| , symlinkJoin |  | ||||||
| , libfabric | , libfabric | ||||||
| , gcc | , gcc13 | ||||||
| , gcc7 |  | ||||||
| , wrapCCWith | , wrapCCWith | ||||||
| , linuxHeaders |  | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| # The distribution of intel packages is a mess. We are doing the installation | # The distribution of intel packages is a mess. We are doing the installation | ||||||
| @ -30,6 +26,8 @@ | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
| 
 | 
 | ||||||
|  |   gcc = gcc13; | ||||||
|  | 
 | ||||||
|   v = { |   v = { | ||||||
|     hpckit   = "2023.1.0"; |     hpckit   = "2023.1.0"; | ||||||
|     compiler = "2023.1.0"; |     compiler = "2023.1.0"; | ||||||
| @ -47,40 +45,31 @@ let | |||||||
|     installPhase = '' |     installPhase = '' | ||||||
|       awk -F': ' '\ |       awk -F': ' '\ | ||||||
|         BEGIN   { print "[ {" } \ |         BEGIN   { print "[ {" } \ | ||||||
|         NR>1 && /^Package: / { print "} {"; } \ |         NF==0 { empty=1; } \ | ||||||
|  |         NF && empty { print "} {"; empty=0; } \ | ||||||
|         /: /    { printf "%s = \"%s\";\n", $1, $2 } \ |         /: /    { printf "%s = \"%s\";\n", $1, $2 } \ | ||||||
|         END     { print "} ]" }' $srcs > $out |         END     { print "} ]" }' $srcs > $out | ||||||
|     ''; |     ''; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   findMatch = name: | ||||||
|  |   let | ||||||
|     aptPackages = import aptPackageIndex; |     aptPackages = import aptPackageIndex; | ||||||
|  |     matches = lib.filter (x: name == x.Package) aptPackages; | ||||||
|  |     n = lib.length matches; | ||||||
|  |     match = builtins.traceVerbose (name + " -- ${builtins.toString n}") (builtins.head matches); | ||||||
| 
 | 
 | ||||||
|     apthost = "https://apt.repos.intel.com/oneapi/"; |     apthost = "https://apt.repos.intel.com/oneapi/"; | ||||||
| 
 |  | ||||||
|   getSum = pkgList: name: |  | ||||||
|   let |  | ||||||
|     matches = lib.filter (x: name == x.Package) pkgList; |  | ||||||
|     #n = lib.length matches; |  | ||||||
|     #match = builtins.trace (name + " -- ${builtins.toString n}") (lib.elemAt matches 0); |  | ||||||
|     match = lib.elemAt matches 0; |  | ||||||
|   in |   in | ||||||
|     match.SHA256; |     { | ||||||
| 
 |       url = apthost + match.Filename; | ||||||
|   getUrl = pkgList: name: |       sha256 = match.SHA256; | ||||||
|   let |     }; | ||||||
|     matches = lib.filter (x: name == x.Package) pkgList; |  | ||||||
|     #match = assert lib.length matches == 1; lib.elemAt matches 0; |  | ||||||
|     n = lib.length matches; |  | ||||||
|     match = |  | ||||||
|       #builtins.trace (name + " -- n=${builtins.toString n}") |  | ||||||
|       (lib.elemAt matches 0); |  | ||||||
|   in |  | ||||||
|     apthost + match.Filename; |  | ||||||
| 
 | 
 | ||||||
|   uncompressDebs = debs: name: stdenv.mkDerivation { |   uncompressDebs = debs: name: stdenv.mkDerivation { | ||||||
|     name = name; |     name = name; | ||||||
|     srcs = debs; |     srcs = debs; | ||||||
|     buildInputs = [ dpkg ]; |     nativeBuildInputs = [ dpkg ]; | ||||||
|     phases = [ "installPhase" ]; |     phases = [ "installPhase" ]; | ||||||
|     installPhase = '' |     installPhase = '' | ||||||
|       mkdir -p $out |       mkdir -p $out | ||||||
| @ -93,10 +82,7 @@ let | |||||||
| 
 | 
 | ||||||
|   joinDebs = name: names: |   joinDebs = name: names: | ||||||
|   let |   let | ||||||
|     urls = builtins.map (x: getUrl aptPackages x) names; |     debs = builtins.map (x: builtins.fetchurl (findMatch x)) names; | ||||||
|     sums = builtins.map (x: getSum aptPackages x) names; |  | ||||||
|     getsrc = url: sha256: builtins.fetchurl { inherit url sha256; }; |  | ||||||
|     debs = lib.zipListsWith getsrc urls sums; |  | ||||||
|   in |   in | ||||||
|     uncompressDebs debs "${name}-source"; |     uncompressDebs debs "${name}-source"; | ||||||
| 
 | 
 | ||||||
| @ -313,7 +299,11 @@ let | |||||||
|       "intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-common-${version}" |       "intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-common-${version}" | ||||||
|       "intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-runtime-${version}" |       "intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-runtime-${version}" | ||||||
|       "intel-oneapi-compiler-dpcpp-cpp-classic-fortran-shared-runtime-${version}" |       "intel-oneapi-compiler-dpcpp-cpp-classic-fortran-shared-runtime-${version}" | ||||||
|  |       "intel-oneapi-compiler-shared-${version}" | ||||||
|  |       "intel-oneapi-compiler-shared-common-${version}" | ||||||
|  |       "intel-oneapi-compiler-shared-runtime-${version}" | ||||||
|     ]; |     ]; | ||||||
|  |     dontCheckForBrokenSymlinks = true; | ||||||
|     # From https://aur.archlinux.org/packages/intel-oneapi-compiler: |     # From https://aur.archlinux.org/packages/intel-oneapi-compiler: | ||||||
|     # - intel-oneapi-compiler-cpp-eclipse-cfg-2023.0.0-25370_all.deb |     # - intel-oneapi-compiler-cpp-eclipse-cfg-2023.0.0-25370_all.deb | ||||||
|     # + intel-oneapi-compiler-dpcpp-cpp-2023.0.0-2023.0.0-25370_amd64.deb |     # + intel-oneapi-compiler-dpcpp-cpp-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
| @ -329,9 +319,9 @@ let | |||||||
|     # - intel-oneapi-compiler-fortran-common-2023.0.0-2023.0.0-25370_all.deb |     # - intel-oneapi-compiler-fortran-common-2023.0.0-2023.0.0-25370_all.deb | ||||||
|     # - intel-oneapi-compiler-fortran-runtime-2023.0.0-2023.0.0-25370_amd64.deb |     # - intel-oneapi-compiler-fortran-runtime-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-compiler-fortran-runtime-2023.0.0-25370_amd64.deb |     # - intel-oneapi-compiler-fortran-runtime-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-compiler-shared-2023.0.0-2023.0.0-25370_amd64.deb |     # + intel-oneapi-compiler-shared-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-compiler-shared-common-2023.0.0-2023.0.0-25370_all.deb |     # + intel-oneapi-compiler-shared-common-2023.0.0-2023.0.0-25370_all.deb | ||||||
|     # - intel-oneapi-compiler-shared-runtime-2023.0.0-2023.0.0-25370_amd64.deb |     # + intel-oneapi-compiler-shared-runtime-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-dpcpp-cpp-2023.0.0-2023.0.0-25370_amd64.deb |     # - intel-oneapi-dpcpp-cpp-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-openmp-2023.0.0-2023.0.0-25370_amd64.deb |     # - intel-oneapi-openmp-2023.0.0-2023.0.0-25370_amd64.deb | ||||||
|     # - intel-oneapi-openmp-common-2023.0.0-2023.0.0-25370_all.deb |     # - intel-oneapi-openmp-common-2023.0.0-2023.0.0-25370_all.deb | ||||||
| @ -398,8 +388,19 @@ let | |||||||
|         echo "-L${intel-compiler-shared}/lib" >> $out/nix-support/cc-ldflags |         echo "-L${intel-compiler-shared}/lib" >> $out/nix-support/cc-ldflags | ||||||
|         echo "-L${cc}/lib" >> $out/nix-support/cc-ldflags |         echo "-L${cc}/lib" >> $out/nix-support/cc-ldflags | ||||||
| 
 | 
 | ||||||
|  |         echo "--gcc-toolchain=${mygcc.cc}" >> $out/nix-support/libcxx-cxxflags | ||||||
|  | 
 | ||||||
|  |         for dir in ${mygcc.cc}/include/c++/*; do | ||||||
|  |           echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||||
|  |         done | ||||||
|  |         for dir in ${mygcc.cc}/include/c++/*/${targetConfig}; do | ||||||
|  |           echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||||
|  |         done | ||||||
|  | 
 | ||||||
|         # Need the gcc in the path |         # Need the gcc in the path | ||||||
|         echo 'export "PATH=${mygcc}/bin:$PATH"' >> $out/nix-support/cc-wrapper-hook |         # FIXME: We should find a better way to modify the PATH instead of using | ||||||
|  |         # this ugly hack. See https://jungle.bsc.es/git/rarias/bscpkgs/issues/9 | ||||||
|  |         echo 'path_backup="${mygcc}/bin:$path_backup"' >> $out/nix-support/cc-wrapper-hook | ||||||
| 
 | 
 | ||||||
|         # Disable hardening by default |         # Disable hardening by default | ||||||
|         echo "" > $out/nix-support/add-hardening.sh |         echo "" > $out/nix-support/add-hardening.sh | ||||||
| @ -441,7 +442,7 @@ let | |||||||
|     ''; |     ''; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   ifort-wrapper = wrapIntel rec { |   ifort-wrapper = wrapIntel { | ||||||
|     cc = intel-compiler-fortran; |     cc = intel-compiler-fortran; | ||||||
|     mygcc = gcc; |     mygcc = gcc; | ||||||
|     extraBuild = '' |     extraBuild = '' | ||||||
|  | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										112674
									
								
								pkgs/intel-oneapi/packages.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112674
									
								
								pkgs/intel-oneapi/packages.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										205
									
								
								pkgs/intel-oneapi/packages.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								pkgs/intel-oneapi/packages.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,205 @@ | |||||||
|  | { lib | ||||||
|  | , stdenv | ||||||
|  | , callPackage | ||||||
|  | , dpkg | ||||||
|  | , fetchurl | ||||||
|  | , recurseIntoAttrs | ||||||
|  | 
 | ||||||
|  | , sqlite | ||||||
|  | , elfutils | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   inherit (builtins) | ||||||
|  |     elem attrNames attrValues concatMap filter fromJSON getAttr groupBy head isNull listToAttrs map mapAttrs readFile replaceStrings splitVersion ; | ||||||
|  |   inherit (lib) | ||||||
|  |     converge findFirst groupBy' hasPrefix optional pipe take toInt toList versionAtLeast versionOlder ; | ||||||
|  | 
 | ||||||
|  |   aptData = fromJSON (readFile ./packages.json); | ||||||
|  | 
 | ||||||
|  |   # Compare versions in debian control file syntax | ||||||
|  |   # See: https://www.debian.org/doc/debian-policy/ch-relationships.html#syntax-of-relationship-fields | ||||||
|  |   # | ||||||
|  |   # NOTE: this is not a proper version comparison | ||||||
|  |   # | ||||||
|  |   # A proper version solver, should aggregate dependencies with the same name | ||||||
|  |   # and compute the constraint (e.g. a (>= 2) a (<< 5) -> 2 <= a << 5) | ||||||
|  |   # | ||||||
|  |   # But in the intel repo, there are no such "duplicated" dependencies to specify | ||||||
|  |   # upper limits, which leads to issues when intel-hpckit-2021 depends on things | ||||||
|  |   # like intel-basekit >= 2021.1.0-2403 and we end up installing the newest | ||||||
|  |   # basekit instead of the one from 2021. | ||||||
|  |   # | ||||||
|  |   # To mitigate this, >= is set to take the latest version with matching major | ||||||
|  |   # and minor (only revision and patch are allowed to change) | ||||||
|  |   compareVersions = got: kind: want: | ||||||
|  |     let | ||||||
|  |       g0 = take 2 (splitVersion got); | ||||||
|  |       w0 = take 2 (splitVersion want); | ||||||
|  |     in if isNull want then true | ||||||
|  |     else if kind == "=" then got == want | ||||||
|  |     else if kind == "<<" then versionOlder got want | ||||||
|  |     else if kind == "<=" then versionAtLeast want got | ||||||
|  |     else if kind == ">>" then versionOlder want got | ||||||
|  |     else if kind == ">=" then (g0 == w0) && versionAtLeast got want # always match major version | ||||||
|  |     else throw "unknown operation: ${kind}"; | ||||||
|  | 
 | ||||||
|  |   findMatching = { pname, kind, version }: | ||||||
|  |     findFirst (x: pname == x.pname && compareVersions x.version kind version) null aptData; | ||||||
|  | 
 | ||||||
|  |   isIntel = pkg: (hasPrefix "intel-" pkg.pname); | ||||||
|  | 
 | ||||||
|  |   expandDeps = pkg: (map findMatching (filter isIntel pkg.dependencies)) ++ (optional (pkg.size != 0) pkg); | ||||||
|  | 
 | ||||||
|  |   # get the oldest by major version. If they have the same major version, take | ||||||
|  |   # the newest. This prevents most issues with resolutions | ||||||
|  |   # versionOlder b a -> true if b is older than a (b `older` a) | ||||||
|  |   getNewerInMajor = a: b: let | ||||||
|  |     va = a.version; | ||||||
|  |     vb = b.version; | ||||||
|  |     va0 = head (splitVersion va); | ||||||
|  |     vb0 = head (splitVersion vb); | ||||||
|  |   in | ||||||
|  |   if isNull a then b | ||||||
|  |   else if va0 != vb0 then | ||||||
|  |     if va0 > vb0 then b else a | ||||||
|  |   else if versionOlder vb va then a else b; | ||||||
|  |   removeDups = l: attrValues (groupBy' getNewerInMajor null (getAttr "provides") l); | ||||||
|  | 
 | ||||||
|  |   _resolveDeps = converge (l: removeDups (concatMap expandDeps l)); | ||||||
|  |   resolveDeps = pkg: let deps = _resolveDeps (toList pkg); | ||||||
|  |       namedDeps = (map (x: "${x.pname}-${x.version}") deps); | ||||||
|  |     in builtins.traceVerbose (builtins.deepSeq namedDeps namedDeps) deps; | ||||||
|  | 
 | ||||||
|  |   blacklist = [ | ||||||
|  |     "intel-basekit-env" | ||||||
|  |     "intel-basekit-getting-started" | ||||||
|  |     "intel-hpckit-env" | ||||||
|  |     "intel-hpckit-getting-started" | ||||||
|  |     "intel-oneapi-advisor" | ||||||
|  |     "intel-oneapi-common-licensing" | ||||||
|  |     "intel-oneapi-common-oneapi-vars" | ||||||
|  |     "intel-oneapi-common-vars" | ||||||
|  |     "intel-oneapi-compiler-cpp-eclipse-cfg" | ||||||
|  |     "intel-oneapi-compiler-dpcpp-eclipse-cfg" | ||||||
|  |     "intel-oneapi-condaindex" | ||||||
|  |     "intel-oneapi-dev-utilities-eclipse-cfg" | ||||||
|  |     "intel-oneapi-dpcpp-ct-eclipse-cfg" | ||||||
|  |     "intel-oneapi-eclipse-ide" | ||||||
|  |     "intel-oneapi-hpc-toolkit-getting-started" | ||||||
|  |     "intel-oneapi-icc-eclipse-plugin-cpp" | ||||||
|  |     "intel-oneapi-vtune" | ||||||
|  |     "intel-oneapi-vtune-eclipse-plugin-vtune" | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   isInBlacklist = pkg: elem pkg.provides blacklist; | ||||||
|  |   removeBlacklist = filter (e: !(isInBlacklist e)); | ||||||
|  | 
 | ||||||
|  |   dpkgExtractAll = pname: version: {srcs, deps}: stdenv.mkDerivation { | ||||||
|  |     inherit pname version srcs; | ||||||
|  | 
 | ||||||
|  |     nativeBuildInputs = [ dpkg ]; | ||||||
|  |     phases = [ "installPhase" ]; | ||||||
|  | 
 | ||||||
|  |     passthru = { inherit deps; }; | ||||||
|  | 
 | ||||||
|  |     installPhase = '' | ||||||
|  |       mkdir -p $out | ||||||
|  |       for src in $srcs; do | ||||||
|  |         echo "Unpacking $src" | ||||||
|  |         dpkg -x $src $out | ||||||
|  |       done | ||||||
|  |     ''; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   apthost = "https://apt.repos.intel.com/oneapi/"; | ||||||
|  |   fetchDeb = p: fetchurl { url = apthost + p.filename; inherit (p) sha256; }; | ||||||
|  | 
 | ||||||
|  |   buildIntel = pkg: pipe pkg [ | ||||||
|  |     resolveDeps | ||||||
|  |     removeBlacklist | ||||||
|  |     (l: {srcs = map fetchDeb l; deps = l; }) | ||||||
|  |     (dpkgExtractAll "${pkg.provides}-extracted" pkg.version) | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   findHpcKit = year: findMatching { pname = "intel-hpckit"; kind = "<<"; version = toString (year+1); }; | ||||||
|  |   years = map toInt (attrNames components); | ||||||
|  | 
 | ||||||
|  |   patchIntel = callPackage ./patch_intel.nix { }; | ||||||
|  | 
 | ||||||
|  |   # Version information for each hpckit. This is used to normalize the paths | ||||||
|  |   # so that files are in $out/{bin,lib,include...} instead of all over the place | ||||||
|  |   # in $out/opt/intel/oneapi/*/*/{...}. | ||||||
|  |   # | ||||||
|  |   # The most important is the compiler component, which is used to build the | ||||||
|  |   # stdenv for the hpckit. | ||||||
|  |   # | ||||||
|  |   # NOTE: this have to be manually specified, so we can avoid IFD. To add a | ||||||
|  |   # new version, add a new field with an empty attrset, (e.g. "2026" = {}; ), | ||||||
|  |   # build hpckit_2026.unpatched and use the values from | ||||||
|  |   # result/opt/intel/oneapi/* to populate the attrset. | ||||||
|  |   # | ||||||
|  |   # WARN: if there are more than one version in the folders of the unpatched | ||||||
|  |   # components, our dependency resolution hacks have probably failed and the | ||||||
|  |   # package set may be broken. | ||||||
|  |   components = { | ||||||
|  |     "2025" = { | ||||||
|  |       ishmem = "1.3"; | ||||||
|  |       pti = "0.12"; | ||||||
|  |       tcm = "1.3"; | ||||||
|  |       umf = "0.10"; | ||||||
|  | 
 | ||||||
|  |       ccl = "2021.15"; | ||||||
|  |       compiler = "2025.1"; | ||||||
|  |       dal = "2025.5"; | ||||||
|  |       debugger = "2025.1"; | ||||||
|  |       dev-utilities = "2025.1"; | ||||||
|  |       dnnl = "2025.1"; | ||||||
|  |       dpcpp-ct = "2025.1"; | ||||||
|  |       dpl = "2022.8"; | ||||||
|  |       ipp = "2022.1"; | ||||||
|  |       ippcp = "2025.1"; | ||||||
|  |       mkl = "2025.1"; | ||||||
|  |       mpi = "2021.15"; | ||||||
|  |       tbb = "2022.1"; | ||||||
|  |     }; | ||||||
|  |     "2024" = { | ||||||
|  |       tcm = "1.1"; | ||||||
|  | 
 | ||||||
|  |       ccl = "2021.13"; | ||||||
|  |       compiler = "2024.2"; | ||||||
|  |       dal = "2024.6"; | ||||||
|  |       debugger = "2024.2"; | ||||||
|  |       dev-utilities = "2024.2"; | ||||||
|  |       diagnostics = "2024.2"; | ||||||
|  |       dnnl = "2024.2"; | ||||||
|  |       dpcpp-ct = "2024.2"; | ||||||
|  |       dpl = "2022.6"; | ||||||
|  |       ipp = "2021.12"; | ||||||
|  |       ippcp = "2021.12"; | ||||||
|  |       mkl = "2024.2"; | ||||||
|  |       mpi = "2021.13"; | ||||||
|  |       tbb = "2021.13"; | ||||||
|  | 
 | ||||||
|  |       extraPackages = [ | ||||||
|  |         sqlite | ||||||
|  |         elfutils | ||||||
|  |       ]; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   replaceDots = replaceStrings ["."] ["_"]; | ||||||
|  | 
 | ||||||
|  | in recurseIntoAttrs (listToAttrs (map (year: let | ||||||
|  |       year_str = toString year; | ||||||
|  |     in { | ||||||
|  |       name = "hpckit_${year_str}"; | ||||||
|  |       value = patchIntel {unpatched = buildIntel (findHpcKit year); components = components.${year_str}; }; | ||||||
|  |   }) years)) // { | ||||||
|  |   apt = pipe aptData [ | ||||||
|  |     (groupBy (p: replaceDots p.provides)) | ||||||
|  |     (mapAttrs (_: l: listToAttrs (map (pkg: { name = replaceDots ("v" + pkg.version); value = pkg; }) l))) | ||||||
|  |   ] ; | ||||||
|  | 
 | ||||||
|  |   inherit resolveDeps patchIntel buildIntel; | ||||||
|  | } | ||||||
							
								
								
									
										168
									
								
								pkgs/intel-oneapi/patch_intel.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								pkgs/intel-oneapi/patch_intel.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,168 @@ | |||||||
|  | { stdenv | ||||||
|  | , stdenvNoCC | ||||||
|  | , lib | ||||||
|  | , symlinkJoin | ||||||
|  | , autoPatchelfHook | ||||||
|  | , wrapCCWith | ||||||
|  | , overrideCC | ||||||
|  | , gcc | ||||||
|  | , hwloc | ||||||
|  | , libelf | ||||||
|  | , libffi_3_3 | ||||||
|  | , libpsm2 | ||||||
|  | , libuuid | ||||||
|  | , libxml2 | ||||||
|  | , numactl | ||||||
|  | , ocl-icd | ||||||
|  | , openssl | ||||||
|  | , python3 | ||||||
|  | , rdma-core | ||||||
|  | , ucx | ||||||
|  | , zlib | ||||||
|  | , makeOverridable | ||||||
|  | , recurseIntoAttrs | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | makeOverridable ( | ||||||
|  | { | ||||||
|  |   unpatched, | ||||||
|  |   components ? { }, | ||||||
|  |   extraPackages ? components.extraPackages or [] | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   inherit (builtins) attrValues filter mapAttrs removeAttrs; | ||||||
|  | 
 | ||||||
|  |   __components = removeAttrs components ["extraPackages"]; | ||||||
|  |   _components = __components; | ||||||
|  |   # _components = lib.traceSeqN 2 { | ||||||
|  |   #   inherit unpatched __components; | ||||||
|  |   #   deps = builtins.map (x: "${x.pname}-${x.version}") unpatched.deps; | ||||||
|  |   # } __components; | ||||||
|  | 
 | ||||||
|  |   wrapIntel = { cc, extraBuildCommands ? "", extraInstall ? "", ... }@args: | ||||||
|  |     let | ||||||
|  |       targetConfig = stdenv.targetPlatform.config; | ||||||
|  |     in (wrapCCWith { | ||||||
|  |       inherit cc; | ||||||
|  |       extraBuildCommands = '' | ||||||
|  |         echo "-isystem ${cc}/include" >> $out/nix-support/cc-cflags | ||||||
|  |         echo "-isystem ${cc}/include/intel64" >> $out/nix-support/cc-cflags | ||||||
|  | 
 | ||||||
|  |         echo "-L${gcc.cc}/lib/gcc/${targetConfig}/${gcc.version}" >> $out/nix-support/cc-ldflags | ||||||
|  |         echo "-L${gcc.cc.lib}/lib" >> $out/nix-support/cc-ldflags | ||||||
|  |         echo "-L${cc}/lib" >> $out/nix-support/cc-ldflags | ||||||
|  | 
 | ||||||
|  |         echo "--gcc-toolchain=${gcc.cc}" >> $out/nix-support/libcxx-cxxflags | ||||||
|  | 
 | ||||||
|  |         for dir in ${gcc.cc}/include/c++/*; do | ||||||
|  |           echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||||
|  |         done | ||||||
|  |         for dir in ${gcc.cc}/include/c++/*/${targetConfig}; do | ||||||
|  |           echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||||
|  |         done | ||||||
|  | 
 | ||||||
|  |         # Need the gcc in the path | ||||||
|  |         echo 'export "PATH=${gcc}/bin:$PATH"' >> $out/nix-support/cc-wrapper-hook | ||||||
|  | 
 | ||||||
|  |         # Disable hardening by default | ||||||
|  |         echo "" > $out/nix-support/add-hardening.sh | ||||||
|  | 
 | ||||||
|  |         # For some reason, If we don't resolve the realpath things go wrong | ||||||
|  |         for stddef in ${cc}/lib/clang/*/include/stddef.h ; do | ||||||
|  |           dir=$(dirname $(realpath "$stddef")) | ||||||
|  |           echo "-isystem $dir" >> $out/nix-support/cc-cflags | ||||||
|  |         done | ||||||
|  | 
 | ||||||
|  |       '' + extraBuildCommands; | ||||||
|  |     } // (removeAttrs args ["cc" "extraBuildCommands" "extraInstall"]) | ||||||
|  |     ).overrideAttrs (old: { | ||||||
|  |       installPhase = old.installPhase + extraInstall; | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  | in | ||||||
|  | stdenvNoCC.mkDerivation (finalAttrs: { | ||||||
|  |   pname = lib.removeSuffix "-extracted" unpatched.pname; | ||||||
|  |   inherit (unpatched) version; | ||||||
|  |   src = unpatched; | ||||||
|  | 
 | ||||||
|  |   phases = [ "installPhase" "fixupPhase" ]; | ||||||
|  |   buildInputs = [ | ||||||
|  |     libffi_3_3 | ||||||
|  |     libelf | ||||||
|  |     libxml2 | ||||||
|  |     hwloc | ||||||
|  |     numactl | ||||||
|  |     libuuid | ||||||
|  |     libpsm2 | ||||||
|  |     zlib | ||||||
|  |     ocl-icd | ||||||
|  |     rdma-core | ||||||
|  |     ucx | ||||||
|  |     openssl | ||||||
|  |     python3 | ||||||
|  |     stdenv.cc.cc.lib | ||||||
|  |   ] ++ extraPackages; | ||||||
|  | 
 | ||||||
|  |   autoPatchelfIgnoreMissingDeps = [ "libhwloc.so.5" "libcuda.so.1" "libze_loader.so.1" ]; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ autoPatchelfHook ]; | ||||||
|  |   installPhase = '' | ||||||
|  |     cp -r $src/opt/intel/oneapi/ $out | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   passthru = let | ||||||
|  |     pkgs = mapAttrs | ||||||
|  |       (folder: version: symlinkJoin { | ||||||
|  |         pname = "intel-${folder}"; | ||||||
|  |         inherit version; | ||||||
|  |         paths = ["${finalAttrs.finalPackage}/${folder}/${version}"]; | ||||||
|  |       }) | ||||||
|  |       _components; | ||||||
|  |   in pkgs // { | ||||||
|  |     inherit unpatched; | ||||||
|  |     pkgs = recurseIntoAttrs pkgs; | ||||||
|  |     components = _components; | ||||||
|  | 
 | ||||||
|  |     # This contains all packages properly symlinked into toplevel directories | ||||||
|  |     # in $out. | ||||||
|  |     # | ||||||
|  |     # NOTE: there are clashes with packages that have symlinks outside their | ||||||
|  |     # scope (libtcm and env/vars.sh) | ||||||
|  |     all = symlinkJoin { | ||||||
|  |       pname = finalAttrs.finalPackage + "-symlinked"; | ||||||
|  |       inherit (finalAttrs.finalPackage) version; | ||||||
|  |       paths = filter lib.isDerivation (attrValues finalAttrs.finalPackage.pkgs); | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     stdenv = overrideCC stdenv finalAttrs.finalPackage.cc; | ||||||
|  | 
 | ||||||
|  |     cc = wrapIntel { | ||||||
|  |       cc = finalAttrs.finalPackage.pkgs.compiler; | ||||||
|  |       extraBuildCommands = '' | ||||||
|  |         wrap icx  $wrapper $ccPath/icx | ||||||
|  |         wrap icpx $wrapper $ccPath/icpx | ||||||
|  |         wrap ifx  $wrapper $ccPath/ifx | ||||||
|  | 
 | ||||||
|  |         ln -s $out/bin/icpx $out/bin/c++ | ||||||
|  |         ln -s $out/bin/icx  $out/bin/cc | ||||||
|  | 
 | ||||||
|  |         # Use this to detect when a compiler subprocess is called | ||||||
|  |         # from icpx (--fsycl-host-compiler) | ||||||
|  |         echo 'export "NIX_CC_WRAPPER_INTEL=1"' >> $out/nix-support/cc-wrapper-hook | ||||||
|  | 
 | ||||||
|  |         sed -i 's/.*isCxx=0/isCxx=1/' $out/bin/icpx | ||||||
|  | 
 | ||||||
|  |         # oneMath looks for sycl libraries in bin/../lib | ||||||
|  |         ln -s ${finalAttrs.finalPackage.pkgs.compiler}/lib $out/lib | ||||||
|  |         ln -s ${finalAttrs.finalPackage.pkgs.compiler}/include $out/include | ||||||
|  |       ''; | ||||||
|  |       extraInstall = '' | ||||||
|  |         export named_cc="icx" | ||||||
|  |         export named_cxx="icpx" | ||||||
|  |         export named_fc="ifx" | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  | })) | ||||||
							
								
								
									
										29
									
								
								pkgs/intel-oneapi/process.jq
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										29
									
								
								pkgs/intel-oneapi/process.jq
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | #!/usr/bin/env -S jq -f | ||||||
|  | 
 | ||||||
|  | def extract_fields: { | ||||||
|  |         pname : .Package, | ||||||
|  |         version : .Version, | ||||||
|  |         provides : .Package | sub("[0-9.-]*$"; ""), | ||||||
|  |         filename : .Filename, | ||||||
|  |         size : ."Installed-Size" | tonumber, | ||||||
|  |         sha256 : .SHA256, | ||||||
|  |         dependencies : .Depends, | ||||||
|  |     } ; | ||||||
|  | 
 | ||||||
|  | # parses dependencies into a list of [{.pname, .kind, .version}] | ||||||
|  | # some dependencies do not have a version specified, in which case, version = version = null | ||||||
|  | # | ||||||
|  | # example dependencies: | ||||||
|  | # intel-oneapi-common-vars (>= 2023.0.0-25325), intel-oneapi-common-licensing-2023.0.0 | ||||||
|  | 
 | ||||||
|  | def split_dependencies : map(try(.dependencies |= split(",\\s?"; "")) // .dependencies |= []) ; | ||||||
|  | 
 | ||||||
|  | def match_version : capture("(?<pname>[a-zA-Z0-9_\\-.]*) *(\\((?<kind>[<>=]*) *(?<version>.*)\\))?"; "") ; | ||||||
|  | 
 | ||||||
|  | def parse_dependencies : map_values(.dependencies.[] |= match_version) ; | ||||||
|  | 
 | ||||||
|  | def sort_version_decreasing : sort_by(.version | split("[-.]"; "") | map(tonumber)) | reverse ; | ||||||
|  | 
 | ||||||
|  | map(extract_fields) | split_dependencies | parse_dependencies | sort_version_decreasing | ||||||
|  | 
 | ||||||
|  | # [.[] | select(.pname == "intel-hpckit") | .version] | ||||||
							
								
								
									
										29
									
								
								pkgs/intel-oneapi/toJson.awk
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										29
									
								
								pkgs/intel-oneapi/toJson.awk
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | #!/usr/bin/env -S awk -f | ||||||
|  | 
 | ||||||
|  | BEGIN   { | ||||||
|  |     FS=": " | ||||||
|  | 
 | ||||||
|  |     prev_empty=1 | ||||||
|  |     t="  " | ||||||
|  | 
 | ||||||
|  |     print "[ {" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | !NF { # empty line, update separator so next non empty line closes the dict | ||||||
|  |     prev_empty=1 | ||||||
|  |     t="},\n{ " | ||||||
|  |     next # skip line (we won't match anything else) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | { | ||||||
|  |     printf t "\"%s\" : \"%s\"\n", $1, $2 | ||||||
|  | 
 | ||||||
|  |     if (prev_empty) { | ||||||
|  |         # we were the first after a group of empty lines, following ones have to | ||||||
|  |         # have a comma | ||||||
|  |         prev_empty=0 | ||||||
|  |         t=", " | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | END     { print "} ]" } | ||||||
| @ -2,3 +2,5 @@ | |||||||
| 
 | 
 | ||||||
| curl https://apt.repos.intel.com/oneapi/dists/all/main/binary-amd64/Packages -o amd64-packages | curl https://apt.repos.intel.com/oneapi/dists/all/main/binary-amd64/Packages -o amd64-packages | ||||||
| curl https://apt.repos.intel.com/oneapi/dists/all/main/binary-all/Packages -o all-packages | curl https://apt.repos.intel.com/oneapi/dists/all/main/binary-all/Packages -o all-packages | ||||||
|  | 
 | ||||||
|  | cat amd64-packages all-packages | ./toJson.awk | ./process.jq >packages.json | ||||||
|  | |||||||
| @ -16,19 +16,19 @@ | |||||||
| , useGit ? false | , useGit ? false | ||||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/llvm-ompss/llvm-mono.git" | , gitUrl ? "ssh://git@bscpm04.bsc.es/llvm-ompss/llvm-mono.git" | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitCommit ? "8c0d267c04d7fc3fb923078f510fcd5f4719a6cc" | , gitCommit ? "880e2341c56bad1dc14e8c369fb3356bec19018e" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   stdenv = llvmPackages_latest.stdenv; |   stdenv = llvmPackages_latest.stdenv; | ||||||
| 
 | 
 | ||||||
|   release = rec { |   release = rec { | ||||||
|     version = "2024.11"; |     version = "2025.06"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "llvm"; |       repo = "llvm"; | ||||||
|       rev = "refs/tags/github-release-${version}"; |       rev = "refs/tags/github-release-${version}"; | ||||||
|       hash = "sha256-pF0qa987nLkIJPUrXh1srzBkLPfb31skIegD0bl34Kg="; |       hash = "sha256-ww9PpRmtz/M9IyLiZ8rAehx2UW4VpQt+svf4XfKBzKo="; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ | |||||||
| , lib | , lib | ||||||
| , gcc | , gcc | ||||||
| , clangOmpss2Unwrapped | , clangOmpss2Unwrapped | ||||||
|  | , writeShellScript | ||||||
| , openmp ? null | , openmp ? null | ||||||
| , wrapCCWith | , wrapCCWith | ||||||
| , llvmPackages_latest | , llvmPackages_latest | ||||||
| @ -37,16 +38,16 @@ let | |||||||
|   inherit gcc; |   inherit gcc; | ||||||
|   cc = clangOmpss2Unwrapped; |   cc = clangOmpss2Unwrapped; | ||||||
|   gccVersion = with versions; let v = gcc.version; in concatStringsSep "." [(major v) (minor v) (patch v)]; |   gccVersion = with versions; let v = gcc.version; in concatStringsSep "." [(major v) (minor v) (patch v)]; | ||||||
| in wrapCCWith { | 
 | ||||||
|   inherit cc bintools; |  | ||||||
|   # extraPackages adds packages to depsTargetTargetPropagated |  | ||||||
|   extraPackages = optional (openmp != null) openmp; |  | ||||||
|   extraBuildCommands = '' |   extraBuildCommands = '' | ||||||
|     echo "-target ${targetConfig}" >> $out/nix-support/cc-cflags |     echo "-target ${targetConfig}" >> $out/nix-support/cc-cflags | ||||||
|     echo "-B${gcc.cc}/lib/gcc/${targetConfig}/${gccVersion}" >> $out/nix-support/cc-cflags |     echo "-B${gcc.cc}/lib/gcc/${targetConfig}/${gccVersion}" >> $out/nix-support/cc-cflags | ||||||
|     echo "-L${gcc.cc}/lib/gcc/${targetConfig}/${gccVersion}" >> $out/nix-support/cc-ldflags |     echo "-L${gcc.cc}/lib/gcc/${targetConfig}/${gccVersion}" >> $out/nix-support/cc-ldflags | ||||||
|     echo "-L${gcc.cc.lib}/lib" >> $out/nix-support/cc-ldflags |     echo "-L${gcc.cc.lib}/lib" >> $out/nix-support/cc-ldflags | ||||||
| 
 | 
 | ||||||
|  |     for dir in ${gcc.cc}/lib/gcc/${targetConfig}/*/include; do | ||||||
|  |       echo "-isystem $dir" >> $out/nix-support/cc-cflags | ||||||
|  |     done | ||||||
|     for dir in ${gcc.cc}/include/c++/*; do |     for dir in ${gcc.cc}/include/c++/*; do | ||||||
|       echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags |       echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||||
|     done |     done | ||||||
| @ -57,8 +58,9 @@ in wrapCCWith { | |||||||
|     echo "--gcc-toolchain=${gcc}" >> $out/nix-support/cc-cflags |     echo "--gcc-toolchain=${gcc}" >> $out/nix-support/cc-cflags | ||||||
| 
 | 
 | ||||||
|     wrap clang++  $wrapper $ccPath/clang++ |     wrap clang++  $wrapper $ccPath/clang++ | ||||||
|  |   ''; | ||||||
| 
 | 
 | ||||||
|   '' + optionalString (openmp != null) '' |   envExports = lib.optionalString (openmp != null) '' | ||||||
|       echo "export OPENMP_RUNTIME=${ompname}" >> $out/nix-support/cc-wrapper-hook |       echo "export OPENMP_RUNTIME=${ompname}" >> $out/nix-support/cc-wrapper-hook | ||||||
|     '' + optionalString (ompss2rt != null) '' |     '' + optionalString (ompss2rt != null) '' | ||||||
|       echo "export OMPSS2_RUNTIME=${rtname}" >> $out/nix-support/cc-wrapper-hook |       echo "export OMPSS2_RUNTIME=${rtname}" >> $out/nix-support/cc-wrapper-hook | ||||||
| @ -66,5 +68,40 @@ in wrapCCWith { | |||||||
|     '' + optionalString (ompss2rt != null && ompss2rt.pname == "nodes") '' |     '' + optionalString (ompss2rt != null && ompss2rt.pname == "nodes") '' | ||||||
|       echo "export NOSV_HOME=${ompss2rt.nosv}" >> $out/nix-support/cc-wrapper-hook |       echo "export NOSV_HOME=${ompss2rt.nosv}" >> $out/nix-support/cc-wrapper-hook | ||||||
|     ''; |     ''; | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
|  |   extraPackages = optional (openmp != null) openmp; | ||||||
|  | 
 | ||||||
|  |   wrappedCC = wrapCCWith { | ||||||
|  |     # extraPackages adds packages to depsTargetTargetPropagated | ||||||
|  |     inherit cc bintools extraPackages; | ||||||
|  |     extraBuildCommands = extraBuildCommands + envExports; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   resetIntelCCFlags = let tconf = builtins.replaceStrings ["-"] ["_"] targetConfig; | ||||||
|  |   in writeShellScript "remove-intel.sh" '' | ||||||
|  |     if [ "''${NIX_CC_WRAPPER_INTEL:-0}" = 1 ]; then | ||||||
|  |       unset NIX_CFLAGS_COMPILE_${tconf} | ||||||
|  |       unset NIX_CC_WRAPPER_FLAGS_SET_${tconf} | ||||||
|  | 
 | ||||||
|  |       if (( "''${NIX_DEBUG:-0}" >= 1 )); then | ||||||
|  |         echo "ompss2: cleaned NIX_CFLAGS_COMPILE_${tconf} (invokation from intel compiler detected)" | ||||||
|  |       fi | ||||||
|  |     fi | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   intelExtraBuildCommands = '' | ||||||
|  |     sed -i 's|# Flirting.*|source ${resetIntelCCFlags}\n\n&|' $out/bin/clang | ||||||
|  |     sed -i 's|# Flirting.*|source ${resetIntelCCFlags}\n\n&|' $out/bin/clang++ | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   wrappedCCIntel = wrapCCWith { | ||||||
|  |     inherit cc bintools extraPackages; | ||||||
|  |     # extraPackages adds packages to depsTargetTargetPropagated | ||||||
|  |     extraBuildCommands = intelExtraBuildCommands + envExports; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  | in wrappedCC.overrideAttrs (oldAttrs: { | ||||||
|  |     passthru = oldAttrs.passthru // { | ||||||
|  |       forIcpx = wrappedCCIntel; | ||||||
|  |     }; | ||||||
|  |   }) | ||||||
|  | |||||||
| @ -17,16 +17,12 @@ stdenv.mkDerivation rec { | |||||||
|     sha256 = "sha256-SzwplRBO3V0R3m3p15n71ivYBMGoLsajFK2TapYxdqk="; |     sha256 = "sha256-SzwplRBO3V0R3m3p15n71ivYBMGoLsajFK2TapYxdqk="; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   postUnpack = '' |  | ||||||
|     export sourceRoot="$sourceRoot/src" |  | ||||||
|   ''; |  | ||||||
| 
 |  | ||||||
|   postPatch = '' |   postPatch = '' | ||||||
|     sed -i "s@/bin/rm@rm@g" $(find . -name Makefile) |     sed -i "s@/bin/rm@rm@g" $(find . -name Makefile) | ||||||
|   ''; |   ''; | ||||||
| 
 | 
 | ||||||
|   buildInputs = [ libtirpc ]; |   buildInputs = [ libtirpc ]; | ||||||
|   patches = [ ./fix-install.patch ]; |   patches = [ ./fix-install.patch ./gcc-14.patch ]; | ||||||
| 
 | 
 | ||||||
|   hardeningDisable = [ "all" ]; |   hardeningDisable = [ "all" ]; | ||||||
| 
 | 
 | ||||||
| @ -34,7 +30,9 @@ stdenv.mkDerivation rec { | |||||||
| 
 | 
 | ||||||
|   preBuild = '' |   preBuild = '' | ||||||
|     makeFlagsArray+=( |     makeFlagsArray+=( | ||||||
|  |       -C src | ||||||
|       BASE=$out |       BASE=$out | ||||||
|  |       CFLAGS=-Wno-implicit-int | ||||||
|       CPPFLAGS=-I${libtirpc.dev}/include/tirpc |       CPPFLAGS=-I${libtirpc.dev}/include/tirpc | ||||||
|       LDFLAGS=-ltirpc |       LDFLAGS=-ltirpc | ||||||
|     ) |     ) | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| --- a/Makefile
 | --- a/src/Makefile
 | ||||||
| +++ b/Makefile
 | +++ b/src/Makefile
 | ||||||
| @@ -144,6 +144,7 @@ install-target:
 | @@ -144,6 +144,7 @@ install-target:
 | ||||||
|  	if [ ! -d $(BASE)/include ]; then mkdir $(BASE)/include; fi |  	if [ ! -d $(BASE)/include ]; then mkdir $(BASE)/include; fi | ||||||
|  	if [ ! -d $(BASE)/lib ]; then mkdir $(BASE)/lib; fi |  	if [ ! -d $(BASE)/lib ]; then mkdir $(BASE)/lib; fi | ||||||
|  | |||||||
							
								
								
									
										77
									
								
								pkgs/lmbench/gcc-14.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								pkgs/lmbench/gcc-14.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | |||||||
|  | From a3c6e7d303cd8368e8d4e35be7cbc1997e801257 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Rodrigo Arias Mallo <rodrigo.arias@bsc.es> | ||||||
|  | Date: Mon, 21 Jul 2025 17:38:58 +0200 | ||||||
|  | Subject: [PATCH] Misc fixes to build with gcc 14 | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  src/bench.h      | 2 ++ | ||||||
|  |  src/lat_select.c | 2 +- | ||||||
|  |  src/lib_debug.c  | 1 + | ||||||
|  |  src/lib_sched.c  | 2 +- | ||||||
|  |  src/lib_timing.c | 2 +- | ||||||
|  |  5 files changed, 6 insertions(+), 3 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/bench.h b/src/bench.h
 | ||||||
|  | index 8166408..4da9079 100644
 | ||||||
|  | --- a/src/bench.h
 | ||||||
|  | +++ b/src/bench.h
 | ||||||
|  | @@ -320,4 +320,6 @@ extern int handle_scheduler(int childno, int benchproc, int nbenchprocs);
 | ||||||
|  |  extern char *rpc_xact_1(); | ||||||
|  |  extern char *client_rpc_xact_1(); | ||||||
|  |   | ||||||
|  | +void lmbench_usage(int argc, char *argv[], char* usage);
 | ||||||
|  | +
 | ||||||
|  |  #endif /* _BENCH_H */ | ||||||
|  | diff --git a/src/lat_select.c b/src/lat_select.c
 | ||||||
|  | index 583b505..39df369 100644
 | ||||||
|  | --- a/src/lat_select.c
 | ||||||
|  | +++ b/src/lat_select.c
 | ||||||
|  | @@ -164,7 +164,7 @@ doit(iter_t iterations, void * cookie)
 | ||||||
|  |  	state_t * 	state = (state_t *)cookie; | ||||||
|  |  	fd_set		nosave; | ||||||
|  |  	static struct timeval tv; | ||||||
|  | -	static count = 0;
 | ||||||
|  | +	static int count = 0;
 | ||||||
|  |  	 | ||||||
|  |  	tv.tv_sec = 0; | ||||||
|  |  	tv.tv_usec = 0; | ||||||
|  | diff --git a/src/lib_debug.c b/src/lib_debug.c
 | ||||||
|  | index e8347dd..cf65312 100644
 | ||||||
|  | --- a/src/lib_debug.c
 | ||||||
|  | +++ b/src/lib_debug.c
 | ||||||
|  | @@ -1,5 +1,6 @@
 | ||||||
|  |  #include "bench.h" | ||||||
|  |  #include "lib_debug.h" | ||||||
|  | +#include <math.h>
 | ||||||
|  |   | ||||||
|  |  /* | ||||||
|  |   * return micro-seconds / iteration at the the fraction point. | ||||||
|  | diff --git a/src/lib_sched.c b/src/lib_sched.c
 | ||||||
|  | index aa83ae0..4f16bbf 100644
 | ||||||
|  | --- a/src/lib_sched.c
 | ||||||
|  | +++ b/src/lib_sched.c
 | ||||||
|  | @@ -91,7 +91,7 @@ handle_scheduler(int childno, int benchproc, int nbenchprocs)
 | ||||||
|  |  			     childno * (nbenchprocs + 1) + benchproc); | ||||||
|  |  	} else { | ||||||
|  |  		/* default action: do nothing */ | ||||||
|  | -		return;
 | ||||||
|  | +		return 0;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	return sched_pin(cpu % sched_ncpus()); | ||||||
|  | diff --git a/src/lib_timing.c b/src/lib_timing.c
 | ||||||
|  | index af8cf68..7ec9652 100644
 | ||||||
|  | --- a/src/lib_timing.c
 | ||||||
|  | +++ b/src/lib_timing.c
 | ||||||
|  | @@ -1623,7 +1623,7 @@ bread(void* buf, long nbytes)
 | ||||||
|  |  void | ||||||
|  |  touch(char *buf, int nbytes) | ||||||
|  |  { | ||||||
|  | -	static	psize;
 | ||||||
|  | +	static int psize;
 | ||||||
|  |   | ||||||
|  |  	if (!psize) { | ||||||
|  |  		psize = getpagesize(); | ||||||
|  | -- 
 | ||||||
|  | 2.49.0 | ||||||
|  | 
 | ||||||
| @ -19,7 +19,7 @@ | |||||||
| , useGit ? false | , useGit ? false | ||||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/nanos6/nanos6" | , gitUrl ? "ssh://git@bscpm04.bsc.es/nanos6/nanos6" | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitCommit ? "9f54c988e0a8b9c011d9d526acdb8d76f18fcae4" | , gitCommit ? "f82762b66c82b5174a8eaad33f6c2f335ac759b4" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| assert enableJemalloc -> (jemallocNanos6 != null); | assert enableJemalloc -> (jemallocNanos6 != null); | ||||||
| @ -28,12 +28,12 @@ with lib; | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   release = rec { |   release = rec { | ||||||
|     version = "4.2"; |     version = "4.3"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "nanos6"; |       repo = "nanos6"; | ||||||
|       rev = "version-${version}"; |       rev = "version-${version}"; | ||||||
|       hash = "sha256-tBrRGLCjSFYdmVGPAC2DzYY6HJyZGUOMeykujafn7+4="; |       hash = "sha256-/c6WiKBsAo/01uvMRmjv0PMucbrgvaGmbxlPE6q+dfE="; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,19 +11,19 @@ | |||||||
| , useGit ? false | , useGit ? false | ||||||
| , gitUrl ? "git@gitlab-internal.bsc.es:nos-v/nos-v.git" | , gitUrl ? "git@gitlab-internal.bsc.es:nos-v/nos-v.git" | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitCommit ? "cfd361bd1dd30c96da405e6bbaa7e78f5f93dfda" | , gitCommit ? "9f47063873c3aa9d6a47482a82c5000a8c813dd8" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| with lib; | with lib; | ||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   release = rec { |   release = rec { | ||||||
|     version = "3.1.0"; |     version = "3.2.0"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "nos-v"; |       repo = "nos-v"; | ||||||
|       rev = "${version}"; |       rev = "${version}"; | ||||||
|       hash = "sha256-Pkre+ZZsREDxJLCoIoPN1HQDuUa2H1IQyKB3omg6qaU="; |       hash = "sha256-yaz92426EM8trdkBJlISmAoG9KJCDTvoAW/HKrasvOw="; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										84
									
								
								pkgs/onemath/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								pkgs/onemath/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,84 @@ | |||||||
|  | { lib | ||||||
|  | , fetchFromGitHub | ||||||
|  | , cmake | ||||||
|  | , withCFlags | ||||||
|  | , intelPackages | ||||||
|  | 
 | ||||||
|  | , mklSupport ? true | ||||||
|  | 
 | ||||||
|  | , config | ||||||
|  | 
 | ||||||
|  | , cudaSupport ? config.cudaSupport | ||||||
|  | , cudaPackages ? { } | ||||||
|  | 
 | ||||||
|  | , rocmSupport ? config.rocmSupport | ||||||
|  | , hipTargets ? null # only one target at a time supported | ||||||
|  | , rocmPackages ? { } | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   # rocmSupport is not enough, we need a specific target | ||||||
|  |   enableHip = rocmSupport && hipTargets != null; | ||||||
|  | 
 | ||||||
|  |   stdenv = withCFlags (lib.optionals cudaSupport [ "--cuda-path=${cudaPackages.cudatoolkit}" ]) intelPackages.stdenv; | ||||||
|  | in | ||||||
|  | 
 | ||||||
|  |   # at least one backend has to be enabled | ||||||
|  |   assert mklSupport || cudaSupport || enableHip; | ||||||
|  | 
 | ||||||
|  | stdenv.mkDerivation rec { | ||||||
|  |   pname = "oneMath"; | ||||||
|  |   version = "0.8"; | ||||||
|  | 
 | ||||||
|  |   src = fetchFromGitHub { | ||||||
|  |     owner = "uxlfoundation"; | ||||||
|  |     repo = "oneMath"; | ||||||
|  |     rev = "v${version}"; | ||||||
|  |     sha256 = "sha256-xK8lKI3oqKlx3xtvdScpMq+HXAuoYCP0BZdkEqnJP5o="; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   cmakeFlags = [ | ||||||
|  |     (lib.cmakeBool "ENABLE_MKLCPU_BACKEND"    mklSupport) | ||||||
|  |     (lib.cmakeBool "ENABLE_MKLGPU_BACKEND"    mklSupport) | ||||||
|  | 
 | ||||||
|  |     (lib.cmakeBool "ENABLE_CUBLAS_BACKEND"    cudaSupport) | ||||||
|  |     (lib.cmakeBool "ENABLE_CUFFT_BACKEND"     cudaSupport) | ||||||
|  |     (lib.cmakeBool "ENABLE_CURAND_BACKEND"    cudaSupport) | ||||||
|  |     (lib.cmakeBool "ENABLE_CUSOLVER_BACKEND"  cudaSupport) | ||||||
|  |     (lib.cmakeBool "ENABLE_CUSPARSE_BACKEND"  cudaSupport) | ||||||
|  | 
 | ||||||
|  |     (lib.cmakeBool "ENABLE_ROCBLAS_BACKEND"   enableHip) | ||||||
|  |     (lib.cmakeBool "ENABLE_ROCFFT_BACKEND"    enableHip) | ||||||
|  |     (lib.cmakeBool "ENABLE_ROCSOLVER_BACKEND" enableHip) | ||||||
|  |     (lib.cmakeBool "ENABLE_ROCRAND_BACKEND"   enableHip) | ||||||
|  |     (lib.cmakeBool "ENABLE_ROCSPARSE_BACKEND" enableHip) | ||||||
|  | 
 | ||||||
|  |     (lib.cmakeBool "BUILD_FUNCTIONAL_TESTS" false) | ||||||
|  |     (lib.cmakeBool "BUILD_EXAMPLES" false) | ||||||
|  |   ] ++ lib.optionals enableHip [ | ||||||
|  |     (lib.cmakeFeature "HIP_TARGETS" hipTargets) | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ cmake ]; | ||||||
|  |   buildInputs = lib.optionals (mklSupport) [ | ||||||
|  |     intelPackages.mkl | ||||||
|  |     intelPackages.tbb | ||||||
|  |   ] ++ lib.optionals (enableHip) [ | ||||||
|  |     rocmPackages.rocmPath | ||||||
|  |     rocmPackages.rocblas | ||||||
|  |     rocmPackages.rocfft | ||||||
|  |     rocmPackages.rocsolver | ||||||
|  |     rocmPackages.rocrand | ||||||
|  |     rocmPackages.rocsparse | ||||||
|  |   ] ++ lib.optionals (cudaSupport) [ | ||||||
|  |     (lib.getDev cudaPackages.cuda_cudart) | ||||||
|  |     cudaPackages.cudatoolkit | ||||||
|  | 
 | ||||||
|  |     cudaPackages.libcublas | ||||||
|  |     cudaPackages.libcurand | ||||||
|  |     cudaPackages.libcufft | ||||||
|  |     cudaPackages.libcusparse | ||||||
|  |     cudaPackages.libcusolver | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -7,7 +7,7 @@ | |||||||
| , useGit ? false | , useGit ? false | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/rarias/ovni.git" | , gitUrl ? "ssh://git@bscpm04.bsc.es/rarias/ovni.git" | ||||||
| , gitCommit ? "a7103f8510d1ec124c3e01ceb47d1e443e98bbf4" | , gitCommit ? "e4f62382076f0cf0b1d08175cf57cc0bc51abc61" | ||||||
| , enableDebug ? false | , enableDebug ? false | ||||||
| # Only enable MPI if the build is native (fails on cross-compilation) | # Only enable MPI if the build is native (fails on cross-compilation) | ||||||
| , useMpi ? (stdenv.buildPlatform.canExecute stdenv.hostPlatform) | , useMpi ? (stdenv.buildPlatform.canExecute stdenv.hostPlatform) | ||||||
| @ -17,13 +17,13 @@ with lib; | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   release = rec { |   release = rec { | ||||||
|     version = "1.11.0"; |     version = "1.12.0"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "ovni"; |       repo = "ovni"; | ||||||
|       rev = "${version}"; |       rev = "${version}"; | ||||||
|       hash = "sha256-DEZUK1dvbPGH5WYkZ2hpP5PShkMxXkHOqMwgYUHHxeM="; |       hash = "sha256-H04JvsVKrdqr3ON7JhU0g17jjlg/jzQ7eTfx9vUNd3E="; | ||||||
|     } // { shortRev = "a7103f8"; }; |     } // { shortRev = "a73afcf"; }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   git = rec { |   git = rec { | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| { | { | ||||||
|   stdenv |   stdenv | ||||||
| , autoreconfHook | , autoreconfHook | ||||||
| , boost | , boost186 | ||||||
| , libxml2 | , libxml2 | ||||||
| , xml2 | , xml2 | ||||||
| , wxGTK32 | , wxGTK32 | ||||||
| @ -15,6 +15,7 @@ | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   wx = wxGTK32; |   wx = wxGTK32; | ||||||
|  |   boost = boost186; | ||||||
| in | in | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "wxparaver"; |   pname = "wxparaver"; | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ | |||||||
| , useGit ? false | , useGit ? false | ||||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/interoperability/tampi.git" | , gitUrl ? "ssh://git@bscpm04.bsc.es/interoperability/tampi.git" | ||||||
| , gitBranch ? "master" | , gitBranch ? "master" | ||||||
| , gitCommit ? "a5c93bf8ab045b71ad4a8d5e2c991ce774db5cbc" | , gitCommit ? "f6455db9d3124ae36e715a4874fd49720e79f20a" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| with lib; | with lib; | ||||||
| @ -24,12 +24,12 @@ assert enableOvni -> (ovni != null); | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   release = rec { |   release = rec { | ||||||
|     version = "4.0"; |     version = "4.1"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "tampi"; |       repo = "tampi"; | ||||||
|       rev = "v${version}"; |       rev = "v${version}"; | ||||||
|       hash = "sha256-R7ew5tsrxGReTvOeeZe1FD0oThBhOHoDGv6Mo2sbmDg="; |       hash = "sha256-SwfPSnwcZnRnSgNvCD5sFSUJRpWINqI5I4adj5Hh+XY="; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|   git = rec { |   git = rec { | ||||||
|  | |||||||
							
								
								
									
										94
									
								
								pkgs/tasycl/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								pkgs/tasycl/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,94 @@ | |||||||
|  | { stdenv | ||||||
|  | , lib | ||||||
|  | , withCFlags | ||||||
|  | , intelPackages | ||||||
|  | , fetchFromGitHub | ||||||
|  | , automake | ||||||
|  | , autoconf | ||||||
|  | , libtool | ||||||
|  | , gnumake | ||||||
|  | , autoreconfHook | ||||||
|  | , boost | ||||||
|  | , adaptivecpp ? null | ||||||
|  | , useIntel ? true | ||||||
|  | 
 | ||||||
|  | , useGit ? false | ||||||
|  | , gitUrl ? "git@gitlab-internal.bsc.es:task-awareness/tasycl/tasycl.git" | ||||||
|  | , gitBranch ? "main" | ||||||
|  | , gitCommit ? "78f98dcf60a66e0eaa3b4ebcf55be076bec64825" | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | assert (useIntel || adaptivecpp != null); | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   variant = if useIntel then "intel" else "acpp"; | ||||||
|  | 
 | ||||||
|  |   syclStdenv = | ||||||
|  |     if useIntel then | ||||||
|  |       # If we don't set optimization level, separateDebugInfo sets ggdb and | ||||||
|  |       # intel disables all optimizations | ||||||
|  |       withCFlags ["-O3"] intelPackages.stdenv | ||||||
|  |     else | ||||||
|  |       withCFlags [ "-L${adaptivecpp}/lib" "-lacpp-rt" "-I${adaptivecpp}/include" ] stdenv | ||||||
|  |   ; | ||||||
|  | 
 | ||||||
|  |   release = rec { | ||||||
|  |     version = "2.1.0"; | ||||||
|  |     src = fetchFromGitHub { | ||||||
|  |       owner = "bsc-pm"; | ||||||
|  |       repo = "tasycl"; | ||||||
|  |       rev = version; | ||||||
|  |       hash = "sha256-0kXnb0lHeQNHR27GTLbJ8xbiICLU8k2+FqEnnFSrzzo="; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   git = rec { | ||||||
|  |     version = src.shortRev; | ||||||
|  |     src = builtins.fetchGit { | ||||||
|  |       url = gitUrl; | ||||||
|  |       ref = gitBranch; | ||||||
|  |       rev = gitCommit; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   source = if (useGit) then git else release; | ||||||
|  | 
 | ||||||
|  |   isOldRelease = (!useGit && (builtins.compareVersions source.version "2.0.0" <= 0)); | ||||||
|  | 
 | ||||||
|  | in | ||||||
|  | 
 | ||||||
|  | assert !isOldRelease || useIntel; # old releases only work with intel | ||||||
|  | 
 | ||||||
|  | syclStdenv.mkDerivation { | ||||||
|  |   pname = "tasycl"; | ||||||
|  |   inherit (source) src version; | ||||||
|  | 
 | ||||||
|  |   enableParallelBuilding = true; | ||||||
|  |   separateDebugInfo = true; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ | ||||||
|  |     autoreconfHook | ||||||
|  |     automake | ||||||
|  |     autoconf | ||||||
|  |     libtool | ||||||
|  |     gnumake | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   buildInputs = [ | ||||||
|  |     boost | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   # only needed for release versions prior or equal to 2.0.0 | ||||||
|  |   configureFlags = lib.optionals isOldRelease [ "--with-sycl-include=${intelPackages.icx.cc}/include/sycl" ]; | ||||||
|  | 
 | ||||||
|  |   # add symlinks so we can explicitly link with tasycl-intel / tasycl-acpp | ||||||
|  |   postInstall = '' | ||||||
|  |     pushd $out/lib | ||||||
|  |     for i in libtasycl* ; do | ||||||
|  |       ln -s "$i" "''\${i/tasycl/tasycl-${variant}}" | ||||||
|  |     done | ||||||
|  |     popd | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   hardeningDisable = [ "all" ]; | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								test/compilers/hello-sycl.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								test/compilers/hello-sycl.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | |||||||
|  | { intelPackages,  writeText, strace }: | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   stdenv = intelPackages.stdenv; | ||||||
|  |   hello_sycl = writeText "hello.cpp" '' | ||||||
|  |     #include <sycl/sycl.hpp> | ||||||
|  | 
 | ||||||
|  |     class hello_world; | ||||||
|  | 
 | ||||||
|  |     int main(int argc, char** argv) try { | ||||||
|  |         auto device_selector = sycl::default_selector_v; | ||||||
|  | 
 | ||||||
|  |         sycl::queue queue(device_selector); | ||||||
|  | 
 | ||||||
|  |         std::cout << "Running on: " | ||||||
|  |                   << queue.get_device().get_info<sycl::info::device::name>() | ||||||
|  |                   << std::endl; | ||||||
|  | 
 | ||||||
|  |         queue.submit([&] (sycl::handler& cgh) { | ||||||
|  |             auto os = sycl::stream{128, 128, cgh}; | ||||||
|  |             cgh.single_task<hello_world>([=]() { | ||||||
|  |                 os << "Hello World! (on device)\n"; | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         return 0; | ||||||
|  |     } catch (sycl::exception &e) { | ||||||
|  |         std::cout << "SYCL exception: " << e.what() << std::endl; | ||||||
|  |         return 0; // we excpect to fail since no devices should be available; | ||||||
|  |     } | ||||||
|  |   ''; | ||||||
|  | in | ||||||
|  | 
 | ||||||
|  | stdenv.mkDerivation { | ||||||
|  |   version = "0.0.1"; | ||||||
|  |   name = "hello-sycl"; | ||||||
|  |   buildInputs = [ stdenv strace ]; | ||||||
|  |   src = hello_sycl; | ||||||
|  |   dontUnpack = true; | ||||||
|  |   dontConfigure = true; | ||||||
|  |   NIX_DEBUG = 0; | ||||||
|  |   buildPhase = '' | ||||||
|  |     cp $src hello.cpp | ||||||
|  |     set -x | ||||||
|  |     echo CXX=$CXX | ||||||
|  |     command -v $CXX | ||||||
|  |     $CXX -fsycl hello.cpp -o hello | ||||||
|  |     ./hello | ||||||
|  |     set +x | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   installPhase = '' | ||||||
|  |     touch $out | ||||||
|  |   ''; | ||||||
|  | } | ||||||
							
								
								
									
										75
									
								
								test/compilers/icpx-ompss2.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								test/compilers/icpx-ompss2.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | |||||||
|  | { writeText, intelPackages, nodes, nosv, clangOmpss2Nodes, strace }: | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   hello_cpp = writeText "hello.cpp" '' | ||||||
|  |     #include <cstdio> | ||||||
|  |     #include <sycl/sycl.hpp> | ||||||
|  | 
 | ||||||
|  |     int main(int argc, char** argv) try { | ||||||
|  |         sycl::queue queue; | ||||||
|  | 
 | ||||||
|  |         std::cout << "Running on: " | ||||||
|  |                   << queue.get_device().get_info<sycl::info::device::name>() | ||||||
|  |                   << std::endl; | ||||||
|  | 
 | ||||||
|  |         #pragma oss task | ||||||
|  |         queue.submit([&] (sycl::handler& cgh) { | ||||||
|  |             auto os = sycl::stream{128, 128, cgh}; | ||||||
|  |             cgh.single_task<class hello_world>([=]() { | ||||||
|  |                 os << "Hello World! (on device)\n"; | ||||||
|  |             }); | ||||||
|  |         }).wait(); | ||||||
|  | 
 | ||||||
|  |         return 0; | ||||||
|  |     } catch (sycl::exception &e) { | ||||||
|  |         std::cout << "SYCL exception: " << e.what() << std::endl; | ||||||
|  |         return 0; // we expect to fail since no devices should be available; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |   ''; | ||||||
|  | in | ||||||
|  | 
 | ||||||
|  | intelPackages.stdenv.mkDerivation { | ||||||
|  |   version = "0.0.1"; | ||||||
|  |   name = "hello-syclompss"; | ||||||
|  | 
 | ||||||
|  |   src = hello_cpp; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ | ||||||
|  |     strace | ||||||
|  |     nodes | ||||||
|  |     nosv | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   dontUnpack = true; | ||||||
|  |   dontConfigure = true; | ||||||
|  | 
 | ||||||
|  |   # NODES requires access to /sys/devices to request NUMA information. It will | ||||||
|  |   # fail to run otherwise, so we disable the sandbox for this test. | ||||||
|  |   __noChroot = true; | ||||||
|  | 
 | ||||||
|  |   env.NODES_HOME = nodes; | ||||||
|  | 
 | ||||||
|  |   NIX_DEBUG = 0; | ||||||
|  |   buildPhase = '' | ||||||
|  |     cp $src hello.cpp | ||||||
|  |     set -x | ||||||
|  |     echo CXX=$CXX | ||||||
|  |     echo NODES_HOME=$NODES_HOME | ||||||
|  |     command -v $CXX | ||||||
|  | 
 | ||||||
|  |     icpx -Wno-deprecated-declarations -fsycl \ | ||||||
|  |         -fsycl-host-compiler=${clangOmpss2Nodes.forIcpx}/bin/clang++ \ | ||||||
|  |         -fsycl-host-compiler-options='-Wno-deprecated-declarations -fompss-2=libnodes' \ | ||||||
|  |         -lnodes -lnosv \ | ||||||
|  |         $NODES_HOME/lib/nodes-main-wrapper.o \ | ||||||
|  |         hello.cpp -o hello | ||||||
|  | 
 | ||||||
|  |     ./hello | ||||||
|  |     set +x | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   installPhase = '' | ||||||
|  |     touch $out | ||||||
|  |   ''; | ||||||
|  | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user