[TAU package] Update with +rocprofv2. Updated some tests. (#43937)

* [TAU package] Update with +rocprofv2. Updated some tests.

pdated with +rocprofv2 flag. Only works with rocm-core >= 6.0.0

Can be tested with (Omnia):
spack install tau@master +rocm+rocprofv2 %gcc@11
Needs the last commit in our local repository, can be done by modifying the "git = " line, or waiting until the public one is updated.


In the case that tests cause issues when building TAU, there is the flag:
disable_tests = False

The rocm test is disabled by default, as the PR regarding tests loading dependencies is not solved (PR#43682).

* [@spackbot] updating style on behalf of jordialcaraz

---------

Co-authored-by: jordialcaraz <jordialcaraz@users.noreply.github.com>
This commit is contained in:
jalcaraz 2024-05-03 17:33:13 +02:00 committed by GitHub
parent c1cea9d304
commit 4ec788ca12
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -85,6 +85,7 @@ class Tau(Package):
variant("level_zero", default=False, description="Activates Intel OneAPI Level Zero support")
variant("rocprofiler", default=False, description="Activates ROCm rocprofiler support")
variant("roctracer", default=False, description="Activates ROCm roctracer support")
variant("rocprofv2", default=False, description="Activates ROCm rocprofiler support")
variant("opencl", default=False, description="Activates OpenCL support")
variant("fortran", default=darwin_default, description="Activates Fortran support")
variant("io", default=True, description="Activates POSIX I/O support")
@ -140,6 +141,7 @@ class Tau(Package):
depends_on("sqlite", when="+sqlite")
depends_on("hwloc")
depends_on("rocprofiler-dev", when="+rocprofiler")
depends_on("rocprofiler-dev@6.0.0:", when="@2.34: +rocprofv2")
depends_on("roctracer-dev", when="+roctracer")
depends_on("hsa-rocr-dev", when="+rocm")
depends_on("rocm-smi-lib", when="@2.32.1: +rocm")
@ -161,15 +163,18 @@ class Tau(Package):
patch("unwind.patch", when="@2.29.0")
conflicts("+rocprofiler", when="+roctracer", msg="Use either rocprofiler or roctracer")
conflicts("+rocprofv2", when="+rocprofiler", msg="Rocprofv2 does not need rocprofiler")
conflicts("+rocprofv2", when="+roctracer", msg="Rocprofv2 does not need roctracer")
requires("+rocm", when="+rocprofiler", msg="Rocprofiler requires ROCm")
requires("+rocm", when="+roctracer", msg="Roctracer requires ROCm")
requires(
"+rocprofiler",
"+roctracer",
"+rocprofv2",
policy="one_of",
when="+rocm",
msg="When using ROCm, you need to select either +rocprofiler or +roctracer",
msg="Using ROCm, select either +rocprofiler, +roctracer or +rocprofv2",
)
filter_compiler_wrappers("Makefile", relative_root="include")
@ -344,6 +349,10 @@ def install(self, spec, prefix):
if spec.satisfies("@2.34:"):
options.append("-hip=%s" % spec["hip"].prefix)
if "+rocprofv2" in spec:
options.append("-rocprofiler=%s" % spec["rocprofiler-dev"].prefix)
options.append("-rocprofv2")
if "+adios2" in spec:
options.append("-adios=%s" % spec["adios2"].prefix)
@ -442,9 +451,9 @@ def setup_run_environment(self, env):
syscall_test = join_path("examples", "syscall")
ompt_test = join_path("examples", "openmp", "c++")
python_test = join_path("examples", "python")
disable_tests = False
# Disabled, see PR#43682 comments
# @run_after("install")
@run_after("install")
def setup_build_tests(self):
"""Copy the build test files after the package is installed to an
install test subdirectory for use during `spack test run`."""
@ -466,157 +475,106 @@ def setup_build_tests(self):
if "+python" in self.spec:
self.cache_extra_test_sources(self.python_test)
def _run_dyninst_test(self, test_dir):
dyn_dir = join_path(test_dir, self.dyninst_test)
flags = "serial"
def _run_python_test(self, test_name, purpose, work_dir):
tau_python = which(self.prefix.bin.tau_python)
tau_py_inter = "-tau-python-interpreter=" + self.spec["python"].prefix.bin.python
pprof = which(self.prefix.bin.pprof)
with test_part(self, f"{test_name}", purpose, work_dir):
if "+mpi" in self.spec:
flags = "mpi"
self.run_test("make", ["all"], [], 0, False, "Build example code", False, dyn_dir)
self.run_test(
"tau_run",
["-T", flags, "./klargest", "-v", "-o", "./klargest.i"],
[],
0,
False,
"Instrument code with dyninst",
False,
dyn_dir,
)
self.run_test(
"./klargest.i", [], [], 0, False, "Execute instrumented code", False, dyn_dir
)
self.run_test(
"pprof",
[],
[],
0,
False,
"Run pprof profile analysis tool on profile output",
False,
dyn_dir,
flag = "mpi"
mpirun = which(self.spec["mpi"].prefix.bin.mpirun)
mpirun(
"-np",
"4",
self.prefix.bin.tau_python,
tau_py_inter,
"-T",
flag,
"firstprime.py",
)
else:
flag = "serial"
tau_python(tau_py_inter, "-T", flag, "firstprime.py")
pprof()
def _run_tau_test(
self, main_test_dir, test_dir, test_name, test_exe, tau_exec_flags=[], use_tau_exec=False
):
inst_test_dir = join_path(main_test_dir, test_dir)
print(inst_test_dir)
test_description = "Build {} test code".format(test_name)
self.run_test("make", ["all"], [], 0, False, test_description, False, inst_test_dir)
def _run_default_test(self, test_name, purpose, work_dir):
tau_exec = which(self.prefix.bin.tau_exec)
pprof = which(self.prefix.bin.pprof)
with test_part(self, f"{test_name}", purpose, work_dir):
make("all")
if "+mpi" in self.spec:
if use_tau_exec:
test_args = ["-n", "4", "tau_exec", "-T", "mpi"] + tau_exec_flags
flags = ["-T", "mpi"]
mpirun = which(self.spec["mpi"].prefix.bin.mpirun)
mpirun("-np", "4", self.prefix.bin.tau_exec, *flags, "./matmult")
else:
test_args = ["-n", "4"] + tau_exec_flags
test_args.append(test_exe)
mpiexe_list = ["mpirun", "mpiexec", "srun"]
for mpiexe in mpiexe_list:
if which(mpiexe) is not None:
test_description = "Run {} test with mpi".format(test_name)
self.run_test(
mpiexe, test_args, [], 0, False, test_description, False, inst_test_dir
)
break
else:
if use_tau_exec:
test_app = "tau_exec"
test_args = ["-T", "serial"] + tau_exec_flags
test_args.append(test_exe)
else:
test_app = test_exe
test_args = []
test_description = "Run sequential {} test".format(test_name)
self.run_test(
test_app, test_args, [], 0, False, test_description, False, inst_test_dir
)
self.run_test(
"pprof",
[],
[],
0,
False,
"Run pprof profile analysis tool on profile output",
False,
inst_test_dir,
)
flags = ["-T", "serial"]
tau_exec(*flags, "./matmult")
pprof()
def _run_python_test(self, test_dir):
python_dir = join_path(test_dir, self.python_test)
flags = "serial"
def _run_ompt_test(self, test_name, purpose, work_dir):
tau_exec = which(self.prefix.bin.tau_exec)
pprof = which(self.prefix.bin.pprof)
with test_part(self, f"{test_name}", purpose, work_dir):
make("all")
if "+mpi" in self.spec:
flags = "mpi"
self.run_test(
"tau_python",
["-T", flags, "firstprime.py"],
[],
0,
False,
"Pyhon example",
False,
python_dir,
)
self.run_test(
"pprof",
[],
[],
0,
False,
"Run pprof profile analysis tool on profile output",
False,
python_dir,
)
flags = ["-T", "mpi", "-ompt"]
mpirun = which(self.spec["mpi"].prefix.bin.mpirun)
mpirun("-np", "4", self.prefix.bin.tau_exec, *flags, "./mandel")
else:
flags = ["-T", "serial", "-ompt"]
tau_exec(*flags, "./mandel")
pprof()
def test(self):
# Temporarily disable tests, will update them with the new test method.
def _run_rocm_test(self, test_name, purpose, work_dir):
tau_exec = which(self.prefix.bin.tau_exec)
pprof = which(self.prefix.bin.pprof)
with test_part(self, f"{test_name}", purpose, work_dir):
make("all")
if "+mpi" in self.spec:
flags = ["-T", "mpi", "-rocm"]
mpirun = which(self.spec["mpi"].prefix.bin.mpirun)
mpirun("-np", "4", self.prefix.bin.tau_exec, *flags, "./gpu-stream-hip")
else:
flags = ["-T", "serial", "-rocm"]
tau_exec(*flags, "./gpu-stream-hip")
pprof()
def test_python(self):
"""test python variant"""
if self.disable_tests:
return
test_dir = self.test_suite.current_test_cache_dir
# Run mm test program pulled from the build
if "+ompt" in self.spec:
tau_exec_flags = ["-ompt"]
self._run_tau_test(test_dir, self.ompt_test, "OMPT example", "mandel", tau_exec_flags)
else:
self._run_tau_test(test_dir, self.matmult_test, "matrix multiplication", "matmult")
if "+dyninst" in self.spec:
self._run_dyninst_test(test_dir)
if "+python" in self.spec:
self._run_python_test(test_dir)
if "+cuda" in self.spec:
tau_exec_flags = ["-cupti"]
self._run_tau_test(
test_dir,
self.cuda_test,
"CUDA example",
"dataElem_um",
tau_exec_flags,
use_tau_exec=True,
)
if "+level_zero" in self.spec:
tau_exec_flags = ["-l0"]
self._run_tau_test(
test_dir,
self.level_zero_test,
"Level Zero example",
"complex_mult.exe",
tau_exec_flags,
use_tau_exec=True,
)
if "+rocm" in self.spec and ("+rocprofiler" in self.spec or "+roctracer" in self.spec):
tau_exec_flags = ["-rocm"]
self._run_tau_test(
test_dir,
self.rocm_test,
"Rocm example",
"vectoradd_hip.exe",
tau_exec_flags,
use_tau_exec=True,
)
if "+syscall" in self.spec:
tau_exec_flags = ["-syscall"]
self._run_tau_test(
test_dir,
self.syscall_test,
"Syscall example",
"syscall_test",
tau_exec_flags,
use_tau_exec=True,
)
# current_test_cache_dir.examples.python
python_test_dir = join_path(self.test_suite.current_test_cache_dir, self.python_test)
self._run_python_test("test_tau_python", "Testing tau_python", python_test_dir)
def test_default(self):
"""default matmult test"""
if self.disable_tests:
return
if "+ompt" in self.spec:
return
default_test_dir = join_path(self.test_suite.current_test_cache_dir, self.matmult_test)
self._run_default_test("test_default", "Testing TAU", default_test_dir)
def test_ompt(self):
"""ompt test"""
if self.disable_tests:
return
if "+ompt" in self.spec:
ompt_test_dir = join_path(self.test_suite.current_test_cache_dir, self.ompt_test)
self._run_ompt_test("test_ompt", "Testing ompt", ompt_test_dir)
def test_rocm(self):
"""rocm test"""
# Disabled, see PR#43682
# make is unable to find rocm_agent_enumerator
# when testing, with spack load, there is no issue
return
if self.disable_tests:
return
if "+rocm" in self.spec and (
"+rocprofiler" in self.spec or "+roctracer" in self.spec or "+rocprofv2" in self.spec
):
rocm_test_dir = join_path(self.test_suite.current_test_cache_dir, self.rocm_test)
self._run_rocm_test("test_rocm", "Testing rocm", rocm_test_dir)