Spaces:
Running
Running
ci : add ccache action to windows-cublas job (#2893)
Browse files* ci : add ccache action to windows-cublas job
This commit adds the ccache action to the windows-cublas job. This will
allow us to cache the build artifacts and hopefully speed up the build
process.
Refs: https://github.com/ggerganov/whisper.cpp/issues/2781
- .github/workflows/build.yml +93 -8
.github/workflows/build.yml
CHANGED
|
@@ -677,14 +677,87 @@ jobs:
|
|
| 677 |
- name: Clone repository
|
| 678 |
uses: actions/checkout@v4
|
| 679 |
|
| 680 |
-
- name:
|
| 681 |
-
uses:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 682 |
|
| 683 |
-
- name: Install
|
| 684 |
-
|
| 685 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 686 |
with:
|
| 687 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 688 |
|
| 689 |
- name: Install 7-Zip
|
| 690 |
run: choco install 7zip -y
|
|
@@ -700,22 +773,34 @@ jobs:
|
|
| 700 |
- name: Configure CMake
|
| 701 |
shell: cmd
|
| 702 |
run: |
|
|
|
|
|
|
|
| 703 |
cmake -S . -B ./build -A ${{ matrix.arch }} ^
|
| 704 |
-DCMAKE_BUILD_TYPE=${{ matrix.build }} ^
|
| 705 |
-DGGML_CUDA=${{ matrix.cublas }} ^
|
| 706 |
-DCMAKE_CUDA_ARCHITECTURES=all ^
|
| 707 |
-DWHISPER_SDL2=${{ matrix.sdl2 }} ^
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 708 |
-DSDL2_DIR="%SDL2_DIR%"
|
| 709 |
|
|
|
|
|
|
|
|
|
|
|
|
|
| 710 |
- name: Build Project
|
| 711 |
shell: cmd
|
| 712 |
run: |
|
|
|
|
| 713 |
cd ./build
|
| 714 |
-
cmake --build . --config ${{ matrix.build }}
|
| 715 |
|
| 716 |
- name: Copy CUDA DLLs
|
| 717 |
run: |
|
| 718 |
-
Get-ChildItem "$
|
| 719 |
Copy-Item -Destination "build/bin/${{ matrix.build }}"
|
| 720 |
|
| 721 |
- name: Copy SDL2.dll
|
|
|
|
| 677 |
- name: Clone repository
|
| 678 |
uses: actions/checkout@v4
|
| 679 |
|
| 680 |
+
- name: Install ccache
|
| 681 |
+
uses: hendrikmuhs/ccache-action@v1.2.16
|
| 682 |
+
with:
|
| 683 |
+
key: ${{ github.job }}-${{ matrix.cuda-toolkit }}-${{ matrix.build }}
|
| 684 |
+
variant: sccache
|
| 685 |
+
evict-old-files: 1d
|
| 686 |
+
|
| 687 |
+
- name: Configure CUDA compilation cache
|
| 688 |
+
run: |
|
| 689 |
+
New-Item -Path "${{ github.workspace }}\cuda_cache" -ItemType Directory -Force
|
| 690 |
+
echo "CUDA_CACHE_PATH=${{ github.workspace }}\cuda_cache" | Out-File -FilePath $env:GITHUB_ENV -Append
|
| 691 |
+
echo "CUDA_CACHE_MAXSIZE=4294967296" | Out-File -FilePath $env:GITHUB_ENV -Append
|
| 692 |
|
| 693 |
+
- name: Install Cuda Toolkit 11.8.0
|
| 694 |
+
if: ${{ matrix.cuda-toolkit == '11.8.0' }}
|
| 695 |
+
run: |
|
| 696 |
+
mkdir -p "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0"
|
| 697 |
+
choco install unzip -y
|
| 698 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_cudart/windows-x86_64/cuda_cudart-windows-x86_64-11.8.89-archive.zip"
|
| 699 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvcc/windows-x86_64/cuda_nvcc-windows-x86_64-11.8.89-archive.zip"
|
| 700 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvrtc/windows-x86_64/cuda_nvrtc-windows-x86_64-11.8.89-archive.zip"
|
| 701 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/libcublas/windows-x86_64/libcublas-windows-x86_64-11.8.1.74-archive.zip"
|
| 702 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvtx/windows-x86_64/cuda_nvtx-windows-x86_64-11.8.86-archive.zip"
|
| 703 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/visual_studio_integration/windows-x86_64/visual_studio_integration-windows-x86_64-11.8.86-archive.zip"
|
| 704 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvprof/windows-x86_64/cuda_nvprof-windows-x86_64-11.8.87-archive.zip"
|
| 705 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_cccl/windows-x86_64/cuda_cccl-windows-x86_64-11.8.89-archive.zip"
|
| 706 |
+
unzip '*.zip' -d "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0"
|
| 707 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_cudart-windows-x86_64-11.8.89-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 708 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_nvcc-windows-x86_64-11.8.89-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 709 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_nvrtc-windows-x86_64-11.8.89-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 710 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\libcublas-windows-x86_64-11.8.1.74-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 711 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_nvtx-windows-x86_64-11.8.86-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 712 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\visual_studio_integration-windows-x86_64-11.8.86-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 713 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_nvprof-windows-x86_64-11.8.87-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 714 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\cuda_cccl-windows-x86_64-11.8.89-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" /E /I /H /Y
|
| 715 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\visual_studio_integration-windows-x86_64-11.8.86-archive\visual_studio_integration\MSBuildExtensions\*" "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Microsoft\VC\v160\BuildCustomizations" /E /I /H /Y
|
| 716 |
+
echo "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
| 717 |
+
echo "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0\libnvvp" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
| 718 |
+
echo "CUDA_PATH=C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
| 719 |
+
echo "CUDA_PATH_V11_8=C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.8.0" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
| 720 |
+
|
| 721 |
+
- name: Install Cuda Toolkit 12.2
|
| 722 |
+
if: ${{ matrix.cuda-toolkit == '12.2.0' }}
|
| 723 |
+
run: |
|
| 724 |
+
mkdir -p "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0"
|
| 725 |
+
choco install unzip -y
|
| 726 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_cudart/windows-x86_64/cuda_cudart-windows-x86_64-12.2.140-archive.zip"
|
| 727 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvcc/windows-x86_64/cuda_nvcc-windows-x86_64-12.2.140-archive.zip"
|
| 728 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvrtc/windows-x86_64/cuda_nvrtc-windows-x86_64-12.2.140-archive.zip"
|
| 729 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/libcublas/windows-x86_64/libcublas-windows-x86_64-12.2.5.6-archive.zip"
|
| 730 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvtx/windows-x86_64/cuda_nvtx-windows-x86_64-12.2.140-archive.zip"
|
| 731 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_profiler_api/windows-x86_64/cuda_profiler_api-windows-x86_64-12.2.140-archive.zip"
|
| 732 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/visual_studio_integration/windows-x86_64/visual_studio_integration-windows-x86_64-12.2.140-archive.zip"
|
| 733 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_nvprof/windows-x86_64/cuda_nvprof-windows-x86_64-12.2.142-archive.zip"
|
| 734 |
+
curl -O "https://developer.download.nvidia.com/compute/cuda/redist/cuda_cccl/windows-x86_64/cuda_cccl-windows-x86_64-12.2.140-archive.zip"
|
| 735 |
+
unzip '*.zip' -d "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0"
|
| 736 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_cudart-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 737 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_nvcc-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 738 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_nvrtc-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 739 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\libcublas-windows-x86_64-12.2.5.6-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 740 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_nvtx-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 741 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_profiler_api-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 742 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\visual_studio_integration-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 743 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_nvprof-windows-x86_64-12.2.142-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 744 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\cuda_cccl-windows-x86_64-12.2.140-archive\*" "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" /E /I /H /Y
|
| 745 |
+
xcopy "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\visual_studio_integration-windows-x86_64-12.2.140-archive\visual_studio_integration\MSBuildExtensions\*" "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Microsoft\VC\v160\BuildCustomizations" /E /I /H /Y
|
| 746 |
+
echo "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
| 747 |
+
echo "C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0\libnvvp" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
| 748 |
+
echo "CUDA_PATH=C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
| 749 |
+
echo "CUDA_PATH_V12_2=C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v12.2.0" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
| 750 |
+
|
| 751 |
+
- name: Cache CUDA compilation results
|
| 752 |
+
uses: actions/cache@v3
|
| 753 |
with:
|
| 754 |
+
path: ${{ github.workspace }}/cuda_cache
|
| 755 |
+
key: cuda-cache-${{ runner.os }}-${{ matrix.cuda-toolkit }}-${{ hashFiles('**/*.cu', '**/*.cuh') }}
|
| 756 |
+
restore-keys: |
|
| 757 |
+
cuda-cache-${{ runner.os }}-${{ matrix.cuda-toolkit }}-
|
| 758 |
+
|
| 759 |
+
- name: Add msbuild to PATH
|
| 760 |
+
uses: microsoft/setup-msbuild@v2
|
| 761 |
|
| 762 |
- name: Install 7-Zip
|
| 763 |
run: choco install 7zip -y
|
|
|
|
| 773 |
- name: Configure CMake
|
| 774 |
shell: cmd
|
| 775 |
run: |
|
| 776 |
+
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars64.bat"
|
| 777 |
+
set "CUDACXX=sccache %CUDA_PATH%\bin\nvcc.exe"
|
| 778 |
cmake -S . -B ./build -A ${{ matrix.arch }} ^
|
| 779 |
-DCMAKE_BUILD_TYPE=${{ matrix.build }} ^
|
| 780 |
-DGGML_CUDA=${{ matrix.cublas }} ^
|
| 781 |
-DCMAKE_CUDA_ARCHITECTURES=all ^
|
| 782 |
-DWHISPER_SDL2=${{ matrix.sdl2 }} ^
|
| 783 |
+
-DCMAKE_CUDA_COMPILER_LAUNCHER=sccache ^
|
| 784 |
+
-DCMAKE_C_COMPILER_LAUNCHER=sccache ^
|
| 785 |
+
-DCMAKE_CXX_COMPILER_LAUNCHER=sccache ^
|
| 786 |
+
-DCMAKE_MSVC_DEBUG_INFORMATION_FORMAT=Embedded ^
|
| 787 |
+
-DCMAKE_POLICY_CMP0141=NEW ^
|
| 788 |
-DSDL2_DIR="%SDL2_DIR%"
|
| 789 |
|
| 790 |
+
- name: Check sccache status after build
|
| 791 |
+
run: |
|
| 792 |
+
sccache --show-stats
|
| 793 |
+
|
| 794 |
- name: Build Project
|
| 795 |
shell: cmd
|
| 796 |
run: |
|
| 797 |
+
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars64.bat"
|
| 798 |
cd ./build
|
| 799 |
+
cmake --build . --config ${{ matrix.build }} -j %NUMBER_OF_PROCESSORS%
|
| 800 |
|
| 801 |
- name: Copy CUDA DLLs
|
| 802 |
run: |
|
| 803 |
+
Get-ChildItem "$env:CUDA_PATH\bin\" -Filter "*.dll" |
|
| 804 |
Copy-Item -Destination "build/bin/${{ matrix.build }}"
|
| 805 |
|
| 806 |
- name: Copy SDL2.dll
|