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

Rollup of 9 pull requests #128248

Closed
wants to merge 36 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
c90b6b8
stabilize `const_int_from_str`
Skgland May 9, 2024
eb799cf
mark `can_not_overflow` as `#[rustc_const_stable(...)]`
Skgland Jul 4, 2024
f99df29
fix tests after rebase
Skgland Jul 4, 2024
404519a
bless tests
Skgland Jul 4, 2024
ceec6dd
update text for E0736 and E0739
folkertdev Jul 16, 2024
4bd3632
improve error message when `#[naked]` is used with `#[inline]`
folkertdev Jul 16, 2024
7e6c083
improve error message when `#[naked]` is used with `#[track-caller] a…
folkertdev Jul 16, 2024
4d082b7
add error message when `#[naked]` is used with `#[test]`
folkertdev Jul 16, 2024
4596ce6
switch to an allowlist approach
folkertdev Jul 17, 2024
0ed639f
merge error codes
folkertdev Jul 17, 2024
6f2318c
allow `#[target_feature]` on `#[naked]` functions
folkertdev Jul 23, 2024
370fcce
rustdoc: change title of search results
lolbinarycat Jul 25, 2024
587b64e
use double quotes
lolbinarycat Jul 25, 2024
caee195
Invert early exit conditions in `collect_tokens_trailing_token`.
nnethercote Jul 25, 2024
4288edb
Inline and remove `AttrWrapper::is_complete`.
nnethercote Jul 25, 2024
3d363c3
Move `is_complete` to the module that uses it.
nnethercote Jul 25, 2024
e631b1e
Invert the sense of `is_complete` and rename it as `needs_tokens`.
nnethercote Jul 25, 2024
a560810
Don't include inner attribute ranges in `CaptureState`.
nnethercote Jul 26, 2024
6e87858
Fix a comment.
nnethercote Jul 26, 2024
6ea2da5
Tweak a loop.
nnethercote Jul 26, 2024
55d37ae
Remove an unnecessary block.
nnethercote Jul 26, 2024
33b98bf
Remove redundant option that was just encoding that a slice was empty
oli-obk Jul 26, 2024
114e0dc
CI: do not respect custom try jobs for unrolled perf builds
Kobzol Jul 26, 2024
33dd288
Add a test case for `extern "C" unsafe` to the ui tests
tdittr Jul 26, 2024
3fdc991
Improve error message for `extern "C" unsafe fn()`
tdittr Jul 26, 2024
130ce49
Fix docs
harryscholes Jul 26, 2024
45e943f
use attribute name that is incompatible in error message
folkertdev Jul 26, 2024
0e50d42
Rollup merge of #124941 - Skgland:stabilize-const-int-from-str, r=dto…
tgross35 Jul 26, 2024
3d85eac
Rollup merge of #127853 - folkertdev:naked-function-error-messages, r…
tgross35 Jul 26, 2024
d4ef544
Rollup merge of #128210 - lolbinarycat:rustdoc-search-title, r=notrid…
tgross35 Jul 26, 2024
d0de531
Rollup merge of #128223 - nnethercote:refactor-collect_tokens, r=petr…
tgross35 Jul 26, 2024
97f49e1
Rollup merge of #128224 - nnethercote:fewer-replace_ranges, r=petroch…
tgross35 Jul 26, 2024
436d6aa
Rollup merge of #128226 - oli-obk:option_vs_empty_slice, r=petrochenkov
tgross35 Jul 26, 2024
caa64a5
Rollup merge of #128227 - Kobzol:ci-unrolled-perf-build-matrix, r=tgr…
tgross35 Jul 26, 2024
6257615
Rollup merge of #128229 - tdittr:unsafe-extern-abi-error, r=compiler-…
tgross35 Jul 26, 2024
2157c39
Rollup merge of #128235 - harryscholes:fix-iterator-filter-docs, r=tg…
tgross35 Jul 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
improve error message when #[naked] is used with `#[track-caller] a…
…nd `#[target-feature]``
  • Loading branch information
folkertdev committed Jul 16, 2024
commit 7e6c083873b7b98aa52d47896107af11560aeaf5
2 changes: 1 addition & 1 deletion compiler/rustc_passes/messages.ftl
Original file line number Diff line number Diff line change
Expand Up @@ -485,7 +485,7 @@ passes_naked_functions_asm_options =
passes_naked_functions_codegen_attribute =
cannot use additional code generation attributes with `#[naked]`
.label = this attribute is incompatible with `#[naked]`
.label2 = function marked with `#[naked]` here
.naked_attribute = function marked with `#[naked]` here

passes_naked_functions_must_use_noreturn =
asm in naked functions must use `noreturn` option
Expand Down
26 changes: 14 additions & 12 deletions compiler/rustc_passes/src/check_attr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -421,20 +421,22 @@ impl<'tcx> CheckAttrVisitor<'tcx> {
const FORBIDDEN: [rustc_span::Symbol; 3] =
[sym::track_caller, sym::inline, sym::target_feature];

for other_attr in attrs {
if FORBIDDEN.into_iter().any(|name| other_attr.has_name(name)) {
self.dcx().emit_err(errors::NakedFunctionCodegenAttribute {
span: other_attr.span,
naked_span: attr.span,
});

return false;
}
}

match target {
Target::Fn
| Target::Method(MethodKind::Trait { body: true } | MethodKind::Inherent) => true,
| Target::Method(MethodKind::Trait { body: true } | MethodKind::Inherent) => {
for other_attr in attrs {
if FORBIDDEN.into_iter().any(|name| other_attr.has_name(name)) {
self.dcx().emit_err(errors::NakedFunctionCodegenAttribute {
span: other_attr.span,
naked_span: attr.span,
});

return false;
}
}

true
}
// FIXME(#80564): We permit struct fields, match arms and macro defs to have an
// `#[naked]` attribute with just a lint, because we previously
// erroneously allowed it and some crates used it accidentally, to be compatible
Expand Down
2 changes: 1 addition & 1 deletion compiler/rustc_passes/src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1188,7 +1188,7 @@ pub struct NakedFunctionCodegenAttribute {
#[primary_span]
#[label]
pub span: Span,
#[label(passes_label2)]
#[label(passes_naked_attribute)]
pub naked_span: Span,
}

Expand Down
13 changes: 13 additions & 0 deletions tests/ui/asm/naked-functions-target-feature.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
//@ only-x86_64
//@ needs-asm-support
#![feature(naked_functions)]
#![crate_type = "lib"]

use std::arch::asm;

#[target_feature(enable = "sse2")]
//~^ ERROR [E0736]
#[naked]
pub unsafe extern "C" fn naked_target_feature() {
asm!("", options(noreturn));
}
12 changes: 12 additions & 0 deletions tests/ui/asm/naked-functions-target-feature.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
error[E0736]: cannot use additional code generation attributes with `#[naked]`
--> $DIR/naked-functions-target-feature.rs:8:1
|
LL | #[target_feature(enable = "sse2")]
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this attribute is incompatible with `#[naked]`
LL |
LL | #[naked]
| -------- function marked with `#[naked]` here

error: aborting due to 1 previous error

For more information about this error, try `rustc --explain E0736`.
4 changes: 2 additions & 2 deletions tests/ui/rfcs/rfc-2091-track-caller/error-with-naked.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

use std::arch::asm;

#[track_caller] //~ ERROR cannot use `#[track_caller]` with `#[naked]`
#[track_caller] //~ ERROR [E0736]
//~^ ERROR `#[track_caller]` requires Rust ABI
#[naked]
extern "C" fn f() {
Expand All @@ -15,7 +15,7 @@ extern "C" fn f() {
struct S;

impl S {
#[track_caller] //~ ERROR cannot use `#[track_caller]` with `#[naked]`
#[track_caller] //~ ERROR [E0736]
//~^ ERROR `#[track_caller]` requires Rust ABI
#[naked]
extern "C" fn g() {
Expand Down
14 changes: 10 additions & 4 deletions tests/ui/rfcs/rfc-2091-track-caller/error-with-naked.stderr
Original file line number Diff line number Diff line change
@@ -1,14 +1,20 @@
error[E0736]: cannot use `#[track_caller]` with `#[naked]`
error[E0736]: cannot use additional code generation attributes with `#[naked]`
--> $DIR/error-with-naked.rs:6:1
|
LL | #[track_caller]
| ^^^^^^^^^^^^^^^
| ^^^^^^^^^^^^^^^ this attribute is incompatible with `#[naked]`
LL |
LL | #[naked]
| -------- function marked with `#[naked]` here

error[E0736]: cannot use `#[track_caller]` with `#[naked]`
error[E0736]: cannot use additional code generation attributes with `#[naked]`
--> $DIR/error-with-naked.rs:18:5
|
LL | #[track_caller]
| ^^^^^^^^^^^^^^^
| ^^^^^^^^^^^^^^^ this attribute is incompatible with `#[naked]`
LL |
LL | #[naked]
| -------- function marked with `#[naked]` here

error[E0737]: `#[track_caller]` requires Rust ABI
--> $DIR/error-with-naked.rs:6:1
Expand Down