mirror of
https://github.com/ROCm/ROCm.git
synced 2026-01-09 14:48:06 -05:00
313 lines
12 KiB
YAML
313 lines
12 KiB
YAML
parameters:
|
|
- name: componentName
|
|
type: string
|
|
default: hipBLASLt
|
|
- 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:
|
|
- ccache
|
|
- gfortran
|
|
- git
|
|
- libboost-filesystem-dev
|
|
- libboost-program-options-dev
|
|
- libdrm-dev
|
|
- liblapack-dev
|
|
- libmsgpack-dev
|
|
- libnuma-dev
|
|
- libopenblas-dev
|
|
- ninja-build
|
|
- python3-pip
|
|
- python3-venv
|
|
- name: pipModules
|
|
type: object
|
|
default:
|
|
- joblib
|
|
- "packaging>=22.0"
|
|
- pyyaml
|
|
- msgpack
|
|
- simplejson
|
|
- ujson
|
|
- orjson
|
|
- yappi
|
|
- --upgrade
|
|
- name: rocmDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- clr
|
|
- hipBLAS-common
|
|
- llvm-project
|
|
- rocminfo
|
|
- rocm-cmake
|
|
- rocm_smi_lib
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
- name: rocmTestDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- clr
|
|
- hipBLAS-common
|
|
- llvm-project
|
|
- rocm-cmake
|
|
- rocminfo
|
|
- rocm_smi_lib
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
|
|
- name: jobMatrix
|
|
type: object
|
|
default:
|
|
buildJobs:
|
|
- { pool: rocm-ci_ultra_build_pool, os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
- { pool: rocm-ci_medium_build_pool, os: ubuntu2204, packageManager: apt, target: gfx90a }
|
|
- { pool: rocm-ci_medium_build_pool, os: ubuntu2204, packageManager: apt, target: gfx1201 }
|
|
- { pool: rocm-ci_medium_build_pool, os: ubuntu2204, packageManager: apt, target: gfx1100 }
|
|
#- { pool: rocm-ci_medium_build_pool, os: ubuntu2204, packageManager: apt, target: gfx1030 }
|
|
- { pool: rocm-ci_ultra_build_pool, os: almalinux8, packageManager: dnf, target: gfx942 }
|
|
- { pool: rocm-ci_medium_build_pool, os: almalinux8, packageManager: dnf, target: gfx90a }
|
|
- { pool: rocm-ci_medium_build_pool, os: almalinux8, packageManager: dnf, target: gfx1201 }
|
|
- { pool: rocm-ci_medium_build_pool, os: almalinux8, packageManager: dnf, target: gfx1100 }
|
|
#- { pool: rocm-ci_medium_build_pool, os: almalinux8, packageManager: dnf, target: gfx1030 }
|
|
testJobs:
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx90a }
|
|
- name: downstreamComponentMatrix
|
|
type: object
|
|
default:
|
|
- rocBLAS:
|
|
name: rocBLAS
|
|
sparseCheckoutDir: projects/rocblas
|
|
skipUnifiedBuild: 'false'
|
|
buildDependsOn:
|
|
- hipBLASLt_build
|
|
|
|
jobs:
|
|
- ${{ each job in parameters.jobMatrix.buildJobs }}:
|
|
- job: ${{ parameters.componentName }}_build_${{ job.os }}_${{ job.target }}
|
|
timeoutInMinutes: 300
|
|
${{ if parameters.buildDependsOn }}:
|
|
dependsOn:
|
|
- ${{ each build in parameters.buildDependsOn }}:
|
|
- ${{ build }}_${{ job.os }}
|
|
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/amdclang
|
|
- name: TENSILE_ROCM_OFFLOAD_BUNDLER_PATH
|
|
value: $(Agent.BuildDirectory)/rocm/llvm/bin/clang-offload-bundler
|
|
- name: ROCM_PATH
|
|
value: $(Agent.BuildDirectory)/rocm
|
|
- name: DAY_STRING
|
|
value: $[format('{0:ddMMyyyy}', pipeline.startTime)]
|
|
pool: ${{ job.pool }}
|
|
${{ if eq(job.os, 'almalinux8') }}:
|
|
container:
|
|
image: rocmexternalcicd.azurecr.io/manylinux228:latest
|
|
endpoint: ContainerService3
|
|
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-custom.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/preamble.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/checkout.yml
|
|
parameters:
|
|
checkoutRepo: ${{ parameters.checkoutRepo }}
|
|
sparseCheckoutDir: ${{ parameters.sparseCheckoutDir }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-vendor.yml
|
|
parameters:
|
|
dependencyList:
|
|
- gtest
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-rocm.yml
|
|
parameters:
|
|
checkoutRef: ${{ parameters.checkoutRef }}
|
|
dependencyList: ${{ parameters.rocmDependencies }}
|
|
os: ${{ job.os }}
|
|
gpuTarget: ${{ job.target }}
|
|
aggregatePipeline: ${{ parameters.aggregatePipeline }}
|
|
${{ if parameters.triggerDownstreamJobs }}:
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}
|
|
- task: Bash@3
|
|
displayName: Add ROCm binaries to PATH
|
|
inputs:
|
|
targetType: inline
|
|
script: |
|
|
echo "##vso[task.prependpath]$(Agent.BuildDirectory)/rocm/bin"
|
|
echo "##vso[task.prependpath]$(Agent.BuildDirectory)/rocm/llvm/bin"
|
|
- task: Bash@3
|
|
displayName: Build and install LAPACK
|
|
inputs:
|
|
targetType: inline
|
|
script: |
|
|
mkdir -p $(Agent.BuildDirectory)/temp-deps
|
|
cd $(Agent.BuildDirectory)/temp-deps
|
|
# position-independent LAPACK is required for almalinux8 builds
|
|
cmake -DBUILD_GTEST=OFF -DBUILD_LAPACK=ON -DCMAKE_POSITION_INDEPENDENT_CODE=ON $(Agent.BuildDirectory)/sparse/projects/hipblaslt/deps
|
|
make -j
|
|
sudo make install
|
|
- script: |
|
|
mkdir -p $(CCACHE_DIR)
|
|
echo "##vso[task.prependpath]/usr/lib/ccache"
|
|
displayName: Update path for ccache
|
|
- task: Cache@2
|
|
displayName: Ccache caching
|
|
inputs:
|
|
key: hipBLASLt | ${{ job.os }} | ${{ job.target }} | $(DAY_STRING) | $(Agent.BuildDirectory)/rocm/llvm/bin/amdclang++
|
|
path: $(CCACHE_DIR)
|
|
restoreKeys: |
|
|
hipBLASLt | ${{ job.os }} | ${{ job.target }} | $(DAY_STRING)
|
|
hipBLASLt | ${{ job.os }} | ${{ job.target }}
|
|
hipBLASLt | ${{ job.os }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/build-cmake.yml
|
|
parameters:
|
|
os: ${{ job.os }}
|
|
cmakeSourceDir: $(Agent.BuildDirectory)/sparse/projects/hipblaslt
|
|
cmakeBuildDir: $(Agent.BuildDirectory)/sparse/projects/hipblaslt/build
|
|
extraBuildFlags: >-
|
|
-DCMAKE_PREFIX_PATH=$(Agent.BuildDirectory)/rocm;$(Agent.BuildDirectory)/vendor
|
|
-DCMAKE_INCLUDE_PATH=$(Agent.BuildDirectory)/rocm/llvm/include
|
|
-DCMAKE_CXX_COMPILER=$(Agent.BuildDirectory)/rocm/llvm/bin/amdclang++
|
|
-DCMAKE_C_COMPILER=$(Agent.BuildDirectory)/rocm/llvm/bin/amdclang
|
|
-DCMAKE_CXX_COMPILER_LAUNCHER=ccache
|
|
-DCMAKE_C_COMPILER_LAUNCHER=ccache
|
|
-DAMDGPU_TARGETS=${{ job.target }}
|
|
-DGPU_TARGETS=${{ job.target }}
|
|
-DBUILD_CLIENTS_TESTS=ON
|
|
-DHIPBLASLT_ENABLE_ROCROLLER=ON
|
|
-DHIPBLASLT_ENABLE_FETCH=ON
|
|
-DHIPBLASLT_ENABLE_BLIS=OFF
|
|
-GNinja
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/manifest.yml
|
|
parameters:
|
|
componentName: ${{ parameters.componentName }}
|
|
sparseCheckoutDir: ${{ parameters.sparseCheckoutDir }}
|
|
os: ${{ job.os }}
|
|
gpuTarget: ${{ job.target }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/artifact-upload.yml
|
|
parameters:
|
|
componentName: ${{ parameters.componentName }}
|
|
os: ${{ job.os }}
|
|
gpuTarget: ${{ job.target }}
|
|
- 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 }}
|
|
extraPaths: /home/user/workspace/rocm/llvm/bin:/home/user/workspace/rocm/bin
|
|
installLatestCMake: true
|
|
extraEnvVars:
|
|
- HIP_ROCCLR_HOME:::/home/user/workspace/rocm
|
|
- TENSILE_ROCM_ASSEMBLER_PATH:::/home/user/workspace/rocm/llvm/bin/amdclang
|
|
- TENSILE_ROCM_OFFLOAD_BUNDLER_PATH:::/home/user/workspace/rocm/llvm/bin/clang-offload-bundler
|
|
- ROCM_PATH:::/home/user/workspace/rocm
|
|
extraCopyDirectories:
|
|
- deps
|
|
|
|
- ${{ if eq(parameters.unifiedBuild, False) }}:
|
|
- ${{ each job in parameters.jobMatrix.testJobs }}:
|
|
- job: ${{ parameters.componentName }}_test_${{ job.os }}_${{ job.target }}
|
|
timeoutInMinutes: 300
|
|
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
|
|
- name: ROCM_PATH
|
|
value: $(Agent.BuildDirectory)/rocm
|
|
pool: ${{ job.target }}_test_pool
|
|
workspace:
|
|
clean: all
|
|
steps:
|
|
- checkout: none
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-other.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
pipModules: ${{ parameters.pipModules }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/preamble.yml
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/local-artifact-download.yml
|
|
parameters:
|
|
preTargetFilter: ${{ parameters.componentName }}
|
|
os: ${{ job.os }}
|
|
gpuTarget: ${{ job.target }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-aqlprofile.yml
|
|
parameters:
|
|
os: ${{ job.os }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-rocm.yml
|
|
parameters:
|
|
checkoutRef: ${{ parameters.checkoutRef }}
|
|
dependencyList: ${{ parameters.rocmTestDependencies }}
|
|
os: ${{ job.os }}
|
|
gpuTarget: ${{ job.target }}
|
|
${{ 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: './hipblaslt-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 }}
|
|
|
|
- ${{ if parameters.triggerDownstreamJobs }}:
|
|
- ${{ each component in parameters.downstreamComponentMatrix }}:
|
|
- ${{ if not(and(parameters.unifiedBuild, eq(component.skipUnifiedBuild, 'true'))) }}:
|
|
- template: /.azuredevops/components/${{ component.name }}.yml@pipelines_repo
|
|
parameters:
|
|
checkoutRepo: ${{ parameters.checkoutRepo }}
|
|
sparseCheckoutDir: ${{ component.sparseCheckoutDir }}
|
|
buildDependsOn: ${{ component.buildDependsOn }}
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}+${{ parameters.componentName }}
|
|
triggerDownstreamJobs: true
|
|
unifiedBuild: ${{ parameters.unifiedBuild }}
|