gpu-burn: add v1.1 and "master" (#22778)
This commit is contained in:
parent
1c0230f7d0
commit
6e48e29c75
2 changed files with 18 additions and 43 deletions
|
@ -1,18 +0,0 @@
|
|||
--- a/Makefile 2018-12-08 05:36:48.000000000 -0600
|
||||
+++ b/Makefile 2019-10-04 13:08:37.095337704 -0500
|
||||
@@ -1,12 +1,6 @@
|
||||
-CUDAPATH=/usr/local/cuda
|
||||
-
|
||||
-# Have this point to an old enough gcc (for nvcc)
|
||||
-GCCPATH=/usr
|
||||
-
|
||||
NVCC=nvcc
|
||||
-CCPATH=${GCCPATH}/bin
|
||||
|
||||
drv:
|
||||
- PATH=${PATH}:.:${CCPATH}:${PATH} ${NVCC} -I${CUDAPATH}/include -arch=compute_30 -ptx compare.cu -o compare.ptx
|
||||
- g++ -O3 -Wno-unused-result -I${CUDAPATH}/include -c gpu_burn-drv.cpp
|
||||
- g++ -o gpu_burn gpu_burn-drv.o -O3 -lcuda -L${CUDAPATH}/lib64 -L${CUDAPATH}/lib -Wl,-rpath=${CUDAPATH}/lib64 -Wl,-rpath=${CUDAPATH}/lib -lcublas -lcudart -o gpu_burn
|
||||
+ ${NVCC} -arch=compute_30 -ptx compare.cu -o compare.ptx
|
||||
+ $(CXX) -O3 -Wno-unused-result -c gpu_burn-drv.cpp
|
||||
+ $(CXX) -o gpu_burn gpu_burn-drv.o -O3 -lcuda -lcublas -lcudart -o gpu_burn
|
|
@ -3,21 +3,18 @@
|
|||
#
|
||||
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
|
||||
|
||||
from spack import *
|
||||
|
||||
|
||||
class GpuBurn(MakefilePackage, CudaPackage):
|
||||
"""Multi-GPU CUDA stress test. Note that the file pointed to by COMPARE_PTX
|
||||
needs to be copied or linked to the current working directory before
|
||||
running gpu_burn."""
|
||||
"""Multi-GPU CUDA stress test."""
|
||||
|
||||
homepage = "http://wili.cc/blog/gpu-burn.html"
|
||||
url = "http://wili.cc/blog/entries/gpu-burn/gpu_burn-1.0.tar.gz"
|
||||
git = "https://github.com/wilicc/gpu-burn"
|
||||
|
||||
version('master', branch='master')
|
||||
version('1.1', sha256='9876dbf7ab17b3072e9bc657034ab39bdedb219478f57c4e93314c78ae2d6376')
|
||||
version('1.0', sha256='d55994f0bee8dabf021966dbe574ef52be1e43386faeee91318dd4ebb36aa74a')
|
||||
|
||||
patch('Makefile.patch')
|
||||
|
||||
# This package uses CudaPackage to pick up the cuda_arch variant. A side
|
||||
# effect is that it also picks up the cuda variant, but cuda is required
|
||||
# for gpu-burn so is not really a variant.
|
||||
|
@ -26,31 +23,27 @@ class GpuBurn(MakefilePackage, CudaPackage):
|
|||
conflicts('~cuda', msg='gpu-burn requires cuda')
|
||||
conflicts('cuda_arch=none', msg='must select a CUDA architecture')
|
||||
|
||||
cuda_arch_values = CudaPackage.cuda_arch_values
|
||||
variant(
|
||||
'cuda_arch',
|
||||
description='CUDA architecture',
|
||||
default='none',
|
||||
values=('none',) + cuda_arch_values,
|
||||
multi=False
|
||||
)
|
||||
|
||||
def edit(self, spec, prefix):
|
||||
# update cuda architecture if necessary
|
||||
if '+cuda' in self.spec:
|
||||
cuda_arch = self.spec.variants['cuda_arch'].value
|
||||
archflag = '-arch=compute_{0}'.format(cuda_arch)
|
||||
filter_file('-arch=compute_30', archflag,
|
||||
'Makefile', string=True)
|
||||
archflag = " ".join(CudaPackage.cuda_flags(cuda_arch))
|
||||
with open('Makefile', 'w') as fh:
|
||||
fh.write('drv:\n')
|
||||
fh.write('\tnvcc {0} -fatbin '
|
||||
'compare.cu -o compare.ptx\n'.format(archflag))
|
||||
fh.write('\tg++ -O3 -c gpu_burn-drv.cpp\n')
|
||||
fh.write('\tg++ -o gpu_burn gpu_burn-drv.o -O3 -lcuda '
|
||||
'-lcublas -lcudart -o gpu_burn\n')
|
||||
|
||||
filter_file('compare.ptx',
|
||||
join_path(prefix.share,
|
||||
'compare.ptx'),
|
||||
'gpu_burn-drv.cpp',
|
||||
string=True)
|
||||
|
||||
def install(self, spec, prefix):
|
||||
mkdir(prefix.bin)
|
||||
mkdir(prefix.share)
|
||||
install('gpu_burn', prefix.bin)
|
||||
install('compare.ptx', prefix.share)
|
||||
|
||||
# The gpu_burn program looks for the compare.ptx file in the current
|
||||
# working directory. Create an environment variable that can be pointed to
|
||||
# so that it can be copied or linked.
|
||||
def setup_run_environment(self, env):
|
||||
env.set('COMPARE_PTX', join_path(self.prefix.share, 'compare.ptx'))
|
||||
|
|
Loading…
Reference in a new issue