mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-23 07:14:28 +00:00
Emit proper lifetime start intrinsics for personality slots
We currently only emit a single call to the lifetime start intrinsic for the personality slot alloca. This happens because we create that call at the time that we create the alloca, instead of creating it each time we start using it. Because LLVM usually removes the alloca before the lifetime intrinsics are even considered, this didn't cause any problems yet, but we should fix this anyway.
This commit is contained in:
parent
e1cec5d4bf
commit
1eaa113581
@ -762,7 +762,6 @@ impl<'a, 'tcx> MirContext<'a, 'tcx> {
|
|||||||
let llretty = Type::struct_(ccx, &[Type::i8p(ccx), Type::i32(ccx)], false);
|
let llretty = Type::struct_(ccx, &[Type::i8p(ccx), Type::i32(ccx)], false);
|
||||||
let slot = bcx.alloca(llretty, "personalityslot");
|
let slot = bcx.alloca(llretty, "personalityslot");
|
||||||
self.llpersonalityslot = Some(slot);
|
self.llpersonalityslot = Some(slot);
|
||||||
Lifetime::Start.call(bcx, slot);
|
|
||||||
slot
|
slot
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -794,6 +793,7 @@ impl<'a, 'tcx> MirContext<'a, 'tcx> {
|
|||||||
let llretval = bcx.landing_pad(llretty, llpersonality, 1, self.llfn);
|
let llretval = bcx.landing_pad(llretty, llpersonality, 1, self.llfn);
|
||||||
bcx.set_cleanup(llretval);
|
bcx.set_cleanup(llretval);
|
||||||
let slot = self.get_personality_slot(&bcx);
|
let slot = self.get_personality_slot(&bcx);
|
||||||
|
Lifetime::Start.call(&bcx, slot);
|
||||||
bcx.store(llretval, slot, None);
|
bcx.store(llretval, slot, None);
|
||||||
bcx.br(target_bb);
|
bcx.br(target_bb);
|
||||||
bcx.llbb()
|
bcx.llbb()
|
||||||
|
39
src/test/codegen/personality_lifetimes.rs
Normal file
39
src/test/codegen/personality_lifetimes.rs
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
// Copyright 2017 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// compile-flags: -O -C no-prepopulate-passes
|
||||||
|
|
||||||
|
#![crate_type="lib"]
|
||||||
|
|
||||||
|
struct S;
|
||||||
|
|
||||||
|
impl Drop for S {
|
||||||
|
fn drop(&mut self) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn might_unwind() {
|
||||||
|
}
|
||||||
|
|
||||||
|
// CHECK-LABEL: @test
|
||||||
|
#[no_mangle]
|
||||||
|
pub fn test() {
|
||||||
|
let _s = S;
|
||||||
|
// Check that the personality slot alloca gets a lifetime start in each cleanup block, not just
|
||||||
|
// in the first one.
|
||||||
|
// CHECK-LABEL: cleanup:
|
||||||
|
// CHECK: bitcast{{.*}}personalityslot
|
||||||
|
// CHECK-NEXT: call void @llvm.lifetime.start
|
||||||
|
// CHECK-LABEL: cleanup1:
|
||||||
|
// CHECK: bitcast{{.*}}personalityslot
|
||||||
|
// CHECK-NEXT: call void @llvm.lifetime.start
|
||||||
|
might_unwind();
|
||||||
|
might_unwind();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user