-
Notifications
You must be signed in to change notification settings - Fork 12.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #122042 - GuillaumeGomez:subtree-update_cg_gcc_2024-03-…
…05, r=MarkSimulacrum Subtree update cg gcc 2024 03 05 Reopening of #121390. r? `@ghost`
- Loading branch information
Showing
81 changed files
with
7,224 additions
and
4,286 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 |
---|---|---|
|
@@ -19,8 +19,8 @@ jobs: | |
fail-fast: false | ||
matrix: | ||
libgccjit_version: | ||
- { gcc: "libgccjit.so", artifacts_branch: "master" } | ||
- { gcc: "libgccjit_without_int128.so", artifacts_branch: "master-without-128bit-integers" } | ||
- { gcc: "gcc-13.deb" } | ||
- { gcc: "gcc-13-without-int128.deb" } | ||
commands: [ | ||
"--mini-tests", | ||
"--std-tests", | ||
|
@@ -32,60 +32,39 @@ jobs: | |
"--extended-regex-tests", | ||
"--test-successful-rustc --nb-parts 2 --current-part 0", | ||
"--test-successful-rustc --nb-parts 2 --current-part 1", | ||
"--projects", | ||
] | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
||
# `rustup show` installs from rust-toolchain.toml | ||
- name: Setup rust toolchain | ||
run: rustup show | ||
|
||
- name: Setup rust cache | ||
uses: Swatinem/rust-cache@v2 | ||
|
||
- name: Install packages | ||
# `llvm-14-tools` is needed to install the `FileCheck` binary which is used for asm tests. | ||
run: sudo apt-get install ninja-build ripgrep llvm-14-tools | ||
|
||
- name: Install rustfmt | ||
run: rustup component add rustfmt | ||
|
||
- name: Download artifact | ||
uses: dawidd6/action-download-artifact@v2 | ||
with: | ||
workflow: main.yml | ||
name: gcc-13 | ||
path: gcc-13 | ||
repo: antoyo/gcc | ||
branch: ${{ matrix.libgccjit_version.artifacts_branch }} | ||
event: push | ||
search_artifacts: true # Because, instead, the action only check the last job ran and that won't work since we want multiple artifacts. | ||
run: curl -LO https://github.com/antoyo/gcc/releases/latest/download/${{ matrix.libgccjit_version.gcc }} | ||
|
||
- name: Setup path to libgccjit | ||
run: | | ||
sudo dpkg --force-overwrite -i gcc-13/gcc-13.deb | ||
echo /usr/lib/ > gcc_path | ||
sudo dpkg --force-overwrite -i ${{ matrix.libgccjit_version.gcc }} | ||
echo 'gcc-path = "/usr/lib/"' > config.toml | ||
- name: Set env | ||
run: | | ||
echo "LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "workspace="$GITHUB_WORKSPACE >> $GITHUB_ENV | ||
- name: Cache cargo installed crates | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/bin | ||
key: cargo-installed-crates2-ubuntu-latest | ||
|
||
- name: Cache cargo registry | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/registry | ||
key: ${{ runner.os }}-cargo-registry2-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo index | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/git | ||
key: ${{ runner.os }}-cargo-index-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo target dir | ||
uses: actions/cache@v3 | ||
with: | ||
path: target | ||
key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('rust-toolchain') }} | ||
echo "LIBRARY_PATH=/usr/lib" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=/usr/lib" >> $GITHUB_ENV | ||
#- name: Cache rust repository | ||
## We only clone the rust repository for rustc tests | ||
|
@@ -99,35 +78,37 @@ jobs: | |
- name: Build | ||
run: | | ||
./y.sh prepare --only-libcore | ||
# TODO: remove --features master when it is back to the default. | ||
./y.sh build --features master | ||
# TODO: remove --features master when it is back to the default. | ||
cargo test --features master | ||
./clean_all.sh | ||
./y.sh build | ||
cargo test | ||
./y.sh clean all | ||
- name: Prepare dependencies | ||
run: | | ||
git config --global user.email "[email protected]" | ||
git config --global user.name "User" | ||
./y.sh prepare | ||
# Compile is a separate step, as the actions-rs/cargo action supports error annotations | ||
- name: Compile | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --release | ||
|
||
- name: Add more failing tests because the sysroot is not compiled with LTO | ||
run: cat failing-non-lto-tests.txt >> failing-ui-tests.txt | ||
run: cat tests/failing-non-lto-tests.txt >> tests/failing-ui-tests.txt | ||
|
||
- name: Run tests | ||
run: | | ||
# TODO: remove --features master when it is back to the default. | ||
./test.sh --features master --release --clean --build-sysroot ${{ matrix.commands }} | ||
./y.sh test --release --clean --build-sysroot ${{ matrix.commands }} | ||
- name: Check formatting | ||
run: cargo fmt -- --check | ||
|
||
duplicates: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- run: python tools/check_intrinsics_duplicates.py | ||
|
||
build_system: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- name: Test build system | ||
run: | | ||
cd build_system | ||
cargo test |
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 |
---|---|---|
|
@@ -21,21 +21,25 @@ jobs: | |
libgccjit_version: | ||
- gcc: "libgccjit.so" | ||
artifacts_branch: "master" | ||
# TODO: switch back to --no-default-features in the case of libgccjit 12 when the default is to enable | ||
# master again. | ||
extra: "--features master" | ||
- gcc: "libgccjit_without_int128.so" | ||
artifacts_branch: "master-without-128bit-integers" | ||
extra: "--features master" | ||
- gcc: "libgccjit12.so" | ||
artifacts_branch: "gcc12" | ||
extra: "--no-default-features" | ||
# FIXME(antoyo): we need to set GCC_EXEC_PREFIX so that the linker can find the linker plugin. | ||
# Not sure why it's not found otherwise. | ||
env_extra: "TEST_FLAGS='-Cpanic=abort -Zpanic-abort-tests' GCC_EXEC_PREFIX=/usr/lib/gcc/" | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
||
# `rustup show` installs from rust-toolchain.toml | ||
- name: Setup rust toolchain | ||
run: rustup show | ||
|
||
- name: Setup rust cache | ||
uses: Swatinem/rust-cache@v2 | ||
|
||
- name: Install packages | ||
run: sudo apt-get install ninja-build ripgrep | ||
|
||
|
@@ -45,56 +49,27 @@ jobs: | |
|
||
- name: Setup path to libgccjit | ||
if: matrix.libgccjit_version.gcc == 'libgccjit12.so' | ||
run: echo /usr/lib/gcc/x86_64-linux-gnu/12 > gcc_path | ||
run: | | ||
echo 'gcc-path = "/usr/lib/gcc/x86_64-linux-gnu/12"' > config.toml | ||
echo "LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/12" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/12" >> $GITHUB_ENV | ||
- name: Download artifact | ||
if: matrix.libgccjit_version.gcc != 'libgccjit12.so' | ||
uses: dawidd6/action-download-artifact@v2 | ||
with: | ||
workflow: main.yml | ||
name: gcc-13 | ||
path: gcc-13 | ||
repo: antoyo/gcc | ||
branch: ${{ matrix.libgccjit_version.artifacts_branch }} | ||
event: push | ||
search_artifacts: true # Because, instead, the action only check the last job ran and that won't work since we want multiple artifacts. | ||
run: curl -LO https://github.com/antoyo/gcc/releases/latest/download/gcc-13.deb | ||
|
||
- name: Setup path to libgccjit | ||
if: matrix.libgccjit_version.gcc != 'libgccjit12.so' | ||
run: | | ||
sudo dpkg --force-overwrite -i gcc-13/gcc-13.deb | ||
echo /usr/lib/ > gcc_path | ||
sudo dpkg --force-overwrite -i gcc-13.deb | ||
echo 'gcc-path = "/usr/lib"' > config.toml | ||
echo "LIBRARY_PATH=/usr/lib" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=/usr/lib" >> $GITHUB_ENV | ||
- name: Set env | ||
run: | | ||
echo "LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "workspace="$GITHUB_WORKSPACE >> $GITHUB_ENV | ||
- name: Cache cargo installed crates | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/bin | ||
key: cargo-installed-crates2-ubuntu-latest | ||
|
||
- name: Cache cargo registry | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/registry | ||
key: ${{ runner.os }}-cargo-registry2-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo index | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/git | ||
key: ${{ runner.os }}-cargo-index-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo target dir | ||
uses: actions/cache@v3 | ||
with: | ||
path: target | ||
key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('rust-toolchain') }} | ||
|
||
#- name: Cache rust repository | ||
#uses: actions/cache@v3 | ||
#id: cache-rust-repository | ||
|
@@ -115,18 +90,11 @@ jobs: | |
if: matrix.libgccjit_version.gcc != 'libgccjit12.so' | ||
run: ./y.sh prepare | ||
|
||
# Compile is a separate step, as the actions-rs/cargo action supports error annotations | ||
- name: Compile | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --release | ||
|
||
- name: Add more failing tests because the sysroot is not compiled with LTO | ||
run: cat failing-non-lto-tests.txt >> failing-ui-tests.txt | ||
run: cat tests/failing-non-lto-tests.txt >> tests/failing-ui-tests.txt | ||
|
||
- name: Run tests | ||
id: tests | ||
run: | | ||
${{ matrix.libgccjit_version.env_extra }} ./test.sh --release --clean --build-sysroot --test-failing-rustc ${{ matrix.libgccjit_version.extra }} | tee output_log | ||
${{ matrix.libgccjit_version.env_extra }} ./y.sh test --release --clean --build-sysroot --test-failing-rustc ${{ matrix.libgccjit_version.extra }} | tee output_log | ||
rg --text "test result" output_log >> $GITHUB_STEP_SUMMARY |
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 |
---|---|---|
|
@@ -28,52 +28,32 @@ jobs: | |
# FIXME: re-enable asm tests when GCC can emit in the right syntax. | ||
# "--asm-tests", | ||
"--test-libcore", | ||
"--extended-rand-tests", | ||
"--extended-regex-example-tests", | ||
"--extended-regex-tests", | ||
"--test-successful-rustc --nb-parts 2 --current-part 0", | ||
"--test-successful-rustc --nb-parts 2 --current-part 1", | ||
] | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
||
# `rustup show` installs from rust-toolchain.toml | ||
- name: Setup rust toolchain | ||
run: rustup show | ||
|
||
- name: Setup rust cache | ||
uses: Swatinem/rust-cache@v2 | ||
|
||
- name: Install packages | ||
# `llvm-14-tools` is needed to install the `FileCheck` binary which is used for asm tests. | ||
run: sudo apt-get install ninja-build ripgrep llvm-14-tools libgccjit-12-dev | ||
|
||
- name: Setup path to libgccjit | ||
run: echo /usr/lib/gcc/x86_64-linux-gnu/12 > gcc_path | ||
run: echo 'gcc-path = "/usr/lib/gcc/x86_64-linux-gnu/12"' > config.toml | ||
|
||
- name: Set env | ||
run: | | ||
echo "LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=$(cat gcc_path)" >> $GITHUB_ENV | ||
echo "workspace="$GITHUB_WORKSPACE >> $GITHUB_ENV | ||
- name: Cache cargo installed crates | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/bin | ||
key: cargo-installed-crates2-ubuntu-latest | ||
|
||
- name: Cache cargo registry | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/registry | ||
key: ${{ runner.os }}-cargo-registry2-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo index | ||
uses: actions/cache@v3 | ||
with: | ||
path: ~/.cargo/git | ||
key: ${{ runner.os }}-cargo-index-${{ hashFiles('**/Cargo.lock') }} | ||
|
||
- name: Cache cargo target dir | ||
uses: actions/cache@v3 | ||
with: | ||
path: target | ||
key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('rust-toolchain') }} | ||
echo "LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/12" >> $GITHUB_ENV | ||
echo "LD_LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/12" >> $GITHUB_ENV | ||
#- name: Cache rust repository | ||
## We only clone the rust repository for rustc tests | ||
|
@@ -89,27 +69,20 @@ jobs: | |
./y.sh prepare --only-libcore --libgccjit12-patches | ||
./y.sh build --no-default-features --sysroot-panic-abort | ||
cargo test --no-default-features | ||
./clean_all.sh | ||
./y.sh clean all | ||
- name: Prepare dependencies | ||
run: | | ||
git config --global user.email "[email protected]" | ||
git config --global user.name "User" | ||
./y.sh prepare --libgccjit12-patches | ||
# Compile is a separate step, as the actions-rs/cargo action supports error annotations | ||
- name: Compile | ||
uses: actions-rs/[email protected] | ||
with: | ||
command: build | ||
args: --release | ||
|
||
- name: Add more failing tests for GCC 12 | ||
run: cat failing-ui-tests12.txt >> failing-ui-tests.txt | ||
run: cat tests/failing-ui-tests12.txt >> tests/failing-ui-tests.txt | ||
|
||
- name: Add more failing tests because the sysroot is not compiled with LTO | ||
run: cat failing-non-lto-tests.txt >> failing-ui-tests.txt | ||
run: cat tests/failing-non-lto-tests.txt >> tests/failing-ui-tests.txt | ||
|
||
- name: Run tests | ||
run: | | ||
./test.sh --release --clean --build-sysroot ${{ matrix.commands }} --no-default-features | ||
./y.sh test --release --clean --build-sysroot ${{ matrix.commands }} --no-default-features |
Oops, something went wrong.