From 03a54bc34214851ce17aed18ef425b9cefb4cd5d Mon Sep 17 00:00:00 2001 From: thansen-amd Date: Mon, 27 Nov 2023 16:03:10 -0700 Subject: [PATCH 1/2] ASAN Setup and switch to settings map --- .jenkins/asan.groovy | 80 +++++++++++++++++++++++++++++++++ .jenkins/common.groovy | 27 ++++++++--- .jenkins/precheckin-cuda.groovy | 6 ++- .jenkins/staticanalysis.groovy | 6 ++- .jenkins/staticlibrary.groovy | 7 +-- 5 files changed, 112 insertions(+), 14 deletions(-) create mode 100644 .jenkins/asan.groovy diff --git a/.jenkins/asan.groovy b/.jenkins/asan.groovy new file mode 100644 index 0000000..203311b --- /dev/null +++ b/.jenkins/asan.groovy @@ -0,0 +1,80 @@ +#!/usr/bin/env groovy +@Library('rocJenkins@pong') _ +import com.amd.project.* +import com.amd.docker.* +import java.nio.file.Path; + +def runCI = +{ + nodeDetails, jobName-> + + def prj = new rocProject('hipRAND', 'address-sanitizer') + + def nodes = new dockerNodes(nodeDetails, jobName, prj) + + def commonGroovy + + boolean formatCheck = false + + def settings = [addressSanitizer: true] + + def compileCommand = + { + platform, project-> + + commonGroovy = load "${project.paths.project_src_prefix}/.jenkins/common.groovy" + commonGroovy.runCompileCommand(platform, project, jobName, settings) + } + + + def testCommand = + { + platform, project-> + + commonGroovy.runTestCommand(platform, project, settings) + } + + def packageCommand = + { + platform, project-> + + commonGroovy.runPackageCommand(platform, project) + } + + buildProject(prj, formatCheck, nodes.dockerArray, compileCommand, testCommand, packageCommand) +} + +ci: { + String urlJobName = auxiliary.getTopJobName(env.BUILD_URL) + + def propertyList = [] + propertyList = auxiliary.appendPropertyList(propertyList) + + def jobNameList = [:] + jobNameList = auxiliary.appendJobNameList(jobNameList) + + propertyList.each + { + jobName, property-> + if (urlJobName == jobName) + properties(auxiliary.addCommonProperties(property)) + } + + jobNameList.each + { + jobName, nodeDetails-> + if (urlJobName == jobName) + stage(jobName) { + runCI(nodeDetails, jobName) + } + } + + // For url job names that are not listed by the jobNameList i.e. compute-rocm-dkms-no-npi-1901 + if(!jobNameList.keySet().contains(urlJobName)) + { + properties(auxiliary.addCommonProperties([pipelineTriggers([cron('0 1 * * 6')])])) + stage(urlJobName) { + runCI(['ubuntu20-cuda11':['anycuda']], urlJobName) + } + } +} \ No newline at end of file diff --git a/.jenkins/common.groovy b/.jenkins/common.groovy index 049cfc3..bd1c8bc 100644 --- a/.jenkins/common.groovy +++ b/.jenkins/common.groovy @@ -1,10 +1,12 @@ // This file is for internal AMD use. // If you are interested in running your own Jenkins, please raise a github issue for assistance. -def runCompileCommand(platform, project, jobName, boolean debug=false, boolean staticLibrary=false, boolean sameOrg=false) +def runCompileCommand(platform, project, jobName, settings) { project.paths.construct_build_prefix() + boolean sameOrg = settings.sameOrg ?: false + def getDependenciesCommand = "" if (project.installLibraryDependenciesFromCI) { @@ -16,13 +18,14 @@ def runCompileCommand(platform, project, jobName, boolean debug=false, boolean s } project.paths.build_command = './install -c' - String buildTypeArg = debug ? '-DCMAKE_BUILD_TYPE=Debug' : '-DCMAKE_BUILD_TYPE=Release' - String buildTypeDir = debug ? 'debug' : 'release' - String buildStatic = staticLibrary ? '-DBUILD_STATIC_LIBS=ON' : '-DBUILD_SHARED=OFF' + String buildTypeArg = settings.debug ? '-DCMAKE_BUILD_TYPE=Debug' : '-DCMAKE_BUILD_TYPE=Release' + String buildTypeDir = settings.debug ? 'debug' : 'release' + String buildStatic = settings.staticLibrary ? '-DBUILD_STATIC_LIBS=ON' : '-DBUILD_SHARED=OFF' String cmake = platform.jenkinsLabel.contains('centos') ? 'cmake3' : 'cmake' //Set CI node's gfx arch as target if PR, otherwise use default targets of the library String amdgpuTargets = env.BRANCH_NAME.startsWith('PR-') ? '-DAMDGPU_TARGETS=\$gfx_arch' : '' String compiler = '/opt/rocm/bin/hipcc' + String asanFlag = settings.addressSanitizer ? '-DBUILD_ADDRESS_SANITIZER=ON' : '' String useCUDA = '' if (platform.jenkinsLabel.contains('cuda')) { @@ -39,25 +42,35 @@ def runCompileCommand(platform, project, jobName, boolean debug=false, boolean s # gfxTargetParser reads gfxarch and adds target features such as xnack ${auxiliary.gfxTargetParser()} echo "ROCM_PATH = \${ROCM_PATH}" - ${cmake} -DCMAKE_CXX_COMPILER=${compiler} ${useCUDA} ${buildTypeArg} ${buildStatic} ${amdgpuTargets} -DBUILD_TEST=ON -DBUILD_BENCHMARK=ON ../.. + ${cmake} -DCMAKE_CXX_COMPILER=${compiler} ${useCUDA} ${buildTypeArg} ${buildStatic} ${amdgpuTargets} ${asanFlag} -DBUILD_TEST=ON -DBUILD_BENCHMARK=ON ../.. make -j\$(nproc) """ platform.runCommand(this, command) } -def runTestCommand (platform, project) +def runTestCommand (platform, project, settings) { String sudo = auxiliary.sudo(platform.jenkinsLabel) def extraArgs = platform.jenkinsLabel.contains('cuda') ? "-E test_hiprand_linkage" : "" def testCommand = "ctest ${extraArgs} --output-on-failure" + def LD_PATH = 'export LD_LIBRARY_PATH=/opt/rocm/lib/' + if (settings.addressSanitizer) + { + LD_PATH = """ + export ASAN_LIB_PATH=\$(/opt/rocm/llvm/bin/clang -print-file-name=libclang_rt.asan-x86_64.so) + export LD_LIBRARY_PATH=\$LD_LIBRARY_PATH:\$(dirname "\${ASAN_LIB_PATH}") + """ + } + def command = """#!/usr/bin/env bash set -x cd ${project.paths.project_build_prefix}/build/release make -j4 - ${sudo} LD_LIBRARY_PATH=/opt/rocm/lib/ ${testCommand} + ${LD_PATH} + ${sudo} ${testCommand} """ platform.runCommand(this, command) diff --git a/.jenkins/precheckin-cuda.groovy b/.jenkins/precheckin-cuda.groovy index 8b33a6e..edc9132 100644 --- a/.jenkins/precheckin-cuda.groovy +++ b/.jenkins/precheckin-cuda.groovy @@ -14,6 +14,8 @@ def runCI = def commonGroovy + def settings = [:] + boolean formatCheck = false def compileCommand = @@ -21,7 +23,7 @@ def runCI = platform, project-> commonGroovy = load "${project.paths.project_src_prefix}/.jenkins/common.groovy" - commonGroovy.runCompileCommand(platform, project, jobName) + commonGroovy.runCompileCommand(platform, project, jobName, settings) } @@ -29,7 +31,7 @@ def runCI = { platform, project-> - commonGroovy.runTestCommand(platform, project) + commonGroovy.runTestCommand(platform, project, settings) } def packageCommand = diff --git a/.jenkins/staticanalysis.groovy b/.jenkins/staticanalysis.groovy index 7236b94..443dd2b 100644 --- a/.jenkins/staticanalysis.groovy +++ b/.jenkins/staticanalysis.groovy @@ -26,14 +26,16 @@ def runCI = boolean formatCheck = false boolean staticAnalysis = true + def settings = [debug: false] + def compileCommand = { platform, project-> - runCompileCommand(platform, project, jobName, false) + runCompileCommand(platform, project, jobName, settings) } - buildProject(prj , formatCheck, nodes.dockerArray, compileCommand, null, null, staticAnalysis) + buildProject(prj, formatCheck, nodes.dockerArray, compileCommand, null, null, staticAnalysis) } ci: { diff --git a/.jenkins/staticlibrary.groovy b/.jenkins/staticlibrary.groovy index 20f1e7b..0a8627f 100644 --- a/.jenkins/staticlibrary.groovy +++ b/.jenkins/staticlibrary.groovy @@ -16,21 +16,22 @@ def runCI = def commonGroovy boolean formatCheck = false + + def settings = [staticLibrary: true] def compileCommand = { platform, project-> commonGroovy = load "${project.paths.project_src_prefix}/.jenkins/common.groovy" - commonGroovy.runCompileCommand(platform, project, jobName, false, true) + commonGroovy.runCompileCommand(platform, project, jobName, settings) } - def testCommand = { platform, project-> - commonGroovy.runTestCommand(platform, project) + commonGroovy.runTestCommand(platform, project, settings) } def packageCommand = From 212437dac9ecb6a46cb94df59eaa86149cabc2da Mon Sep 17 00:00:00 2001 From: thansen-amd Date: Wed, 13 Dec 2023 10:29:12 -0700 Subject: [PATCH 2/2] rocRAND dependency --- .jenkins/asan.groovy | 1 + 1 file changed, 1 insertion(+) diff --git a/.jenkins/asan.groovy b/.jenkins/asan.groovy index 203311b..c376e70 100644 --- a/.jenkins/asan.groovy +++ b/.jenkins/asan.groovy @@ -9,6 +9,7 @@ def runCI = nodeDetails, jobName-> def prj = new rocProject('hipRAND', 'address-sanitizer') + prj.libraryDependencies = ['rocRAND'] def nodes = new dockerNodes(nodeDetails, jobName, prj)