Skip to content

Commit bf45975

Browse files
committed
Auto merge of rust-lang#70175 - Amanieu:remove_nlp, r=pnkfelix
Remove -Z no-landing-pads flag Since rust-lang#67502, `-Z no-landing-pads` will cause all attempted unwinds to abort since we don't generate a `try` / `catch`. This previously worked because `__rust_try` was located in libpanic_unwind which is always compiled with `-C panic=unwind`, but `__rust_try` is now directly inline into the crate that uses `catch_unwind`. As such, `-Z no-landing-pads` is now mostly useless and people should use `-C panic=abort` instead.
2 parents 7c8dbd9 + c6817ff commit bf45975

File tree

14 files changed

+57
-114
lines changed

14 files changed

+57
-114
lines changed

src/librustc_codegen_llvm/attributes.rs

+4-1
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@ use rustc_middle::ty::query::Providers;
1313
use rustc_middle::ty::{self, TyCtxt};
1414
use rustc_session::config::{OptLevel, Sanitizer};
1515
use rustc_session::Session;
16+
use rustc_target::spec::PanicStrategy;
1617

1718
use crate::attributes;
1819
use crate::llvm::AttributePlace::Function;
@@ -270,7 +271,9 @@ pub fn from_fn_attrs(cx: &CodegenCx<'ll, 'tcx>, llfn: &'ll Value, instance: ty::
270271
//
271272
// You can also find more info on why Windows is whitelisted here in:
272273
// https://bugzilla.mozilla.org/show_bug.cgi?id=1302078
273-
if !cx.sess().no_landing_pads() || cx.sess().target.target.options.requires_uwtable {
274+
if cx.sess().panic_strategy() == PanicStrategy::Unwind
275+
|| cx.sess().target.target.options.requires_uwtable
276+
{
274277
attributes::emit_uwtable(llfn, true);
275278
}
276279

src/librustc_codegen_llvm/intrinsic.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@ use rustc_middle::ty::{self, Ty};
2222
use rustc_middle::{bug, span_bug};
2323
use rustc_span::Span;
2424
use rustc_target::abi::{self, HasDataLayout, LayoutOf, Primitive};
25+
use rustc_target::spec::PanicStrategy;
2526

2627
use std::cmp::Ordering;
2728
use std::iter;
@@ -804,7 +805,7 @@ fn try_intrinsic(
804805
catch_func: &'ll Value,
805806
dest: &'ll Value,
806807
) {
807-
if bx.sess().no_landing_pads() {
808+
if bx.sess().panic_strategy() == PanicStrategy::Abort {
808809
bx.call(try_func, &[data], None);
809810
// Return 0 unconditionally from the intrinsic call;
810811
// we can never unwind.

src/librustc_codegen_ssa/back/write.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@ use rustc_session::Session;
3535
use rustc_span::hygiene::ExpnId;
3636
use rustc_span::source_map::SourceMap;
3737
use rustc_span::symbol::{sym, Symbol};
38-
use rustc_target::spec::MergeFunctions;
38+
use rustc_target::spec::{MergeFunctions, PanicStrategy};
3939

4040
use std::any::Any;
4141
use std::fs;
@@ -995,7 +995,7 @@ fn start_executing_work<B: ExtraBackendMethods>(
995995
crate_types: sess.crate_types.borrow().clone(),
996996
each_linked_rlib_for_lto,
997997
lto: sess.lto(),
998-
no_landing_pads: sess.no_landing_pads(),
998+
no_landing_pads: sess.panic_strategy() == PanicStrategy::Abort,
999999
fewer_names: sess.fewer_names(),
10001000
save_temps: sess.opts.cg.save_temps,
10011001
opts: Arc::new(sess.opts.clone()),

src/librustc_interface/tests.rs

-1
Original file line numberDiff line numberDiff line change
@@ -546,7 +546,6 @@ fn test_debugging_options_tracking_hash() {
546546
tracked!(new_llvm_pass_manager, true);
547547
tracked!(no_codegen, true);
548548
tracked!(no_generate_arange_section, true);
549-
tracked!(no_landing_pads, true);
550549
tracked!(no_link, true);
551550
tracked!(no_profiler_runtime, true);
552551
tracked!(osx_rpath_install_name, true);

src/librustc_mir/transform/generator.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -68,6 +68,7 @@ use rustc_middle::ty::subst::SubstsRef;
6868
use rustc_middle::ty::GeneratorSubsts;
6969
use rustc_middle::ty::{self, AdtDef, Ty, TyCtxt};
7070
use rustc_target::abi::VariantIdx;
71+
use rustc_target::spec::PanicStrategy;
7172
use std::borrow::Cow;
7273
use std::iter;
7374

@@ -978,7 +979,7 @@ fn can_return<'tcx>(tcx: TyCtxt<'tcx>, body: &Body<'tcx>) -> bool {
978979

979980
fn can_unwind<'tcx>(tcx: TyCtxt<'tcx>, body: &Body<'tcx>) -> bool {
980981
// Nothing can unwind when landing pads are off.
981-
if tcx.sess.no_landing_pads() {
982+
if tcx.sess.panic_strategy() == PanicStrategy::Abort {
982983
return false;
983984
}
984985

src/librustc_mir/transform/no_landing_pads.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@ use crate::transform::{MirPass, MirSource};
55
use rustc_middle::mir::visit::MutVisitor;
66
use rustc_middle::mir::*;
77
use rustc_middle::ty::TyCtxt;
8+
use rustc_target::spec::PanicStrategy;
89

910
pub struct NoLandingPads<'tcx> {
1011
tcx: TyCtxt<'tcx>,
@@ -23,7 +24,7 @@ impl<'tcx> MirPass<'tcx> for NoLandingPads<'tcx> {
2324
}
2425

2526
pub fn no_landing_pads<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) {
26-
if tcx.sess.no_landing_pads() {
27+
if tcx.sess.panic_strategy() == PanicStrategy::Abort {
2728
NoLandingPads::new(tcx).visit_body(body);
2829
}
2930
}

src/librustc_mir/transform/remove_noop_landing_pads.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -3,14 +3,15 @@ use crate::util::patch::MirPatch;
33
use rustc_index::bit_set::BitSet;
44
use rustc_middle::mir::*;
55
use rustc_middle::ty::TyCtxt;
6+
use rustc_target::spec::PanicStrategy;
67

78
/// A pass that removes noop landing pads and replaces jumps to them with
89
/// `None`. This is important because otherwise LLVM generates terrible
910
/// code for these.
1011
pub struct RemoveNoopLandingPads;
1112

1213
pub fn remove_noop_landing_pads<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) {
13-
if tcx.sess.no_landing_pads() {
14+
if tcx.sess.panic_strategy() == PanicStrategy::Abort {
1415
return;
1516
}
1617
debug!("remove_noop_landing_pads({:?})", body);

src/librustc_mir_build/build/mod.rs

-5
Original file line numberDiff line numberDiff line change
@@ -536,11 +536,6 @@ fn should_abort_on_panic(tcx: TyCtxt<'_>, fn_def_id: LocalDefId, _abi: Abi) -> b
536536
return false;
537537
}
538538

539-
// We cannot add landing pads, so don't add one.
540-
if tcx.sess.no_landing_pads() {
541-
return false;
542-
}
543-
544539
// This is a special case: some functions have a C abi but are meant to
545540
// unwind anyway. Don't stop them.
546541
match unwind_attr {

src/librustc_session/options.rs

-2
Original file line numberDiff line numberDiff line change
@@ -878,8 +878,6 @@ options! {DebuggingOptions, DebuggingSetter, basic_debugging_options,
878878
"omit DWARF address ranges that give faster lookups"),
879879
no_interleave_lints: bool = (false, parse_no_flag, [UNTRACKED],
880880
"execute lints separately; allows benchmarking individual lints"),
881-
no_landing_pads: bool = (false, parse_no_flag, [TRACKED],
882-
"omit landing pads for unwinding"),
883881
no_leak_check: bool = (false, parse_no_flag, [UNTRACKED],
884882
"disable the 'leak check' for subtyping; unsound, but useful for tests"),
885883
no_link: bool = (false, parse_no_flag, [TRACKED],

src/librustc_session/session.rs

-3
Original file line numberDiff line numberDiff line change
@@ -540,9 +540,6 @@ impl Session {
540540
self.opts.debugging_opts.fewer_names || !more_names
541541
}
542542

543-
pub fn no_landing_pads(&self) -> bool {
544-
self.opts.debugging_opts.no_landing_pads || self.panic_strategy() == PanicStrategy::Abort
545-
}
546543
pub fn unstable_options(&self) -> bool {
547544
self.opts.debugging_opts.unstable_options
548545
}

src/test/mir-opt/generator-tiny.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,8 @@
11
//! Tests that generators that cannot return or unwind don't have unnecessary
22
//! panic branches.
33
4-
// compile-flags: -Zno-landing-pads
4+
// compile-flags: -C panic=abort
5+
// no-prefer-dynamic
56

67
#![feature(generators, generator_trait)]
78

Original file line numberDiff line numberDiff line change
@@ -1,78 +1,78 @@
11
// MIR for `main::{{closure}}#0` 0 generator_resume
22
// generator_layout = GeneratorLayout { field_tys: [HasDrop], variant_fields: [[], [], [], [_0]], storage_conflicts: BitMatrix { num_rows: 1, num_columns: 1, words: [1], marker: PhantomData } }
33

4-
fn main::{{closure}}#0(_1: std::pin::Pin<&mut [generator@$DIR/generator-tiny.rs:18:16: 24:6 {u8, HasDrop, ()}]>, _2: u8) -> std::ops::GeneratorState<(), ()> {
5-
debug _x => _10; // in scope 0 at $DIR/generator-tiny.rs:18:17: 18:19
6-
let mut _0: std::ops::GeneratorState<(), ()>; // return place in scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
7-
let _3: HasDrop; // in scope 0 at $DIR/generator-tiny.rs:19:13: 19:15
8-
let mut _4: !; // in scope 0 at $DIR/generator-tiny.rs:20:9: 23:10
9-
let mut _5: (); // in scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
10-
let _6: u8; // in scope 0 at $DIR/generator-tiny.rs:21:13: 21:18
11-
let mut _7: (); // in scope 0 at $DIR/generator-tiny.rs:21:13: 21:18
12-
let _8: (); // in scope 0 at $DIR/generator-tiny.rs:22:13: 22:21
13-
let mut _9: (); // in scope 0 at $DIR/generator-tiny.rs:18:25: 18:25
14-
let _10: u8; // in scope 0 at $DIR/generator-tiny.rs:18:17: 18:19
15-
let mut _11: isize; // in scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
4+
fn main::{{closure}}#0(_1: std::pin::Pin<&mut [generator@$DIR/generator-tiny.rs:19:16: 25:6 {u8, HasDrop, ()}]>, _2: u8) -> std::ops::GeneratorState<(), ()> {
5+
debug _x => _10; // in scope 0 at $DIR/generator-tiny.rs:19:17: 19:19
6+
let mut _0: std::ops::GeneratorState<(), ()>; // return place in scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
7+
let _3: HasDrop; // in scope 0 at $DIR/generator-tiny.rs:20:13: 20:15
8+
let mut _4: !; // in scope 0 at $DIR/generator-tiny.rs:21:9: 24:10
9+
let mut _5: (); // in scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
10+
let _6: u8; // in scope 0 at $DIR/generator-tiny.rs:22:13: 22:18
11+
let mut _7: (); // in scope 0 at $DIR/generator-tiny.rs:22:13: 22:18
12+
let _8: (); // in scope 0 at $DIR/generator-tiny.rs:23:13: 23:21
13+
let mut _9: (); // in scope 0 at $DIR/generator-tiny.rs:19:25: 19:25
14+
let _10: u8; // in scope 0 at $DIR/generator-tiny.rs:19:17: 19:19
15+
let mut _11: isize; // in scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
1616
scope 1 {
17-
debug _d => (((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:18:16: 24:6 {u8, HasDrop, ()}])) as variant#3).0: HasDrop); // in scope 1 at $DIR/generator-tiny.rs:19:13: 19:15
17+
debug _d => (((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:19:16: 25:6 {u8, HasDrop, ()}])) as variant#3).0: HasDrop); // in scope 1 at $DIR/generator-tiny.rs:20:13: 20:15
1818
}
1919

2020
bb0: {
21-
_11 = discriminant((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:18:16: 24:6 {u8, HasDrop, ()}]))); // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
22-
switchInt(move _11) -> [0u32: bb1, 3u32: bb5, otherwise: bb6]; // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
21+
_11 = discriminant((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:19:16: 25:6 {u8, HasDrop, ()}]))); // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
22+
switchInt(move _11) -> [0u32: bb1, 3u32: bb5, otherwise: bb6]; // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
2323
}
2424

2525
bb1: {
26-
_10 = move _2; // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
27-
nop; // scope 0 at $DIR/generator-tiny.rs:19:13: 19:15
28-
(((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:18:16: 24:6 {u8, HasDrop, ()}])) as variant#3).0: HasDrop) = HasDrop; // scope 0 at $DIR/generator-tiny.rs:19:18: 19:25
29-
StorageLive(_4); // scope 1 at $DIR/generator-tiny.rs:20:9: 23:10
30-
goto -> bb2; // scope 1 at $DIR/generator-tiny.rs:20:9: 23:10
26+
_10 = move _2; // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
27+
nop; // scope 0 at $DIR/generator-tiny.rs:20:13: 20:15
28+
(((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:19:16: 25:6 {u8, HasDrop, ()}])) as variant#3).0: HasDrop) = HasDrop; // scope 0 at $DIR/generator-tiny.rs:20:18: 20:25
29+
StorageLive(_4); // scope 1 at $DIR/generator-tiny.rs:21:9: 24:10
30+
goto -> bb2; // scope 1 at $DIR/generator-tiny.rs:21:9: 24:10
3131
}
3232

3333
bb2: {
34-
StorageLive(_6); // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
35-
StorageLive(_7); // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
36-
_7 = (); // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
37-
_0 = std::ops::GeneratorState::<(), ()>::Yielded(move _7); // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
38-
discriminant((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:18:16: 24:6 {u8, HasDrop, ()}]))) = 3; // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
39-
return; // scope 1 at $DIR/generator-tiny.rs:21:13: 21:18
34+
StorageLive(_6); // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
35+
StorageLive(_7); // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
36+
_7 = (); // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
37+
_0 = std::ops::GeneratorState::<(), ()>::Yielded(move _7); // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
38+
discriminant((*(_1.0: &mut [generator@$DIR/generator-tiny.rs:19:16: 25:6 {u8, HasDrop, ()}]))) = 3; // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
39+
return; // scope 1 at $DIR/generator-tiny.rs:22:13: 22:18
4040
}
4141

4242
bb3: {
43-
StorageDead(_7); // scope 1 at $DIR/generator-tiny.rs:21:17: 21:18
44-
StorageDead(_6); // scope 1 at $DIR/generator-tiny.rs:21:18: 21:19
45-
StorageLive(_8); // scope 1 at $DIR/generator-tiny.rs:22:13: 22:21
46-
_8 = const callee() -> bb4; // scope 1 at $DIR/generator-tiny.rs:22:13: 22:21
43+
StorageDead(_7); // scope 1 at $DIR/generator-tiny.rs:22:17: 22:18
44+
StorageDead(_6); // scope 1 at $DIR/generator-tiny.rs:22:18: 22:19
45+
StorageLive(_8); // scope 1 at $DIR/generator-tiny.rs:23:13: 23:21
46+
_8 = const callee() -> bb4; // scope 1 at $DIR/generator-tiny.rs:23:13: 23:21
4747
// ty::Const
4848
// + ty: fn() {callee}
4949
// + val: Value(Scalar(<ZST>))
5050
// mir::Constant
51-
// + span: $DIR/generator-tiny.rs:22:13: 22:19
51+
// + span: $DIR/generator-tiny.rs:23:13: 23:19
5252
// + literal: Const { ty: fn() {callee}, val: Value(Scalar(<ZST>)) }
5353
}
5454

5555
bb4: {
56-
StorageDead(_8); // scope 1 at $DIR/generator-tiny.rs:22:21: 22:22
57-
_5 = const (); // scope 1 at $DIR/generator-tiny.rs:20:14: 23:10
56+
StorageDead(_8); // scope 1 at $DIR/generator-tiny.rs:23:21: 23:22
57+
_5 = const (); // scope 1 at $DIR/generator-tiny.rs:21:14: 24:10
5858
// ty::Const
5959
// + ty: ()
6060
// + val: Value(Scalar(<ZST>))
6161
// mir::Constant
62-
// + span: $DIR/generator-tiny.rs:20:14: 23:10
62+
// + span: $DIR/generator-tiny.rs:21:14: 24:10
6363
// + literal: Const { ty: (), val: Value(Scalar(<ZST>)) }
64-
goto -> bb2; // scope 1 at $DIR/generator-tiny.rs:20:9: 23:10
64+
goto -> bb2; // scope 1 at $DIR/generator-tiny.rs:21:9: 24:10
6565
}
6666

6767
bb5: {
68-
StorageLive(_4); // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
69-
StorageLive(_6); // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
70-
StorageLive(_7); // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
71-
_6 = move _2; // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
72-
goto -> bb3; // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
68+
StorageLive(_4); // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
69+
StorageLive(_6); // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
70+
StorageLive(_7); // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
71+
_6 = move _2; // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
72+
goto -> bb3; // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
7373
}
7474

7575
bb6: {
76-
unreachable; // scope 0 at $DIR/generator-tiny.rs:18:16: 24:6
76+
unreachable; // scope 0 at $DIR/generator-tiny.rs:19:16: 25:6
7777
}
7878
}

src/test/run-fail/mir_codegen_no_landing_pads.rs

-27
This file was deleted.

src/test/run-fail/mir_codegen_no_landing_pads_diverging.rs

-27
This file was deleted.

0 commit comments

Comments
 (0)