Auto merge of #118362 - RalfJung:panic_nounwind, r=thomcc
make sure panic_nounwind_fmt can still be fully inlined (e.g. for panic_immediate_abort) Follow-up to https://github.com/rust-lang/rust/pull/110303.
This commit is contained in:
commit
154f645d76
1 changed files with 6 additions and 3 deletions
|
@ -84,6 +84,7 @@ pub const fn panic_fmt(fmt: fmt::Arguments<'_>) -> ! {
|
||||||
#[rustc_nounwind]
|
#[rustc_nounwind]
|
||||||
#[rustc_const_unstable(feature = "core_panic", issue = "none")]
|
#[rustc_const_unstable(feature = "core_panic", issue = "none")]
|
||||||
pub const fn panic_nounwind_fmt(fmt: fmt::Arguments<'_>, force_no_backtrace: bool) -> ! {
|
pub const fn panic_nounwind_fmt(fmt: fmt::Arguments<'_>, force_no_backtrace: bool) -> ! {
|
||||||
|
#[inline] // this should always be inlined into `panic_nounwind_fmt`
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
fn runtime(fmt: fmt::Arguments<'_>, force_no_backtrace: bool) -> ! {
|
fn runtime(fmt: fmt::Arguments<'_>, force_no_backtrace: bool) -> ! {
|
||||||
if cfg!(feature = "panic_immediate_abort") {
|
if cfg!(feature = "panic_immediate_abort") {
|
||||||
|
@ -112,6 +113,7 @@ pub const fn panic_nounwind_fmt(fmt: fmt::Arguments<'_>, force_no_backtrace: boo
|
||||||
#[inline]
|
#[inline]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
const fn comptime(fmt: fmt::Arguments<'_>, _force_no_backtrace: bool) -> ! {
|
const fn comptime(fmt: fmt::Arguments<'_>, _force_no_backtrace: bool) -> ! {
|
||||||
|
// We don't unwind anyway at compile-time so we can call the regular `panic_fmt`.
|
||||||
panic_fmt(fmt);
|
panic_fmt(fmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,7 +144,8 @@ pub const fn panic(expr: &'static str) -> ! {
|
||||||
panic_fmt(fmt::Arguments::new_const(&[expr]));
|
panic_fmt(fmt::Arguments::new_const(&[expr]));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Like `panic`, but without unwinding and track_caller to reduce the impact on codesize.
|
/// Like `panic`, but without unwinding and track_caller to reduce the impact on codesize on the caller.
|
||||||
|
/// If you want `#[track_caller]` for nicer errors, call `panic_nounwind_fmt` directly.
|
||||||
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
||||||
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
||||||
#[lang = "panic_nounwind"] // needed by codegen for non-unwinding panics
|
#[lang = "panic_nounwind"] // needed by codegen for non-unwinding panics
|
||||||
|
@ -205,8 +208,8 @@ fn panic_bounds_check(index: usize, len: usize) -> ! {
|
||||||
panic!("index out of bounds: the len is {len} but the index is {index}")
|
panic!("index out of bounds: the len is {len} but the index is {index}")
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cold]
|
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
||||||
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never))]
|
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
#[lang = "panic_misaligned_pointer_dereference"] // needed by codegen for panic on misaligned pointer deref
|
#[lang = "panic_misaligned_pointer_dereference"] // needed by codegen for panic on misaligned pointer deref
|
||||||
#[rustc_nounwind] // `CheckAlignment` MIR pass requires this function to never unwind
|
#[rustc_nounwind] // `CheckAlignment` MIR pass requires this function to never unwind
|
||||||
|
|
Loading…
Add table
Reference in a new issue