-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This refactors the CI workflows to group some logic and makes sure that all (pre)release binaries are actually tested. The screenshot below shows the execution logic of the reworked ci, https://github.com/Disservin/Stockfish/actions/runs/7773581379. You can also hover over the cards to see the execution flow. The `matrix.json` and `arm_matrix.json` define the binaries which will be uploaded to GitHub. Afterwards a matrix is created and each job compiles a profile guided build for that arch and uploads that as an artifact to GitHub. The Binaries/ARM_Binaries workflow's are called when the previous step has been completed, and uploads all artifacts to the (pre)release. This also fixes some indentations and renames the workflows, see https://github.com/official-stockfish/Stockfish/actions, where every workflow is called `Stockfish` vs https://github.com/Disservin/Stockfish/actions. It also increases the parallel compilation used for make from `-j2 to -j4`. It now also prevents the prerelease action from running on forks. A test release can be viewed here https://github.com/Disservin/Stockfish/releases. closes #5035 No functional change
- Loading branch information
Showing
15 changed files
with
612 additions
and
622 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 |
---|---|---|
@@ -0,0 +1,51 @@ | ||
{ | ||
"config": [ | ||
{ | ||
"name": "Android NDK aarch64", | ||
"os": "ubuntu-22.04", | ||
"simple_name": "android", | ||
"compiler": "aarch64-linux-android21-clang++", | ||
"emu": "qemu-aarch64", | ||
"comp": "ndk", | ||
"shell": "bash", | ||
"archive_ext": "tar" | ||
}, | ||
{ | ||
"name": "Android NDK arm", | ||
"os": "ubuntu-22.04", | ||
"simple_name": "android", | ||
"compiler": "armv7a-linux-androideabi21-clang++", | ||
"emu": "qemu-arm", | ||
"comp": "ndk", | ||
"shell": "bash", | ||
"archive_ext": "tar" | ||
} | ||
], | ||
"binaries": ["armv8-dotprod", "armv8", "armv7", "armv7-neon"], | ||
"exclude": [ | ||
{ | ||
"binaries": "armv8-dotprod", | ||
"config": { | ||
"compiler": "armv7a-linux-androideabi21-clang++" | ||
} | ||
}, | ||
{ | ||
"binaries": "armv8", | ||
"config": { | ||
"compiler": "armv7a-linux-androideabi21-clang++" | ||
} | ||
}, | ||
{ | ||
"binaries": "armv7", | ||
"config": { | ||
"compiler": "aarch64-linux-android21-clang++" | ||
} | ||
}, | ||
{ | ||
"binaries": "armv7-neon", | ||
"config": { | ||
"compiler": "aarch64-linux-android21-clang++" | ||
} | ||
} | ||
] | ||
} |
File renamed without changes.
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 |
---|---|---|
@@ -0,0 +1,160 @@ | ||
{ | ||
"config": [ | ||
{ | ||
"name": "Ubuntu 20.04 GCC", | ||
"os": "ubuntu-20.04", | ||
"simple_name": "ubuntu", | ||
"compiler": "g++", | ||
"comp": "gcc", | ||
"shell": "bash", | ||
"archive_ext": "tar", | ||
"sde": "/home/runner/work/Stockfish/Stockfish/.output/sde-temp-files/sde-external-9.27.0-2023-09-13-lin/sde -future --" | ||
}, | ||
{ | ||
"name": "MacOS 13 Apple Clang", | ||
"os": "macos-13", | ||
"simple_name": "macos", | ||
"compiler": "clang++", | ||
"comp": "clang", | ||
"shell": "bash", | ||
"archive_ext": "tar" | ||
}, | ||
{ | ||
"name": "MacOS 14 Apple Clang M1", | ||
"os": "macos-14", | ||
"simple_name": "macos-m1", | ||
"compiler": "clang++", | ||
"comp": "clang", | ||
"shell": "bash", | ||
"archive_ext": "tar" | ||
}, | ||
{ | ||
"name": "Windows 2022 Mingw-w64 GCC x86_64", | ||
"os": "windows-2022", | ||
"simple_name": "windows", | ||
"compiler": "g++", | ||
"comp": "mingw", | ||
"msys_sys": "mingw64", | ||
"msys_env": "x86_64-gcc", | ||
"shell": "msys2 {0}", | ||
"ext": ".exe", | ||
"sde": "/d/a/Stockfish/Stockfish/.output/sde-temp-files/sde-external-9.27.0-2023-09-13-win/sde.exe -future --", | ||
"archive_ext": "zip" | ||
} | ||
], | ||
"binaries": [ | ||
"x86-64", | ||
"x86-64-sse41-popcnt", | ||
"x86-64-avx2", | ||
"x86-64-bmi2", | ||
"x86-64-avxvnni", | ||
"x86-64-avx512", | ||
"x86-64-vnni256", | ||
"x86-64-vnni512", | ||
"apple-silicon" | ||
], | ||
"exclude": [ | ||
{ | ||
"binaries": "x86-64", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-sse41-popcnt", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avx2", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-bmi2", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avxvnni", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avxvnni", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avx512", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-vnni256", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-vnni512", | ||
"config": { | ||
"os": "macos-14" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avxvnni", | ||
"config": { | ||
"ubuntu-20.04": null | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avxvnni", | ||
"config": { | ||
"os": "macos-13" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-avx512", | ||
"config": { | ||
"os": "macos-13" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-vnni256", | ||
"config": { | ||
"os": "macos-13" | ||
} | ||
}, | ||
{ | ||
"binaries": "x86-64-vnni512", | ||
"config": { | ||
"os": "macos-13" | ||
} | ||
}, | ||
{ | ||
"binaries": "apple-silicon", | ||
"config": { | ||
"os": "windows-2022" | ||
} | ||
}, | ||
{ | ||
"binaries": "apple-silicon", | ||
"config": { | ||
"os": "macos-13" | ||
} | ||
}, | ||
{ | ||
"binaries": "apple-silicon", | ||
"config": { | ||
"os": "ubuntu-20.04" | ||
} | ||
} | ||
] | ||
} |
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 |
---|---|---|
@@ -0,0 +1,94 @@ | ||
name: Compilation | ||
on: | ||
workflow_call: | ||
inputs: | ||
matrix: | ||
type: string | ||
required: true | ||
jobs: | ||
Compilation: | ||
name: ${{ matrix.config.name }} ${{ matrix.binaries }} | ||
runs-on: ${{ matrix.config.os }} | ||
env: | ||
COMPILER: ${{ matrix.config.compiler }} | ||
COMP: ${{ matrix.config.comp }} | ||
EMU: ${{ matrix.config.emu }} | ||
EXT: ${{ matrix.config.ext }} | ||
BINARY: ${{ matrix.binaries }} | ||
strategy: | ||
fail-fast: false | ||
matrix: ${{ fromJson(inputs.matrix) }} | ||
defaults: | ||
run: | ||
working-directory: src | ||
shell: ${{ matrix.config.shell }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
|
||
- name: Download required linux packages | ||
if: runner.os == 'Linux' | ||
run: | | ||
sudo apt update | ||
sudo apt install qemu-user | ||
- name: Install NDK | ||
if: runner.os == 'Linux' | ||
run: | | ||
if [ $COMP == ndk ]; then | ||
NDKV="21.4.7075529" | ||
ANDROID_ROOT=/usr/local/lib/android | ||
ANDROID_SDK_ROOT=$ANDROID_ROOT/sdk | ||
SDKMANAGER=$ANDROID_SDK_ROOT/cmdline-tools/latest/bin/sdkmanager | ||
echo "y" | $SDKMANAGER "ndk;$NDKV" | ||
ANDROID_NDK_ROOT=$ANDROID_SDK_ROOT/ndk/$NDKV | ||
ANDROID_NDK_BIN=$ANDROID_NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/bin | ||
echo "ANDROID_NDK_BIN=$ANDROID_NDK_BIN" >> $GITHUB_ENV | ||
fi | ||
- name: Extract the bench number from the commit history | ||
run: | | ||
for hash in $(git rev-list -100 HEAD); do | ||
benchref=$(git show -s $hash | tac | grep -m 1 -o -x '[[:space:]]*\b[Bb]ench[ :]\+[1-9][0-9]\{5,7\}\b[[:space:]]*' | sed 's/[^0-9]//g') && break || true | ||
done | ||
[[ -n "$benchref" ]] && echo "benchref=$benchref" >> $GITHUB_ENV && echo "From commit: $hash" && echo "Reference bench: $benchref" || echo "No bench found" | ||
- name: Download the used network from the fishtest framework | ||
run: make net | ||
|
||
- name: Check compiler | ||
run: | | ||
if [ $COMP == ndk ]; then | ||
export PATH=${{ env.ANDROID_NDK_BIN }}:$PATH | ||
fi | ||
$COMPILER -v | ||
- name: Test help target | ||
run: make help | ||
|
||
- name: Check git | ||
run: git --version | ||
|
||
# Compile profile guided builds | ||
|
||
- name: Compile ${{ matrix.binaries }} build | ||
run: | | ||
if [ $COMP == ndk ]; then | ||
export PATH=${{ env.ANDROID_NDK_BIN }}:$PATH | ||
export LDFLAGS="-static -Wno-unused-command-line-argument" | ||
fi | ||
make clean | ||
make -j4 profile-build ARCH=$BINARY COMP=$COMP WINE_PATH=$EMU | ||
make strip ARCH=$BINARY COMP=$COMP | ||
WINE_PATH=$EMU ../tests/signature.sh $benchref | ||
mv ./stockfish$EXT ../stockfish-android-$BINARY$EXT | ||
- name: Remove non src files | ||
run: git clean -fx | ||
|
||
- name: Upload artifact for (pre)-release | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: ${{ matrix.config.simple_name }} ${{ matrix.binaries }} | ||
path: . |
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
Oops, something went wrong.