Reduce the number of drop-flag assignments in unwind paths
This commit is contained in:
parent
611988551f
commit
54aa418a60
@ -361,6 +361,7 @@ impl<'b, 'a, 'tcx> Gatherer<'b, 'a, 'tcx> {
|
||||
fn gather_terminator(&mut self, term: &Terminator<'tcx>) {
|
||||
match term.kind {
|
||||
TerminatorKind::Goto { target: _ }
|
||||
| TerminatorKind::Return
|
||||
| TerminatorKind::Resume
|
||||
| TerminatorKind::Abort
|
||||
| TerminatorKind::GeneratorDrop
|
||||
@ -368,10 +369,6 @@ impl<'b, 'a, 'tcx> Gatherer<'b, 'a, 'tcx> {
|
||||
| TerminatorKind::FalseUnwind { .. }
|
||||
| TerminatorKind::Unreachable => {}
|
||||
|
||||
TerminatorKind::Return => {
|
||||
self.gather_move(Place::return_place());
|
||||
}
|
||||
|
||||
TerminatorKind::Assert { ref cond, .. } => {
|
||||
self.gather_operand(cond);
|
||||
}
|
||||
|
@ -163,8 +163,6 @@ where
|
||||
.patch_terminator(bb, TerminatorKind::Goto { target: self.succ });
|
||||
}
|
||||
DropStyle::Static => {
|
||||
let loc = self.terminator_loc(bb);
|
||||
self.elaborator.clear_drop_flag(loc, self.path, DropFlagMode::Deep);
|
||||
self.elaborator.patch().patch_terminator(
|
||||
bb,
|
||||
TerminatorKind::Drop {
|
||||
@ -175,9 +173,7 @@ where
|
||||
);
|
||||
}
|
||||
DropStyle::Conditional => {
|
||||
let unwind = self.unwind; // FIXME(#43234)
|
||||
let succ = self.succ;
|
||||
let drop_bb = self.complete_drop(Some(DropFlagMode::Deep), succ, unwind);
|
||||
let drop_bb = self.complete_drop(self.succ, self.unwind);
|
||||
self.elaborator
|
||||
.patch()
|
||||
.patch_terminator(bb, TerminatorKind::Goto { target: drop_bb });
|
||||
@ -249,7 +245,7 @@ where
|
||||
// our own drop flag.
|
||||
path: self.path,
|
||||
}
|
||||
.complete_drop(None, succ, unwind)
|
||||
.complete_drop(succ, unwind)
|
||||
}
|
||||
}
|
||||
|
||||
@ -278,13 +274,7 @@ where
|
||||
// Clear the "master" drop flag at the end. This is needed
|
||||
// because the "master" drop protects the ADT's discriminant,
|
||||
// which is invalidated after the ADT is dropped.
|
||||
let (succ, unwind) = (self.succ, self.unwind); // FIXME(#43234)
|
||||
(
|
||||
self.drop_flag_reset_block(DropFlagMode::Shallow, succ, unwind),
|
||||
unwind.map(|unwind| {
|
||||
self.drop_flag_reset_block(DropFlagMode::Shallow, unwind, Unwind::InCleanup)
|
||||
}),
|
||||
)
|
||||
(self.drop_flag_reset_block(DropFlagMode::Shallow, self.succ, self.unwind), self.unwind)
|
||||
}
|
||||
|
||||
/// Creates a full drop ladder, consisting of 2 connected half-drop-ladders
|
||||
@ -820,11 +810,7 @@ where
|
||||
self.open_drop_for_adt(def, substs)
|
||||
}
|
||||
}
|
||||
ty::Dynamic(..) => {
|
||||
let unwind = self.unwind; // FIXME(#43234)
|
||||
let succ = self.succ;
|
||||
self.complete_drop(Some(DropFlagMode::Deep), succ, unwind)
|
||||
}
|
||||
ty::Dynamic(..) => self.complete_drop(self.succ, self.unwind),
|
||||
ty::Array(ety, size) => {
|
||||
let size = size.try_eval_usize(self.tcx(), self.elaborator.param_env());
|
||||
self.open_drop_for_array(ety, size)
|
||||
@ -835,20 +821,10 @@ where
|
||||
}
|
||||
}
|
||||
|
||||
fn complete_drop(
|
||||
&mut self,
|
||||
drop_mode: Option<DropFlagMode>,
|
||||
succ: BasicBlock,
|
||||
unwind: Unwind,
|
||||
) -> BasicBlock {
|
||||
debug!("complete_drop({:?},{:?})", self, drop_mode);
|
||||
fn complete_drop(&mut self, succ: BasicBlock, unwind: Unwind) -> BasicBlock {
|
||||
debug!("complete_drop(succ={:?}, unwind={:?})", succ, unwind);
|
||||
|
||||
let drop_block = self.drop_block(succ, unwind);
|
||||
let drop_block = if let Some(mode) = drop_mode {
|
||||
self.drop_flag_reset_block(mode, drop_block, unwind)
|
||||
} else {
|
||||
drop_block
|
||||
};
|
||||
|
||||
self.drop_flag_test_block(drop_block, succ, unwind)
|
||||
}
|
||||
@ -861,6 +837,11 @@ where
|
||||
) -> BasicBlock {
|
||||
debug!("drop_flag_reset_block({:?},{:?})", self, mode);
|
||||
|
||||
if unwind.is_cleanup() {
|
||||
// The drop flag isn't read again on the unwind path, so don't
|
||||
// bother setting it.
|
||||
return succ;
|
||||
}
|
||||
let block = self.new_block(unwind, TerminatorKind::Goto { target: succ });
|
||||
let block_start = Location { block, statement_index: 0 };
|
||||
self.elaborator.clear_drop_flag(block_start, self.path, mode);
|
||||
@ -969,11 +950,6 @@ where
|
||||
self.elaborator.patch().new_temp(ty, self.source_info.span)
|
||||
}
|
||||
|
||||
fn terminator_loc(&mut self, bb: BasicBlock) -> Location {
|
||||
let body = self.elaborator.body();
|
||||
self.elaborator.patch().terminator_loc(body, bb)
|
||||
}
|
||||
|
||||
fn constant_usize(&self, val: u16) -> Operand<'tcx> {
|
||||
Operand::Constant(box Constant {
|
||||
span: self.source_info.span,
|
||||
|
Loading…
Reference in New Issue
Block a user