[ROCm] tweak rocm wheel build workflow to avoid ci timeouts #562
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: wheels | |
on: | |
pull_request: | |
paths: | |
- "packaging/compute_wheel_version.sh" | |
- ".github/workflows/wheel*" | |
- ".github/actions/setup-windows-runner/action.yml" | |
- "setup.py" | |
- "requirements*.txt" | |
push: | |
branches: | |
- main | |
tags: | |
- "v[0-9]+*" | |
jobs: | |
target_determinator: | |
runs-on: ubuntu-latest | |
outputs: | |
matrix: ${{ steps.set-matrix.outputs.matrix }} | |
steps: | |
- id: set-matrix | |
shell: python | |
run: | | |
import os | |
import json | |
import itertools | |
environ = os.environ | |
PY_VERSIONS = ['3.8', '3.9', '3.10', '3.11', '3.12'] | |
CU_VERSIONS = ['118', '121', '124'] | |
ROCM_VERSIONS = ["6.0", "6.1"] | |
PY_CU = list(itertools.product(PY_VERSIONS, CU_VERSIONS)) | |
PY_ROCM = list(itertools.product(PY_VERSIONS, ROCM_VERSIONS)) | |
print("Full matrix PY_CU", PY_CU) | |
if os.environ["GITHUB_EVENT_NAME"] == "pull_request": | |
print("pull-request: limiting matrix to save resources") | |
PY_CU = [(PY_VERSIONS[0], CU_VERSIONS[0])] | |
for cu in CU_VERSIONS[1:]: | |
PY_CU.append((PY_VERSIONS[-1], cu)) | |
print("Limited matrix PY_CU", PY_CU) | |
PY_ROCM = [(PY_VERSIONS[-1], ROCM_VERSIONS[-1])] | |
include = [] | |
for os in ['8-core-ubuntu', 'windows-8-core']: | |
for torch_version in ['2.4.0']: | |
# CUDA builds | |
for python, cuda_short_version in PY_CU: | |
include.append(dict( | |
os=os, | |
python=python, | |
torch_version=torch_version, | |
toolkit_type="cuda", | |
toolkit_short_version=cuda_short_version, | |
)) | |
print(include[-1]) | |
# ROCM builds | |
for python, rocm_short_version in PY_ROCM: | |
if os == 'windows-8-core': | |
continue | |
include.append(dict( | |
os="16-core-ubuntu", # use for ROCm wheels only to avoid CI timeouts | |
python=python, | |
torch_version=torch_version, | |
toolkit_type="rocm", | |
toolkit_short_version=rocm_short_version, | |
)) | |
print(include[-1]) | |
matrix = {'include': include} | |
print(json.dumps(matrix)) | |
with open(environ["GITHUB_OUTPUT"], "a") as fd: | |
fd.write("matrix="+json.dumps(matrix)) | |
build: | |
needs: target_determinator | |
strategy: | |
fail-fast: false | |
matrix: ${{ fromJson(needs.target_determinator.outputs.matrix) }} | |
uses: ./.github/workflows/wheels_build.yml | |
if: github.repository == 'facebookresearch/xformers' || github.event_name == 'pull_request' | |
with: | |
os: ${{ matrix.os }} | |
python: ${{ matrix.python }} | |
torch_version: ${{ matrix.torch_version }} | |
toolkit_type: ${{ matrix.toolkit_type }} | |
toolkit_short_version: ${{ matrix.toolkit_short_version }} | |
upload_pip: | |
needs: build | |
uses: ./.github/workflows/wheels_upload_pip.yml | |
with: | |
twine_username: __token__ | |
filter: "*torch2.4.0+cu121*" | |
execute: ${{ github.repository == 'facebookresearch/xformers' && github.event_name != 'pull_request' }} | |
secrets: | |
twine_password: ${{ secrets.PYPI_TOKEN }} | |
upload_pt_cu118: | |
needs: build | |
uses: ./.github/workflows/wheels_upload_s3.yml | |
with: | |
aws_role: "arn:aws:iam::749337293305:role/pytorch_bot_uploader_role" | |
s3_path: s3://pytorch/whl/cu118/ | |
aws_s3_cp_extra_args: --acl public-read | |
filter: "*torch2.4.0+cu118*" | |
execute: ${{ github.repository == 'facebookresearch/xformers' && github.ref_type == 'tag' }} | |
upload_pt_cu121: | |
needs: build | |
uses: ./.github/workflows/wheels_upload_s3.yml | |
with: | |
aws_role: "arn:aws:iam::749337293305:role/pytorch_bot_uploader_role" | |
s3_path: s3://pytorch/whl/cu121/ | |
aws_s3_cp_extra_args: --acl public-read | |
filter: "*torch2.4.0+cu121*" | |
execute: ${{ github.repository == 'facebookresearch/xformers' && github.ref_type == 'tag' }} | |
upload_pt_rocm6_0: | |
needs: build | |
uses: ./.github/workflows/wheels_upload_s3.yml | |
with: | |
aws_role: "arn:aws:iam::749337293305:role/pytorch_bot_uploader_role" | |
s3_path: s3://pytorch/whl/rocm6.0/ | |
aws_s3_cp_extra_args: --acl public-read | |
filter: "*torch2.4.0+rocm6.0*" | |
execute: ${{ github.repository == 'facebookresearch/xformers' && github.ref_type == 'tag' }} | |
upload_pt_rocm6_1: | |
needs: build | |
uses: ./.github/workflows/wheels_upload_s3.yml | |
with: | |
aws_role: "arn:aws:iam::749337293305:role/pytorch_bot_uploader_role" | |
s3_path: s3://pytorch/whl/rocm6.1/ | |
aws_s3_cp_extra_args: --acl public-read | |
filter: "*torch2.4.0+rocm6.1*" | |
execute: ${{ github.repository == 'facebookresearch/xformers' && github.ref_type == 'tag' }} | |