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": { | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1736867362, | ||||
|         "narHash": "sha256-i/UJ5I7HoqmFMwZEH6vAvBxOrjjOJNU739lnZnhUln8=", | ||||
|         "path": "/nix/store/2csx2kkb2hxyxhhmg2xs9jfyypikwwk6-source", | ||||
|         "rev": "9c6b49aeac36e2ed73a8c472f1546f6d9cf1addc", | ||||
|         "lastModified": 1752436162, | ||||
|         "narHash": "sha256-Kt1UIPi7kZqkSc5HVj6UY5YLHHEzPBkgpNUByuyxtlw=", | ||||
|         "path": "/nix/store/zk8v61cpk1wprp9ld5ayc1g5fq4pdkwv-source", | ||||
|         "rev": "dfcd5b901dbab46c9c6e80b265648481aafb01f8", | ||||
|         "type": "path" | ||||
|       }, | ||||
|       "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; }; | ||||
|     clangOmpss2Unwrapped = callPackage ./pkgs/llvm-ompss2/clang.nix { }; | ||||
|     #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_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 { }; | ||||
|     lmbench = callPackage ./pkgs/lmbench/default.nix { }; | ||||
|     mcxx = callPackage ./pkgs/mcxx/default.nix { }; | ||||
| @ -44,8 +49,10 @@ let | ||||
|     stdenvClangOmpss2Nanos6 = final.stdenv.override { cc = final.clangOmpss2Nanos6; allowedRequisites = null; }; | ||||
|     stdenvClangOmpss2Nodes = final.stdenv.override { cc = final.clangOmpss2Nodes; 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 { }; | ||||
|     tasycl = callPackage ./pkgs/tasycl/default.nix { }; | ||||
|     tasycl-acpp = callPackage ./pkgs/tasycl/default.nix { useIntel = false; }; | ||||
|     wxparaver = callPackage ./pkgs/paraver/default.nix { }; | ||||
|   }; | ||||
| 
 | ||||
| @ -60,6 +67,8 @@ in bscPkgs // { | ||||
|       #sigsegv = callPackage ./test/reproducers/sigsegv.nix { }; | ||||
|       hello-c = callPackage ./test/compilers/hello-c.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 { }; | ||||
|       asan = callPackage ./test/compilers/asan.nix { }; | ||||
|       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 { | ||||
|         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-asan  = asan.override      { stdenv = final.stdenvClangOmpss2Nanos6; }; | ||||
|       clangOmpss2-task  = callPackage ./test/compilers/ompss2.nix { | ||||
|  | ||||
| @ -1,14 +1,20 @@ | ||||
| { | ||||
|   stdenv | ||||
| , bigotes | ||||
| , cmake | ||||
| , clangOmpss2 | ||||
| , openmp | ||||
| , openmpv | ||||
| , nanos6 | ||||
| , nodes | ||||
| , nosv | ||||
| , mpi | ||||
| , tampi | ||||
| , openblas | ||||
| , ovni | ||||
| , gitBranch ? "master" | ||||
| , gitURL ? "ssh://git@bscpm04.bsc.es/rarias/bench6.git" | ||||
| , gitCommit ? "1e6ce2aa8ad7b4eef38df1581d7ec48a8815f85d" | ||||
| , gitCommit ? "bf29a53113737c3aa74d2fe3d55f59868faea7b4" | ||||
| }: | ||||
| 
 | ||||
| stdenv.mkDerivation rec { | ||||
| @ -21,9 +27,28 @@ stdenv.mkDerivation rec { | ||||
|     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 = [ | ||||
|     "-DCMAKE_C_COMPILER=clang" | ||||
|     "-DCMAKE_CXX_COMPILER=clang++" | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| { stdenv | ||||
| , fetchurl | ||||
| , ncurses | ||||
| , lib | ||||
| , dpkg | ||||
| , rsync | ||||
| @ -10,12 +9,9 @@ | ||||
| , hwloc | ||||
| , zlib | ||||
| , autoPatchelfHook | ||||
| , symlinkJoin | ||||
| , libfabric | ||||
| , gcc | ||||
| , gcc7 | ||||
| , gcc13 | ||||
| , wrapCCWith | ||||
| , linuxHeaders | ||||
| }: | ||||
| 
 | ||||
| # The distribution of intel packages is a mess. We are doing the installation | ||||
| @ -30,6 +26,8 @@ | ||||
| 
 | ||||
| let | ||||
| 
 | ||||
|   gcc = gcc13; | ||||
| 
 | ||||
|   v = { | ||||
|     hpckit   = "2023.1.0"; | ||||
|     compiler = "2023.1.0"; | ||||
| @ -47,40 +45,31 @@ let | ||||
|     installPhase = '' | ||||
|       awk -F': ' '\ | ||||
|         BEGIN   { print "[ {" } \ | ||||
|         NR>1 && /^Package: / { print "} {"; } \ | ||||
|         NF==0 { empty=1; } \ | ||||
|         NF && empty { print "} {"; empty=0; } \ | ||||
|         /: /    { printf "%s = \"%s\";\n", $1, $2 } \ | ||||
|         END     { print "} ]" }' $srcs > $out | ||||
|     ''; | ||||
|   }; | ||||
| 
 | ||||
|   findMatch = name: | ||||
|   let | ||||
|     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/"; | ||||
| 
 | ||||
|   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 | ||||
|     match.SHA256; | ||||
| 
 | ||||
|   getUrl = pkgList: name: | ||||
|   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; | ||||
|     { | ||||
|       url = apthost + match.Filename; | ||||
|       sha256 = match.SHA256; | ||||
|     }; | ||||
| 
 | ||||
|   uncompressDebs = debs: name: stdenv.mkDerivation { | ||||
|     name = name; | ||||
|     srcs = debs; | ||||
|     buildInputs = [ dpkg ]; | ||||
|     nativeBuildInputs = [ dpkg ]; | ||||
|     phases = [ "installPhase" ]; | ||||
|     installPhase = '' | ||||
|       mkdir -p $out | ||||
| @ -93,10 +82,7 @@ let | ||||
| 
 | ||||
|   joinDebs = name: names: | ||||
|   let | ||||
|     urls = builtins.map (x: getUrl aptPackages x) names; | ||||
|     sums = builtins.map (x: getSum aptPackages x) names; | ||||
|     getsrc = url: sha256: builtins.fetchurl { inherit url sha256; }; | ||||
|     debs = lib.zipListsWith getsrc urls sums; | ||||
|     debs = builtins.map (x: builtins.fetchurl (findMatch x)) names; | ||||
|   in | ||||
|     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-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: | ||||
|     # - 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 | ||||
| @ -329,9 +319,9 @@ let | ||||
|     # - 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-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-runtime-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-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-openmp-2023.0.0-2023.0.0-25370_amd64.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${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 | ||||
|         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 | ||||
|         echo "" > $out/nix-support/add-hardening.sh | ||||
| @ -441,7 +442,7 @@ let | ||||
|     ''; | ||||
|   }; | ||||
| 
 | ||||
|   ifort-wrapper = wrapIntel rec { | ||||
|   ifort-wrapper = wrapIntel { | ||||
|     cc = intel-compiler-fortran; | ||||
|     mygcc = gcc; | ||||
|     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-all/Packages -o all-packages | ||||
| 
 | ||||
| cat amd64-packages all-packages | ./toJson.awk | ./process.jq >packages.json | ||||
|  | ||||
| @ -16,19 +16,19 @@ | ||||
| , useGit ? false | ||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/llvm-ompss/llvm-mono.git" | ||||
| , gitBranch ? "master" | ||||
| , gitCommit ? "8c0d267c04d7fc3fb923078f510fcd5f4719a6cc" | ||||
| , gitCommit ? "880e2341c56bad1dc14e8c369fb3356bec19018e" | ||||
| }: | ||||
| 
 | ||||
| let | ||||
|   stdenv = llvmPackages_latest.stdenv; | ||||
| 
 | ||||
|   release = rec { | ||||
|     version = "2024.11"; | ||||
|     version = "2025.06"; | ||||
|     src = fetchFromGitHub { | ||||
|       owner = "bsc-pm"; | ||||
|       repo = "llvm"; | ||||
|       rev = "refs/tags/github-release-${version}"; | ||||
|       hash = "sha256-pF0qa987nLkIJPUrXh1srzBkLPfb31skIegD0bl34Kg="; | ||||
|       hash = "sha256-ww9PpRmtz/M9IyLiZ8rAehx2UW4VpQt+svf4XfKBzKo="; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|  | ||||
| @ -3,6 +3,7 @@ | ||||
| , lib | ||||
| , gcc | ||||
| , clangOmpss2Unwrapped | ||||
| , writeShellScript | ||||
| , openmp ? null | ||||
| , wrapCCWith | ||||
| , llvmPackages_latest | ||||
| @ -37,16 +38,16 @@ let | ||||
|   inherit gcc; | ||||
|   cc = clangOmpss2Unwrapped; | ||||
|   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 = '' | ||||
|     echo "-target ${targetConfig}" >> $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}/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 | ||||
|       echo "-isystem $dir" >> $out/nix-support/libcxx-cxxflags | ||||
|     done | ||||
| @ -57,8 +58,9 @@ in wrapCCWith { | ||||
|     echo "--gcc-toolchain=${gcc}" >> $out/nix-support/cc-cflags | ||||
| 
 | ||||
|     wrap clang++  $wrapper $ccPath/clang++ | ||||
|   ''; | ||||
| 
 | ||||
|   '' + optionalString (openmp != null) '' | ||||
|   envExports = lib.optionalString (openmp != null) '' | ||||
|       echo "export OPENMP_RUNTIME=${ompname}" >> $out/nix-support/cc-wrapper-hook | ||||
|     '' + optionalString (ompss2rt != null) '' | ||||
|       echo "export OMPSS2_RUNTIME=${rtname}" >> $out/nix-support/cc-wrapper-hook | ||||
| @ -66,5 +68,40 @@ in wrapCCWith { | ||||
|     '' + optionalString (ompss2rt != null && ompss2rt.pname == "nodes") '' | ||||
|       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="; | ||||
|   }; | ||||
| 
 | ||||
|   postUnpack = '' | ||||
|     export sourceRoot="$sourceRoot/src" | ||||
|   ''; | ||||
| 
 | ||||
|   postPatch = '' | ||||
|     sed -i "s@/bin/rm@rm@g" $(find . -name Makefile) | ||||
|   ''; | ||||
| 
 | ||||
|   buildInputs = [ libtirpc ]; | ||||
|   patches = [ ./fix-install.patch ]; | ||||
|   patches = [ ./fix-install.patch ./gcc-14.patch ]; | ||||
| 
 | ||||
|   hardeningDisable = [ "all" ]; | ||||
| 
 | ||||
| @ -34,7 +30,9 @@ stdenv.mkDerivation rec { | ||||
| 
 | ||||
|   preBuild = '' | ||||
|     makeFlagsArray+=( | ||||
|       -C src | ||||
|       BASE=$out | ||||
|       CFLAGS=-Wno-implicit-int | ||||
|       CPPFLAGS=-I${libtirpc.dev}/include/tirpc | ||||
|       LDFLAGS=-ltirpc | ||||
|     ) | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| --- a/Makefile
 | ||||
| +++ b/Makefile
 | ||||
| --- a/src/Makefile
 | ||||
| +++ b/src/Makefile
 | ||||
| @@ -144,6 +144,7 @@ install-target:
 | ||||
|  	if [ ! -d $(BASE)/include ]; then mkdir $(BASE)/include; 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 | ||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/nanos6/nanos6" | ||||
| , gitBranch ? "master" | ||||
| , gitCommit ? "9f54c988e0a8b9c011d9d526acdb8d76f18fcae4" | ||||
| , gitCommit ? "f82762b66c82b5174a8eaad33f6c2f335ac759b4" | ||||
| }: | ||||
| 
 | ||||
| assert enableJemalloc -> (jemallocNanos6 != null); | ||||
| @ -28,12 +28,12 @@ with lib; | ||||
| 
 | ||||
| let | ||||
|   release = rec { | ||||
|     version = "4.2"; | ||||
|     version = "4.3"; | ||||
|     src = fetchFromGitHub { | ||||
|       owner = "bsc-pm"; | ||||
|       repo = "nanos6"; | ||||
|       rev = "version-${version}"; | ||||
|       hash = "sha256-tBrRGLCjSFYdmVGPAC2DzYY6HJyZGUOMeykujafn7+4="; | ||||
|       hash = "sha256-/c6WiKBsAo/01uvMRmjv0PMucbrgvaGmbxlPE6q+dfE="; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|  | ||||
| @ -11,19 +11,19 @@ | ||||
| , useGit ? false | ||||
| , gitUrl ? "git@gitlab-internal.bsc.es:nos-v/nos-v.git" | ||||
| , gitBranch ? "master" | ||||
| , gitCommit ? "cfd361bd1dd30c96da405e6bbaa7e78f5f93dfda" | ||||
| , gitCommit ? "9f47063873c3aa9d6a47482a82c5000a8c813dd8" | ||||
| }: | ||||
| 
 | ||||
| with lib; | ||||
| 
 | ||||
| let | ||||
|   release = rec { | ||||
|     version = "3.1.0"; | ||||
|     version = "3.2.0"; | ||||
|     src = fetchFromGitHub { | ||||
|       owner = "bsc-pm"; | ||||
|       repo = "nos-v"; | ||||
|       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 | ||||
| , gitBranch ? "master" | ||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/rarias/ovni.git" | ||||
| , gitCommit ? "a7103f8510d1ec124c3e01ceb47d1e443e98bbf4" | ||||
| , gitCommit ? "e4f62382076f0cf0b1d08175cf57cc0bc51abc61" | ||||
| , enableDebug ? false | ||||
| # Only enable MPI if the build is native (fails on cross-compilation) | ||||
| , useMpi ? (stdenv.buildPlatform.canExecute stdenv.hostPlatform) | ||||
| @ -17,13 +17,13 @@ with lib; | ||||
| 
 | ||||
| let | ||||
|   release = rec { | ||||
|     version = "1.11.0"; | ||||
|     version = "1.12.0"; | ||||
|     src = fetchFromGitHub { | ||||
|       owner = "bsc-pm"; | ||||
|       repo = "ovni"; | ||||
|       rev = "${version}"; | ||||
|       hash = "sha256-DEZUK1dvbPGH5WYkZ2hpP5PShkMxXkHOqMwgYUHHxeM="; | ||||
|     } // { shortRev = "a7103f8"; }; | ||||
|       hash = "sha256-H04JvsVKrdqr3ON7JhU0g17jjlg/jzQ7eTfx9vUNd3E="; | ||||
|     } // { shortRev = "a73afcf"; }; | ||||
|   }; | ||||
| 
 | ||||
|   git = rec { | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| { | ||||
|   stdenv | ||||
| , autoreconfHook | ||||
| , boost | ||||
| , boost186 | ||||
| , libxml2 | ||||
| , xml2 | ||||
| , wxGTK32 | ||||
| @ -15,6 +15,7 @@ | ||||
| 
 | ||||
| let | ||||
|   wx = wxGTK32; | ||||
|   boost = boost186; | ||||
| in | ||||
| stdenv.mkDerivation rec { | ||||
|   pname = "wxparaver"; | ||||
|  | ||||
| @ -15,7 +15,7 @@ | ||||
| , useGit ? false | ||||
| , gitUrl ? "ssh://git@bscpm04.bsc.es/interoperability/tampi.git" | ||||
| , gitBranch ? "master" | ||||
| , gitCommit ? "a5c93bf8ab045b71ad4a8d5e2c991ce774db5cbc" | ||||
| , gitCommit ? "f6455db9d3124ae36e715a4874fd49720e79f20a" | ||||
| }: | ||||
| 
 | ||||
| with lib; | ||||
| @ -24,12 +24,12 @@ assert enableOvni -> (ovni != null); | ||||
| 
 | ||||
| let | ||||
|   release = rec { | ||||
|     version = "4.0"; | ||||
|     version = "4.1"; | ||||
|     src = fetchFromGitHub { | ||||
|       owner = "bsc-pm"; | ||||
|       repo = "tampi"; | ||||
|       rev = "v${version}"; | ||||
|       hash = "sha256-R7ew5tsrxGReTvOeeZe1FD0oThBhOHoDGv6Mo2sbmDg="; | ||||
|       hash = "sha256-SwfPSnwcZnRnSgNvCD5sFSUJRpWINqI5I4adj5Hh+XY="; | ||||
|     }; | ||||
|   }; | ||||
|   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