123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- name: test
- concurrency:
- # For PRs, later CI runs preempt previous ones. e.g. a force push on a PR
- # cancels running CI jobs and starts all new ones.
- #
- # For non-PR pushes, concurrency.group needs to be unique for every distinct
- # CI run we want to have happen. Use run_id, which in practice means all
- # non-PR CI runs will be allowed to run without preempting each other.
- group: ${{ github.workflow }}-$${{ github.pull_request.number || github.run_id }}
- cancel-in-progress: true
- on:
- pull_request:
- paths:
- - '**/*'
- - '!docs/**'
- - '!README.md'
- jobs:
- changes:
- runs-on: ubuntu-latest
- outputs:
- changed: ${{ steps.changes.outputs.changed }}
- steps:
- - uses: actions/checkout@v4
- with:
- fetch-depth: 0
- - id: changes
- run: |
- changed() {
- local BASE=${{ github.event.pull_request.base.sha }}
- local HEAD=${{ github.event.pull_request.head.sha }}
- local MERGE_BASE=$(git merge-base $BASE $HEAD)
- git diff-tree -r --no-commit-id --name-only "$MERGE_BASE" "$HEAD" \
- | xargs python3 -c "import sys; from pathlib import Path; print(any(Path(x).match(glob) for x in sys.argv[1:] for glob in '$*'.split(' ')))"
- }
- echo changed=$(changed 'llama/llama.cpp/**' 'ml/backend/ggml/ggml/**') | tee -a $GITHUB_OUTPUT
- linux:
- needs: [changes]
- if: needs.changes.outputs.changed == 'True'
- strategy:
- matrix:
- include:
- - preset: CPU
- - preset: CUDA
- container: nvidia/cuda:11.8.0-devel-ubuntu22.04
- flags: '-DCMAKE_CUDA_ARCHITECTURES=87'
- - preset: ROCm
- container: rocm/dev-ubuntu-22.04:6.1.2
- extra-packages: rocm-libs
- flags: '-DAMDGPU_TARGETS=gfx1010 -DCMAKE_PREFIX_PATH=/opt/rocm'
- runs-on: linux
- container: ${{ matrix.container }}
- steps:
- - uses: actions/checkout@v4
- - run: |
- [ -n "${{ matrix.container }}" ] || sudo=sudo
- $sudo apt-get update
- $sudo apt-get install -y cmake ccache ${{ matrix.extra-packages }}
- env:
- DEBIAN_FRONTEND: noninteractive
- - uses: actions/cache@v4
- with:
- path: /github/home/.cache/ccache
- key: ccache-${{ runner.os }}-${{ runner.arch }}-${{ matrix.preset }}
- - run: |
- cmake --preset ${{ matrix.preset }} ${{ matrix.flags }}
- cmake --build --preset ${{ matrix.preset }} --parallel
- windows:
- needs: [changes]
- if: needs.changes.outputs.changed == 'True'
- strategy:
- matrix:
- include:
- - preset: CPU
- - preset: CUDA
- install: https://developer.download.nvidia.com/compute/cuda/11.8.0/local_installers/cuda_11.8.0_522.06_windows.exe
- flags: '-DCMAKE_CUDA_ARCHITECTURES=87'
- - preset: ROCm
- install: https://download.amd.com/developer/eula/rocm-hub/AMD-Software-PRO-Edition-24.Q3-WinSvr2022-For-HIP.exe
- flags: '-DAMDGPU_TARGETS=gfx1010'
- runs-on: windows
- steps:
- - run: |
- choco install -y --no-progress ccache ninja
- ccache -o cache_dir=${{ github.workspace }}\.ccache
- - if: matrix.preset == 'CUDA' || matrix.preset == 'ROCm'
- id: cache-install
- uses: actions/cache/restore@v4
- with:
- path: |
- C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA
- C:\Program Files\AMD\ROCm
- key: ${{ matrix.install }}
- - if: matrix.preset == 'CUDA'
- name: Install CUDA ${{ matrix.cuda-version }}
- run: |
- $ErrorActionPreference = "Stop"
- if ("${{ steps.cache-install.outputs.cache-hit }}" -ne 'true') {
- Invoke-WebRequest -Uri "${{ matrix.install }}" -OutFile "install.exe"
- Start-Process -FilePath .\install.exe -ArgumentList (@("-s", "cudart_11.8", "nvcc_11.8", "cublas_11.8", "cublas_dev_11.8")) -NoNewWindow -Wait
- }
- $cudaPath = (Resolve-Path "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\*").path
- echo "$cudaPath\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
- - if: matrix.preset == 'ROCm'
- name: Install ROCm ${{ matrix.rocm-version }}
- run: |
- $ErrorActionPreference = "Stop"
- if ("${{ steps.cache-install.outputs.cache-hit }}" -ne 'true') {
- Invoke-WebRequest -Uri "${{ matrix.install }}" -OutFile "install.exe"
- Start-Process -FilePath .\install.exe -ArgumentList '-install' -NoNewWindow -Wait
- }
- $hipPath = (Resolve-Path "C:\Program Files\AMD\ROCm\*").path
- echo "$hipPath\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
- echo "CC=$hipPath\bin\clang.exe" | Out-File -FilePath $env:GITHUB_ENV -Append
- echo "CXX=$hipPath\bin\clang++.exe" | Out-File -FilePath $env:GITHUB_ENV -Append
- - if: ${{ !cancelled() && steps.cache-install.outputs.cache-hit != 'true' }}
- uses: actions/cache/save@v4
- with:
- path: |
- C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA
- C:\Program Files\AMD\ROCm
- key: ${{ matrix.install }}
- - uses: actions/checkout@v4
- - uses: actions/cache@v4
- with:
- path: ${{ github.workspace }}\.ccache
- key: ccache-${{ runner.os }}-${{ runner.arch }}-${{ matrix.preset }}
- - run: |
- Import-Module 'C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\Tools\Microsoft.VisualStudio.DevShell.dll'
- Enter-VsDevShell -VsInstallPath 'C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise' -SkipAutomaticLocation -DevCmdArguments '-arch=x64 -no_logo'
- cmake --preset "${{ matrix.preset }}" ${{ matrix.flags }}
- cmake --build --parallel --preset "${{ matrix.preset }}"
- env:
- CMAKE_GENERATOR: Ninja
- test:
- strategy:
- matrix:
- os: [ubuntu-latest, macos-latest, windows-latest]
- runs-on: ${{ matrix.os }}
- env:
- CGO_ENABLED: '1'
- GOEXPERIMENT: 'synctest'
- steps:
- - uses: actions/checkout@v4
- - uses: actions/setup-go@v5
- with:
- go-version-file: go.mod
- - uses: golangci/golangci-lint-action@v6
- with:
- args: --timeout 10m0s -v
- - run: go test ./...
- patches:
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v4
- - name: Verify patches apply cleanly and do not change files
- run: |
- make -f Makefile.sync clean sync
- git diff --compact-summary --exit-code
|