forked from rarias/bscpkgs
		
	Add build for tasycl with adaptivecpp
This commit is contained in:
		
							parent
							
								
									812d71beb1
								
							
						
					
					
						commit
						d974fbee05
					
				| @ -48,6 +48,7 @@ let | |||||||
|     tagaspi = callPackage ./pkgs/tagaspi/default.nix { }; |     tagaspi = callPackage ./pkgs/tagaspi/default.nix { }; | ||||||
|     tampi = callPackage ./pkgs/tampi/default.nix { }; |     tampi = callPackage ./pkgs/tampi/default.nix { }; | ||||||
|     tasycl = callPackage ./pkgs/tasycl/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 { }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,4 +1,7 @@ | |||||||
| { intelPackages | { stdenv | ||||||
|  | , lib | ||||||
|  | , withCFlags | ||||||
|  | , intelPackages | ||||||
| , fetchFromGitHub | , fetchFromGitHub | ||||||
| , automake | , automake | ||||||
| , autoconf | , autoconf | ||||||
| @ -6,18 +9,68 @@ | |||||||
| , gnumake | , gnumake | ||||||
| , autoreconfHook | , autoreconfHook | ||||||
| , boost | , boost | ||||||
|  | , opensycl ? null | ||||||
|  | , adaptivecpp ? null | ||||||
|  | , useIntel ? true | ||||||
|  |   # TODO: move back to main branch and release | ||||||
|  | , useGit ? true | ||||||
|  | , gitUrl ? "git@gitlab-internal.bsc.es:task-awareness/tasycl/tasycl.git" | ||||||
|  | , gitBranch ? "fix/various" | ||||||
|  | , gitCommit ? "8be4729ded0ef64f028e98eb2b2baf2ccba7ff42" | ||||||
| }: | }: | ||||||
| 
 | 
 | ||||||
| intelPackages.stdenv.mkDerivation rec { | assert (useIntel || opensycl != null || adaptivecpp != null); | ||||||
|   pname = "tasycl"; |  | ||||||
|   version = "2.0.0"; |  | ||||||
| 
 | 
 | ||||||
|  | let | ||||||
|  |   # opensycl has migrated to adaptivecpp | ||||||
|  |   acpp-flags = | ||||||
|  |     if adaptivecpp == null then | ||||||
|  |       [ "-L${opensycl}/lib" "-lhipSYCL-rt" "-I${opensycl}/include" ] | ||||||
|  |     else | ||||||
|  |       [ "-L${adaptivecpp}/lib" "-lacpp-rt" "-I${adaptivecpp}/include" ] | ||||||
|  |   ; | ||||||
|  | 
 | ||||||
|  |   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 acpp-flags stdenv | ||||||
|  |   ; | ||||||
|  | 
 | ||||||
|  |   release = rec { | ||||||
|  |     version = "2.0.0"; | ||||||
|     src = fetchFromGitHub { |     src = fetchFromGitHub { | ||||||
|       owner = "bsc-pm"; |       owner = "bsc-pm"; | ||||||
|       repo = "tasycl"; |       repo = "tasycl"; | ||||||
|       rev = version; |       rev = version; | ||||||
|       hash = "sha256-Z4d45baVBhE9NW8Ww948M78TJx7BpxTr9pGJvJO9hdI="; |       hash = "sha256-Z4d45baVBhE9NW8Ww948M78TJx7BpxTr9pGJvJO9hdI="; | ||||||
|     }; |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   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; |   enableParallelBuilding = true; | ||||||
|   separateDebugInfo = true; |   separateDebugInfo = true; | ||||||
| @ -34,7 +87,17 @@ intelPackages.stdenv.mkDerivation rec { | |||||||
|     boost |     boost | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|   configureFlags = [ "--with-sycl-include=${intelPackages.icx.cc}/include/sycl" ]; |   # 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" ]; |   hardeningDisable = [ "all" ]; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user