forked from aws/aws-ofi-nccl
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Yong Tao <[email protected]>
- Loading branch information
1 parent
17833fd
commit 3f23e37
Showing
1 changed file
with
0 additions
and
317 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,318 +1 @@ | ||
name: PR CI | ||
on: [push, pull_request] | ||
env: | ||
APT_PACKAGES: >- | ||
build-essential | ||
git | ||
libhwloc-dev | ||
make | ||
|
||
# note, related to issue around actions/checkout@v4, linked below. This | ||
# environment variable is also now needed, as of july 2024. | ||
# ref: https://github.com/actions/runner/issues/2906#issuecomment-2208546951 | ||
ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: 'true' | ||
concurrency: | ||
group: ${{ github.head_ref || github.run_id }} | ||
cancel-in-progress: true | ||
jobs: | ||
amazonlinux: | ||
strategy: | ||
matrix: | ||
sdk: | ||
- cuda | ||
amazonlinux: | ||
- al2023 | ||
- al2 | ||
efainstaller: | ||
- latest | ||
- 1.32.0 | ||
- 1.31.0 | ||
- 1.30.0 | ||
include: | ||
- amazonlinux: al2023 | ||
efainstallerdir: ALINUX2023 | ||
nvidiadistro: fedora37 | ||
configmanager: dnf config-manager | ||
cudapackages: cuda-cudart-devel-12-3 cuda-driver-devel-12-3 | ||
|
||
- amazonlinux: al2 | ||
efainstallerdir: ALINUX2 | ||
nvidiadistro: rhel7 | ||
configmanager: yum-config-manager | ||
cudapackages: cuda-cudart-devel-12-3 cuda-driver-devel-12-3 | ||
|
||
runs-on: codebuild-ghactions-${{ github.run_id }}-${{ github.run_attempt }} | ||
name: ${{matrix.amazonlinux}}/${{ matrix.sdk }}/efa@${{ matrix.efainstaller }}/makeinstall | ||
steps: | ||
# note, do not bump to v4: https://github.com/actions/checkout/issues/1590 | ||
- uses: actions/checkout@v4 | ||
- name: Fetch and Install EFA Installer Dependencies | ||
run: | | ||
curl -O https://efa-installer.amazonaws.com/aws-efa-installer-${{ matrix.efainstaller }}.tar.gz | ||
tar -xf aws-efa-installer-*.tar.gz | ||
cd aws-efa-installer/RPMS/${{ matrix.efainstallerdir }}/x86_64 | ||
find . | grep rpm$ | xargs sudo yum -y localinstall | ||
- name: Install hwloc, utilities. | ||
run: | | ||
sudo yum -y install hwloc-devel yum-utils | ||
- name: Add EPEL | ||
if: matrix.amazonlinux == 'al2' | ||
run: | | ||
sudo yum -y install \ | ||
https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm | ||
- name: Install CUDA | ||
run: | | ||
sudo ${{ matrix.configmanager }} --add-repo \ | ||
http://developer.download.nvidia.com/compute/cuda/repos/${{ matrix.nvidiadistro }}/x86_64/cuda-${{ matrix.nvidiadistro }}.repo \ | ||
--save | ||
sudo yum -y clean expire-cache | ||
sudo yum -y install ${{ matrix.cudapackages }} | ||
- name: Call `autoreconf -ivf` | ||
run: ./autogen.sh | ||
|
||
- name: Call `./configure` | ||
run: | | ||
./configure --prefix=/opt/aws-ofi-nccl --with-mpi=/opt/amazon/openmpi \ | ||
--with-libfabric=/opt/amazon/efa \ | ||
--with-cuda=/usr/local/cuda \ | ||
--enable-tests=no \ | ||
--enable-platform-aws | ||
- name: Call `make` | ||
run: make -j | ||
|
||
- name: Call `make install` | ||
run: sudo make install | ||
|
||
distcheck: | ||
runs-on: ubuntu-22.04 | ||
strategy: | ||
matrix: | ||
cc-variant: | ||
- latest | ||
- legacy | ||
cc: | ||
- gcc | ||
- clang | ||
tracing: | ||
- lttng | ||
- none | ||
sdk: | ||
- cuda | ||
- neuron | ||
|
||
include: | ||
- cc-variant: latest | ||
cc: clang | ||
cc-version: 19 | ||
- cc-variant: latest | ||
cc: gcc | ||
cc-version: 13 | ||
|
||
name: u2204/${{ matrix.sdk }}/libfabric@git/${{matrix.cc}}(${{matrix.cc-variant}})/distcheck/ | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Configure Neuron SDK Repository | ||
if: matrix.sdk == 'neuron' | ||
run: | | ||
# Configure Linux for Neuron repository updates | ||
sudo tee /etc/apt/sources.list.d/neuron.list > /dev/null << EOF | ||
deb https://apt.repos.neuron.amazonaws.com jammy main | ||
EOF | ||
wget -qO - https://apt.repos.neuron.amazonaws.com/GPG-PUB-KEY-AMAZON-AWS-NEURON.PUB | sudo apt-key add - | ||
sudo apt update -y | ||
- name: Add compiler repositories | ||
if: matrix.cc-variant == 'latest' | ||
run: | | ||
if [ "${{ matrix.cc }}" == "clang" ]; then | ||
wget https://apt.llvm.org/llvm.sh | ||
chmod +x llvm.sh | ||
# Delete the last line, allowing us to use the cache below for | ||
# actually installing the package; this just adds the | ||
# repository. | ||
sed -i '$ d' llvm.sh | ||
sudo ./llvm.sh ${{ matrix.cc-version }} | ||
fi | ||
if [ "${{ matrix.cc }}" == "gcc" ]; then | ||
sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test | ||
fi | ||
- name: Install Latest Compiler | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
if: matrix.cc-variant == 'latest' | ||
with: | ||
packages: ${{ matrix.cc }}-${{matrix.cc-version}} | ||
version: compiler-${{ matrix.cc }}-${{matrix.cc-version}} | ||
|
||
- name: Install Base Dependencies | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: ${{ env.APT_PACKAGES }} | ||
version: base-packages | ||
|
||
- name: Install CUDA SDK | ||
if: matrix.sdk == 'cuda' | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: nvidia-cuda-toolkit | ||
version: cuda-packages | ||
|
||
- name: Install Neuron SDK | ||
if: matrix.sdk == 'neuron' | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: aws-neuronx-runtime-lib | ||
version: neuron-packages | ||
|
||
- name: Install lttng | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
if: matrix.tracing == 'lttng' | ||
with: | ||
packages: liblttng-ust-dev | ||
version: lttng | ||
|
||
- name: Fetch and Install EFA Installer Dependencies | ||
run: | | ||
curl -O https://efa-installer.amazonaws.com/aws-efa-installer-latest.tar.gz | ||
tar -xf aws-efa-installer-*.tar.gz | ||
pushd aws-efa-installer/ | ||
sudo ./efa_installer.sh -y --skip-kmod | ||
popd | ||
- name: Build Plugin | ||
run: | | ||
set -x | ||
export CC="${{ matrix.realcc || matrix.cc }}" | ||
# actions/checkout@v4 would drop the plugin source in $PWD, | ||
# so go ahead and build it. | ||
./autogen.sh | ||
if [ "${{ matrix.sdk }}" == "cuda" ] | ||
then | ||
./configure --with-mpi=/opt/amazon/openmpi \ | ||
--with-libfabric=/opt/amazon/efa \ | ||
--with-cuda=/usr/local/cuda/ \ | ||
--enable-tests \ | ||
--enable-platform-aws | ||
else | ||
./configure --with-libfabric=/opt/amazon/efa \ | ||
--enable-neuron \ | ||
--enable-platform-aws | ||
fi | ||
make -j "$(nproc)" | ||
- name: Run Dist Check | ||
run: make distcheck | ||
|
||
- name: Upload build logs | ||
if: failure() | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: ${{ matrix.cc }}-${{ matrix.cc-variant }}-${{ matrix.sdk }}-config.log | ||
path: config.log | ||
if-no-files-found: ignore | ||
|
||
|
||
codechecker: | ||
runs-on: ubuntu-22.04 | ||
needs: [distcheck] | ||
strategy: | ||
matrix: | ||
sdk: | ||
- cuda | ||
- neuron | ||
name: CodeChecker - ${{ matrix.sdk }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-python@v5 | ||
with: | ||
python-version: '3.9' | ||
|
||
- name: Configure Neuron SDK Repository | ||
if: matrix.sdk == 'neuron' | ||
run: | | ||
# Configure Linux for Neuron repository updates | ||
sudo tee /etc/apt/sources.list.d/neuron.list > /dev/null << EOF | ||
deb https://apt.repos.neuron.amazonaws.com jammy main | ||
EOF | ||
wget -qO - https://apt.repos.neuron.amazonaws.com/GPG-PUB-KEY-AMAZON-AWS-NEURON.PUB | sudo apt-key add - | ||
sudo apt update -y | ||
- name: Install Base Dependencies | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: ${{ env.APT_PACKAGES }} | ||
version: base-packages | ||
|
||
- name: Install CUDA SDK | ||
if: matrix.sdk == 'cuda' | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: nvidia-cuda-toolkit | ||
version: cuda-packages | ||
|
||
- name: Install Neuron SDK | ||
if: matrix.sdk == 'neuron' | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: aws-neuronx-runtime-lib | ||
version: neuron-packages | ||
|
||
- name: Install cppcheck | ||
uses: awalsh128/cache-apt-pkgs-action@latest | ||
with: | ||
packages: cppcheck | ||
version: codechecker-cppcheck | ||
|
||
- name: Fetch and Install EFA Installer Dependencies | ||
run: | | ||
curl -O https://efa-installer.amazonaws.com/aws-efa-installer-latest.tar.gz | ||
tar -xf aws-efa-installer-*.tar.gz | ||
pushd aws-efa-installer/ | ||
sudo ./efa_installer.sh -y --skip-kmod | ||
popd | ||
- name: Run Configure | ||
run: | | ||
./autogen.sh | ||
if [ "${{ matrix.sdk }}" == "neuron" ]; then | ||
./configure \ | ||
--with-libfabric="/opt/amazon/efa" \ | ||
--enable-neuron \ | ||
--enable-platform-aws | ||
else | ||
./configure \ | ||
--with-libfabric="/opt/amazon/efa" \ | ||
--with-mpi="/opt/amazon/openmpi" \ | ||
--with-cuda=/usr/local/cuda/ \ | ||
--enable-tests \ | ||
--enable-platform-aws | ||
fi | ||
- name: Run CodeChecker | ||
uses: whisperity/codechecker-analysis-action@v1 | ||
id: codechecker | ||
with: | ||
build-command: make | ||
ctu: true | ||
config: .github/codechecker.yaml | ||
install-custom: true | ||
version: v6.23.1 | ||
llvm-version: '18' | ||
|
||
- name: Save CodeChecker HTML output. | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: CodeChecker Bug Reports for ${{ matrix.sdk }} | ||
path: ${{ steps.codechecker.outputs.result-html-dir }}/*.html | ||
|
||
- name: CodeChecker Pass Or Fail? | ||
if: steps.codechecker.outputs.warnings-in-diff == 'true' | ||
shell: bash | ||
run: | | ||
echo "::error title=Static Analyzers Failed::Analysed commit(s) caused static analysis warnings" | ||
exit 0 |