mirror of
https://github.com/ROCm/ROCm.git
synced 2026-01-09 14:48:06 -05:00
- Update rccl component pipeline to include new additions made to projects already in super repos. - Also update rccl to trigger rocproifler-sdk job upon completion. - rocprofiler-sdk pipeline updated to include os parameter to enable future almalinux 8 job.
243 lines
8.7 KiB
YAML
243 lines
8.7 KiB
YAML
parameters:
|
|
- name: componentName
|
|
type: string
|
|
default: rccl
|
|
- name: checkoutRepo
|
|
type: string
|
|
default: 'self'
|
|
- name: checkoutRef
|
|
type: string
|
|
default: ''
|
|
- name: systemsRepo
|
|
type: string
|
|
default: systems_repo
|
|
- name: systemsSparseCheckoutDir
|
|
type: string
|
|
default: 'projects/rocprofiler-sdk'
|
|
# 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:
|
|
- cmake
|
|
- git
|
|
- libboost-program-options-dev
|
|
- libdrm-dev
|
|
- libfftw3-dev
|
|
- libnuma-dev
|
|
- libstdc++-12-dev
|
|
- ninja-build
|
|
- python3-pip
|
|
- name: rocmDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- aomp-extras
|
|
- clr
|
|
- HIPIFY
|
|
- llvm-project
|
|
- rocm-cmake
|
|
- rocm-core
|
|
- rocm_smi_lib
|
|
- rocminfo
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
- name: rocmTestDependencies
|
|
type: object
|
|
default:
|
|
- aomp
|
|
- aomp-extras
|
|
- clr
|
|
- HIPIFY
|
|
- llvm-project
|
|
- rocm-cmake
|
|
- rocm-core
|
|
- rocm_smi_lib
|
|
- rocminfo
|
|
- rocprofiler-register
|
|
- ROCR-Runtime
|
|
- roctracer
|
|
|
|
- name: jobMatrix
|
|
type: object
|
|
default:
|
|
buildJobs:
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx90a }
|
|
testJobs:
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx942 }
|
|
- { os: ubuntu2204, packageManager: apt, target: gfx90a }
|
|
- name: downstreamComponentMatrix
|
|
type: object
|
|
default:
|
|
- rocprofiler-sdk:
|
|
name: rocprofiler-sdk
|
|
sparseCheckoutDir: ''
|
|
skipUnifiedBuild: 'false'
|
|
buildDependsOn:
|
|
- rccl_build
|
|
|
|
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 }}
|
|
timeoutInMinutes: 120
|
|
variables:
|
|
- group: common
|
|
- template: /.azuredevops/variables-global.yml
|
|
- name: HIP_ROCCLR_HOME
|
|
value: $(Build.BinariesDirectory)/rocm
|
|
pool: ${{ variables.MEDIUM_BUILD_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 }}
|
|
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 }}
|
|
submoduleBehaviour: recursive
|
|
- 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 }}
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/build-cmake.yml
|
|
parameters:
|
|
os: ${{ job.os }}
|
|
extraBuildFlags: >-
|
|
-DCMAKE_CXX_COMPILER=$(Agent.BuildDirectory)/rocm/bin/hipcc
|
|
-DCMAKE_C_COMPILER=$(Agent.BuildDirectory)/rocm/bin/hipcc
|
|
-DCMAKE_BUILD_TYPE=Release
|
|
-DROCM_PATH=$(Agent.BuildDirectory)/rocm
|
|
-DBUILD_TESTS=ON
|
|
-DCMAKE_PREFIX_PATH=$(Agent.BuildDirectory)/rocm;$(Agent.BuildDirectory)/rocm/share/rocm/cmake;$(Agent.BuildDirectory)/rocm/libexec/hipify
|
|
-DGPU_TARGETS=${{ job.target }}
|
|
-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 }}
|
|
gpuTarget: ${{ job.target }}
|
|
extraEnvVars:
|
|
- HIP_ROCCLR_HOME:::/home/user/workspace/rocm
|
|
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:
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/dependencies-other.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
- 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
|
|
- 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: './rccl-UnitTests'
|
|
testParameters: '--gtest_output=xml:./test_output.xml --gtest_color=yes'
|
|
- template: ${{ variables.CI_TEMPLATE_PATH }}/steps/docker-container.yml
|
|
parameters:
|
|
aptPackages: ${{ parameters.aptPackages }}
|
|
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.systemsRepo }}
|
|
sparseCheckoutDir: ${{ parameters.systemsSparseCheckoutDir }}
|
|
triggerDownstreamJobs: true
|
|
unifiedBuild: ${{ parameters.unifiedBuild }}
|
|
${{ if parameters.unifiedBuild }}:
|
|
buildDependsOn: ${{ component.unifiedBuild.buildDependsOn }}
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}+${{ component.unifiedBuild.downstreamAggregateNames }}
|
|
${{ else }}:
|
|
buildDependsOn: ${{ component.buildDependsOn }}
|
|
downstreamAggregateNames: ${{ parameters.downstreamAggregateNames }}+${{ parameters.componentName }}
|