Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Make #[repr(Rust)] incompatible with other (non-modifier) representation hints like C and simd #116829

Merged
merged 1 commit into from
Oct 19, 2023

Conversation

fmease
Copy link
Member

@fmease fmease commented Oct 17, 2023

Read more about this change here: #116829 (comment).

Fixes [after backport] #116825.

@fmease fmease added the beta-nominated Nominated for backporting to the compiler in the beta channel. label Oct 17, 2023
@rustbot
Copy link
Collaborator

rustbot commented Oct 17, 2023

r? @b-naber

(rustbot has picked a reviewer for you, use r? to override)

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Oct 17, 2023
#[derive(LintDiagnostic)]
#[diag(passes_repr_conflicting, code = "E0566")]
pub struct ReprConflicting;
pub struct ReprConflictingLint;
Copy link
Member

Choose a reason for hiding this comment

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

If you're interested in a follow-up, it's probably time to bump this lint up to a hard-error 😸

@compiler-errors
Copy link
Member

I think this is pretty obviously an error, but since T-lang's triage meeting is tomorrow, I guess it doesn't hurt to wait until then. r=me after, though.

@fmease fmease added T-lang Relevant to the language team, which will review and decide on the PR/issue. I-lang-nominated Nominated for discussion during a lang team meeting. labels Oct 17, 2023
@fmease fmease force-pushed the rust-aint-c branch 2 times, most recently from cf1fba5 to cae6344 Compare October 17, 2023 11:34
@WaffleLapkin
Copy link
Member

WaffleLapkin commented Oct 18, 2023

Consensus from the lang team triage meeting (minutes):

  • We should allow repr(Rust, aligned(N))
  • We should allow repr(Rust, packed)
  • We should ban all other repr(Rust, other) combinations, including, but not necesseraly limited to:
    • C
    • transparent
    • i* and u* (u8, i8, u16, ...)
    • simd

@WaffleLapkin
Copy link
Member

WaffleLapkin commented Oct 18, 2023

Personally I think we can allow Rust, u*/i*, but since we didn't come to a consensus on this in the meeting, let's pospone this desicion to later.

This PR can probably be merged as-is, but someone needs to create a follow-up with banning all other combinations.

@fmease
Copy link
Member Author

fmease commented Oct 18, 2023

Imma update this PR instead of creating another one, otherwise we'd need to backport 2 PRs.

@fmease fmease added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Oct 18, 2023
@fmease fmease added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. I-lang-nominated Nominated for discussion during a lang team meeting. labels Oct 18, 2023
@fmease
Copy link
Member Author

fmease commented Oct 18, 2023

We already have positive behavior tests for #[repr(Rust, align(N))] and #[repr(Rust, packed)] in tests/ui/abi/explicit_repr_rust.rs.

@fmease fmease changed the title Make #[repr(Rust)] and #[repr(C)] incompatible with one another Make #[repr(Rust)] incompatible with other (non-modifier) representations like C and simd Oct 18, 2023
@fmease fmease changed the title Make #[repr(Rust)] incompatible with other (non-modifier) representations like C and simd Make #[repr(Rust)] incompatible with other (non-modifier) representation hints like C and simd Oct 18, 2023
self.tcx.sess.emit_err(errors::TransparentIncompatible {
hint_spans,
target: target.to_string(),
});
}
if is_explicit_rust && (int_reprs > 0 || is_c || is_simd) {
Copy link
Member Author

Choose a reason for hiding this comment

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

I could also turn the bools into a bitfield and check if the difference between the set bitflags and {Rust, align, packed} is empty to address “but not necessarily limited to” part of

We should ban all other repr(Rust, other) combinations, including, but not necesseraly limited to

Copy link
Member

Choose a reason for hiding this comment

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

I think refactoring this function would be a lot of good, as the current code seems to be error-prone and confusing. But obv this refactoring can come as a follow-up, which does not need a backport. (cc me if you'll do it please)

Copy link
Member

Choose a reason for hiding this comment

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

One of the things that would be nice is to default to disallowing, so that no changes can accidentally allow new combinations.

@compiler-errors
Copy link
Member

@bors r+

@bors
Copy link
Contributor

bors commented Oct 18, 2023

📌 Commit d0b99e3 has been approved by compiler-errors

It is now in the queue for this repository.

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Oct 18, 2023
bors added a commit to rust-lang-ci/rust that referenced this pull request Oct 19, 2023
Rollup of 7 pull requests

Successful merges:

 - rust-lang#116663 (Don't ICE when encountering unresolved regions in `fully_resolve`)
 - rust-lang#116761 (Fix podman detection in CI scripts)
 - rust-lang#116795 (Add `#[track_caller]` to `Option::unwrap_or_else`)
 - rust-lang#116829 (Make `#[repr(Rust)]` incompatible with other (non-modifier) representation hints like `C` and `simd`)
 - rust-lang#116883 (Change my name in mailmap)
 - rust-lang#116908 (Tweak wording of type errors involving type params)
 - rust-lang#116912 (Some renaming nits for `rustc_type_ir`)

r? `@ghost`
`@rustbot` modify labels: rollup
@bors bors merged commit 2eb6e5f into rust-lang:master Oct 19, 2023
@rustbot rustbot added this to the 1.75.0 milestone Oct 19, 2023
rust-timer added a commit to rust-lang-ci/rust that referenced this pull request Oct 19, 2023
Rollup merge of rust-lang#116829 - fmease:rust-aint-c, r=compiler-errors

Make `#[repr(Rust)]` incompatible with other (non-modifier) representation hints like `C` and `simd`

Read more about this change here: rust-lang#116829 (comment).

Fixes [after backport] rust-lang#116825.
@fmease fmease deleted the rust-aint-c branch October 19, 2023 12:02
@apiraino
Copy link
Contributor

Beta backport accepted as per compiler team on Zulip

@rustbot label +beta-accepted

@rustbot rustbot added the beta-accepted Accepted for backporting to the compiler in the beta channel. label Oct 19, 2023
@cuviper cuviper modified the milestones: 1.75.0, 1.74.0 Oct 21, 2023
@cuviper cuviper removed the beta-nominated Nominated for backporting to the compiler in the beta channel. label Oct 21, 2023
bors added a commit to rust-lang-ci/rust that referenced this pull request Oct 21, 2023
[beta] backports and stage0 bump

- Bump stage0 to released stable compiler
- Hide host effect params from docs rust-lang#116670
- Fix a performance regression in obligation deduplication. rust-lang#116826
- Make `#[repr(Rust)]` and `#[repr(C)]` incompatible with one another rust-lang#116829
- Update to LLVM 17.0.3 rust-lang#116840
- Disable effects in libcore again rust-lang#116856
- revert rust-lang#114586 rust-lang#116879

r? cuviper
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
beta-accepted Accepted for backporting to the compiler in the beta channel. S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-lang Relevant to the language team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants