Skip to content

Conversation

@GuillaumeGomez
Copy link
Member

Since we're now going to make GCC backend mandatory for CI (rust-lang/rust#146414), we need to make it as easy as possible for contributors to be able to test their code with this backend as well.

r? @Kobzol

@rustbot rustbot added the S-waiting-on-review Status: this PR is waiting for a reviewer to verify its content label Sep 10, 2025
Then when running tests, add the `--test-codegen-backend gcc` option. For example:

```bash
./x.py test tests/ui --test-codegen-backend gcc
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

With this flag, it is not necessary to add gcc to codegen-backends above, no?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is still needed. The user could specify an external rustc sysroot that we don't build, and still ask for GCC to be used in tests.

--test-codegen-backend => which backend to use in tests
codegen-backends => which backends should be built and included in rustc's sysroot

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

codegen-backends => which backends should be built and included in rustc's sysroot

Does that mean that the sysroot will be built with LLVM with the config above?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If by sysroot you mean the standard library, then yes. To build the standard library with GCC, you'd need to set codegen-backends = ["gcc"].

@antoyo
Copy link

antoyo commented Sep 10, 2025

cc @RalfJung

setting in `bootstrap.toml`:

```toml
rust.codegen-backends = ["llvm", "gcc"]
Copy link
Member

@RalfJung RalfJung Sep 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since this can hit any contributor in any PR, I think it should be possible to run these tests in a one-shot way without permanently altering one's configuration.

I don't know what exactly altering the config in this way does, but if it means during my next PR it will build this backend, then that's not great -- it's unlikely to be relevant again then.

Please put yourself into the shoes of a rustc contributor that has nothing to do with the GCC backend, and is unlikely to encounter it for most of their PRs -- and tell that contributor what they should do to fix the PR where this weird failure they didn't expect shows up. :)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This can be done with ./x test ... --test-codegen-backend gcc --set 'rust.codegen-backends=["llvm", "gcc"]'. A bit of a mouthful, but it will likely be copy-pasted from the docs anyway, or stored in some local helper file.

Copy link
Member

@RalfJung RalfJung Sep 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Somewhere on this page, in a super obvious place that the reader will find immediately when going here the first time (i.e., probably at the top), should be a command to copy-paste to run the tests. That's still not the case, isn't it? I have to copy multiple things together to get the actual command I need to use.

I don't know how much more clear I can be about optimizing this for an inexperienced contributor who doesn't want to do much work on the GCC backend, they just want to fix their PR. Or even an experienced contributor who doesn't normally touch GCC but has their tests fail in GCC every 4 months (i.e., too rarely to remember the command). Please, when writing this, put yourself in the shoes of such a contributor, not in the shoes of someone who's been working on rustc and its GCC backend for years.

I think that command is

x.py test --set 'rust.codegen-backends=["llvm", "gcc"]' tests/ui --test-codegen-backend gcc

but I am not actually sure.

@GuillaumeGomez GuillaumeGomez force-pushed the gcc-backend-missing-docs branch from 1f9eb93 to f764662 Compare September 10, 2025 16:44
@GuillaumeGomez
Copy link
Member Author

I added more examples and also cases where you don't need to update bootstrap.toml.

If you don't want to build `gcc` yourself, you also need to set:

```toml
gcc.download-ci-gcc = true
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do I also have to add this to --set to avoid waiting hours until GCC is built?

Why is true not the default?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do I also have to add this to --set to avoid waiting hours until GCC is built?

Yes.

Why is true not the default?

Good question. But not something to be discussed in here I think. 😉

Copy link
Member

@Noratrieb Noratrieb Sep 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah it should really be the default for any non-dist profile. No one wants to build GCC except for the few people working on it.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Kobzol
Copy link
Member

Kobzol commented Sep 11, 2025

Hmm, the documentation was kind of all over the place, and it seemed to me that it was a bit hard to understand which command does what. I tried to restructure it, let me know what you think.

FWIW, I think that it would make more sense to have a dedicated page for each backend, rather than a "testing with XYZ backend", but for now I think this is good enough.

Zalathar added a commit to Zalathar/rust that referenced this pull request Sep 12, 2025
…r=GuillaumeGomez

Change the default value of `gcc.download-ci-gcc` to `true`

It makes sense for the vast majority of uses (rust-lang/rustc-dev-guide#2587 (comment)).

r? `@GuillaumeGomez`
Zalathar added a commit to Zalathar/rust that referenced this pull request Sep 12, 2025
…r=GuillaumeGomez

Change the default value of `gcc.download-ci-gcc` to `true`

It makes sense for the vast majority of uses (rust-lang/rustc-dev-guide#2587 (comment)).

r? ``@GuillaumeGomez``
Zalathar added a commit to Zalathar/rust that referenced this pull request Sep 12, 2025
…r=GuillaumeGomez

Change the default value of `gcc.download-ci-gcc` to `true`

It makes sense for the vast majority of uses (rust-lang/rustc-dev-guide#2587 (comment)).

r? ```@GuillaumeGomez```
rust-timer added a commit to rust-lang/rust that referenced this pull request Sep 12, 2025
Rollup merge of #146435 - Kobzol:gcc-download-default-true, r=GuillaumeGomez

Change the default value of `gcc.download-ci-gcc` to `true`

It makes sense for the vast majority of uses (rust-lang/rustc-dev-guide#2587 (comment)).

r? ```@GuillaumeGomez```
github-actions bot pushed a commit to rust-lang/miri that referenced this pull request Sep 13, 2025
…meGomez

Change the default value of `gcc.download-ci-gcc` to `true`

It makes sense for the vast majority of uses (rust-lang/rustc-dev-guide#2587 (comment)).

r? ```@GuillaumeGomez```
@Kobzol
Copy link
Member

Kobzol commented Sep 15, 2025

GCC is now downloaded by default, and the libgccjit path issue has been fixed. @GuillaumeGomez Unless you want to change something here, I'm fine with merging this to unblock rust-lang/rust#146414.

@GuillaumeGomez
Copy link
Member Author

Let's merge as is, I'll send follow-ups as I continue to work on rust-lang/rust#146414.

@GuillaumeGomez GuillaumeGomez merged commit d04eed5 into rust-lang:master Sep 18, 2025
1 check passed
@rustbot rustbot removed the S-waiting-on-review Status: this PR is waiting for a reviewer to verify its content label Sep 18, 2025
@GuillaumeGomez GuillaumeGomez deleted the gcc-backend-missing-docs branch September 18, 2025 20:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

6 participants