mirror of
https://github.com/ROCm/ROCm.git
synced 2026-01-09 22:58:17 -05:00
245 lines
9.3 KiB
YAML
245 lines
9.3 KiB
YAML
parameters:
|
|
- name: componentName
|
|
type: string
|
|
default: hipSPARSELt
|
|
- name: checkoutRepo
|
|
type: string
|
|
default: 'self'
|
|
- name: checkoutRef
|
|
type: string
|
|
default: ''
|
|
# monorepo related parameters
|
|
- name: sparseCheckoutDir
|
|
type: string
|
|
default: ''
|
|
- name: triggerDownstreamJobs
|
|
type: boolean
|
|
default: false
|
|
- name: downstreamAggregateNames
|
|
type: string
|
|
default: ''
|
|
- name: buildDependsOn
|
|
type: object
|
|
default: null
|
|
- name: unifiedBuild
|
|
type: boolean
|
|
default: false
|
|
# set to true if doing full build of ROCm stack
|
|
# and dependencies are pulled from same pipeline
|
|
- name: aggregatePipeline
|
|
type: boolean
|
|
default: false
|
|
- name: aptPackages
|
|
type: object
|
|
default:
|
|
- ninja-build
|
|
- python3-venv
|
|
- libmsgpack-dev
|
|
- git
|
|
- python3-pip
|
|
- gfortran
|
|
- libgfortran5
|
|
- libopenblas-dev
|
|
- name: pipModules
|
|
type: object
|
|
default:
|
|
- joblib
|
|
- name: rocmDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- clr
|
|
- hipSPARSE
|
|
- llvm-project
|
|
- rocBLAS
|
|
- rocm_smi_lib
|
|
- rocminfo
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
- name: rocmTestDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- clr
|
|
- llvm-project
|
|
- hipBLAS-common
|
|
- hipBLASLt
|
|
- rocBLAS
|
|
- rocminfo
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
|
|
- name: jobMatrix
|
|
type: object
|
|
default:
|
|
buildJobs:
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
testJobs:
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
|
|
jobs:
|
|
- ${{ each job in parameters.jobMatrix.buildJobs }}:
|
|
- job: ${{ parameters.componentName }}_build_${{ job.os }}_${{ job.target }}
|
|
${{ if parameters.buildDependsOn }}:
|
|
dependsOn:
|
|
- ${{ each build in parameters.buildDependsOn }}:
|
|
- ${{ build }}_${{ job.os }}_${{ job.target }}
|
|
variables:
|
|
- group: common
|
|
- template: /.azuredevops/variables-global.yml
|
|
- name: HIP_ROCCLR_HOME
|
|
value: $(Build.BinariesDirectory)/rocm
|
|
- name: TENSILE_ROCM_ASSEMBLER_PATH
|
|
value: $(Agent.BuildDirectory)/rocm/llvm/bin/clang
|
|
- name: CMAKE_CXX_COMPILER
|
|
value: $(Agent.BuildDirectory)/rocm/llvm/bin/hipcc
|
|
- name: TENSILE_ROCM_OFFLOAD_BUNDLER_PATH
|
|
value: $(Agent.BuildDirectory)/rocm/llvm/bin/clang-offload-bundler
|
|
- name: PATH
|
|
value: $(Agent.BuildDirectory)/rocm/llvm/bin:$(Agent.BuildDirectory)/rocm/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/snap/bin
|
|
pool: ${{ variables.MEDIUM_BUILD_POOL }}
|
|
workspace:
|
|
clean: all
|
|
steps:
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-other.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
pipModules: ${{ parameters.pipModules }}
|
|
packageManager: ${{ job.packageManager }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-cmake-latest.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/preamble.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/checkout.yml
|
|
parameters:
|
|
checkoutRepo: ${{ parameters.checkoutRepo }}
|
|
# ignore sparse checkout for monorepo case, we want access to hipblaslt directory
|
|
# sparseCheckoutDir: ${{ parameters.sparseCheckoutDir }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-rocm.yml
|
|
parameters:
|
|
checkoutRef: ${{ parameters.checkoutRef }}
|
|
dependencyList: ${{ parameters.rocmDependencies }}
|
|
gpuTarget: ${{ job.target }}
|
|
os: ${{ job.os }}
|
|
aggregatePipeline: ${{ parameters.aggregatePipeline }}
|
|
${{ if parameters.triggerDownstreamJobs }}:
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}
|
|
# Build and install gtest and lapack
|
|
# $(Pipeline.Workspace)/deps is a temporary folder for the build process
|
|
# $(Pipeline.Workspace)/s/deps is part of the hipSPARSELt repo
|
|
- script: mkdir $(Pipeline.Workspace)/deps
|
|
displayName: Create temp folder for external dependencies
|
|
# hipSPARSELt already has a CMake script for external deps, so we can just run that
|
|
# https://github.com/ROCm/hipSPARSELt/blob/develop/deps/CMakeLists.txt
|
|
- ${{ if ne(parameters.sparseCheckoutDir, '') }}:
|
|
script: cmake $(Pipeline.Workspace)/s/projects/hipsparselt/deps
|
|
${{ else }}:
|
|
script: cmake $(Pipeline.Workspace)/s/deps
|
|
displayName: Configure hipSPARSELt external dependencies
|
|
workingDirectory: $(Pipeline.Workspace)/deps
|
|
- script: make
|
|
displayName: Build hipSPARSELt external dependencies
|
|
workingDirectory: $(Pipeline.Workspace)/deps
|
|
- script: sudo make install
|
|
displayName: Install hipSPARSELt external dependencies
|
|
workingDirectory: $(Pipeline.Workspace)/deps
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/build-cmake.yml
|
|
parameters:
|
|
os: ${{ job.os }}
|
|
extraBuildFlags: >-
|
|
-DCMAKE_BUILD_TYPE=Release
|
|
-DCMAKE_CXX_COMPILER=$(Agent.BuildDirectory)/rocm/llvm/bin/amdclang++
|
|
-DCMAKE_C_COMPILER=$(Agent.BuildDirectory)/rocm/llvm/bin/amdclang
|
|
-DCMAKE_Fortran_COMPILER=f95
|
|
-DAMDGPU_TARGETS=${{ job.target }}
|
|
-DTensile_LOGIC=
|
|
-DTensile_CPU_THREADS=
|
|
-DTensile_LIBRARY_FORMAT=msgpack
|
|
-DCMAKE_PREFIX_PATH="$(Agent.BuildDirectory)/rocm"
|
|
-DROCM_PATH=$(Agent.BuildDirectory)/rocm
|
|
-DBUILD_CLIENTS_TESTS=ON
|
|
-DBUILD_USE_LOCAL_TENSILE=OFF
|
|
-GNinja
|
|
${{ if ne(parameters.sparseCheckoutDir, '') }}:
|
|
cmakeSourceDir: $(Build.SourcesDirectory)/projects/hipsparselt
|
|
cmakeBuildDir: $(Build.SourcesDirectory)/projects/hipsparselt
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/manifest.yml
|
|
parameters:
|
|
componentName: ${{ parameters.componentName }}
|
|
gpuTarget: ${{ job.target }}
|
|
os: ${{ job.os }}
|
|
sparseCheckoutDir: ${{ parameters.sparseCheckoutDir }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/artifact-upload.yml
|
|
parameters:
|
|
componentName: ${{ parameters.componentName }}
|
|
gpuTarget: ${{ job.target }}
|
|
os: ${{ job.os }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/artifact-links.yml
|
|
- ${{ if eq(job.os, 'ubuntu2204') }}:
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/docker-container.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
pipModules: ${{ parameters.pipModules }}
|
|
gpuTarget: ${{ job.target }}
|
|
extraCopyDirectories:
|
|
- deps
|
|
extraPaths: /home/user/workspace/rocm/llvm/bin:/home/user/workspace/rocm/bin
|
|
extraEnvVars:
|
|
- HIP_ROCCLR_HOME:::/home/user/workspace/rocm
|
|
- TENSILE_ROCM_ASSEMBLER_PATH:::/home/user/workspace/rocm/llvm/bin/clang
|
|
- CMAKE_CXX_COMPILER:::/home/user/workspace/rocm/llvm/bin/hipcc
|
|
- TENSILE_ROCM_OFFLOAD_BUNDLER_PATH:::/home/user/workspace/rocm/llvm/bin/clang-offload-bundler
|
|
installLatestCMake: true
|
|
|
|
- ${{ if eq(parameters.unifiedBuild, False) }}:
|
|
- ${{ each job in parameters.jobMatrix.testJobs }}:
|
|
- job: ${{ parameters.componentName }}_test_${{ job.os }}_${{ job.target }}
|
|
timeoutInMinutes: 120
|
|
dependsOn: ${{ parameters.componentName }}_build_${{ job.os }}_${{ job.target }}
|
|
condition:
|
|
and(succeeded(),
|
|
eq(variables['ENABLE_${{ upper(job.target) }}_TESTS'], 'true'),
|
|
not(containsValue(split(variables['DISABLED_${{ upper(job.target) }}_TESTS'], ','), '${{ parameters.componentName }}')),
|
|
eq(${{ parameters.aggregatePipeline }}, False)
|
|
)
|
|
variables:
|
|
- group: common
|
|
- template: /.azuredevops/variables-global.yml
|
|
pool: ${{ job.target }}_test_pool
|
|
workspace:
|
|
clean: all
|
|
steps:
|
|
- checkout: none
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-other.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
packageManager: ${{ job.packageManager }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/preamble.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/local-artifact-download.yml
|
|
parameters:
|
|
preTargetFilter: ${{ parameters.componentName }}
|
|
gpuTarget: ${{ job.target }}
|
|
os: ${{ job.os }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-rocm.yml
|
|
parameters:
|
|
checkoutRef: ${{ parameters.checkoutRef }}
|
|
dependencyList: ${{ parameters.rocmTestDependencies }}
|
|
gpuTarget: ${{ job.target }}
|
|
os: ${{ job.os }}
|
|
${{ if parameters.triggerDownstreamJobs }}:
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/gpu-diagnostics.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/test.yml
|
|
parameters:
|
|
componentName: ${{ parameters.componentName }}
|
|
os: ${{ job.os }}
|
|
testDir: '$(Agent.BuildDirectory)/rocm/bin'
|
|
testExecutable: './hipsparselt-test'
|
|
testParameters: '--gtest_output=xml:./test_output.xml --gtest_color=yes --gtest_filter=*pre_checkin*'
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/docker-container.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
pipModules: ${{ parameters.pipModules }}
|
|
environment: test
|
|
gpuTarget: ${{ job.target }}
|