-
Notifications
You must be signed in to change notification settings - Fork 12.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #71131 - pnkfelix:issue-69798-dont-reuse-post-lto-produ…
…cts-when-exports-change, r=nagisa Do not reuse post LTO products when exports change Do not reuse post lto products when exports change Generalizes code from PR #67020, which handled case when imports change. Fix #69798
- Loading branch information
Showing
3 changed files
with
121 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
26 changes: 26 additions & 0 deletions
26
src/test/incremental/thinlto/cgu_invalidated_when_export_added.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
// revisions: cfail1 cfail2 | ||
// build-pass | ||
|
||
// rust-lang/rust#69798: | ||
// | ||
// This is analgous to cgu_invalidated_when_import_added, but it covers a | ||
// problem uncovered where a change to the *export* set caused a link failure | ||
// when reusing post-LTO optimized object code. | ||
|
||
pub struct Foo {} | ||
impl Drop for Foo { | ||
fn drop(&mut self) { | ||
println!("Dropping Foo"); | ||
} | ||
} | ||
#[no_mangle] | ||
pub extern "C" fn run() { | ||
thread_local! { pub static FOO : Foo = Foo { } ; } | ||
|
||
#[cfg(cfail2)] | ||
{ | ||
FOO.with(|_f| ()) | ||
} | ||
} | ||
|
||
pub fn main() { run() } |
26 changes: 26 additions & 0 deletions
26
src/test/incremental/thinlto/cgu_invalidated_when_export_removed.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
// revisions: cfail1 cfail2 | ||
// build-pass | ||
|
||
// rust-lang/rust#69798: | ||
// | ||
// This is analgous to cgu_invalidated_when_export_added, but it covers the | ||
// other direction. This is analogous to cgu_invalidated_when_import_added: we | ||
// include it, because it may uncover bugs in variant implementation strategies. | ||
|
||
pub struct Foo {} | ||
impl Drop for Foo { | ||
fn drop(&mut self) { | ||
println!("Dropping Foo"); | ||
} | ||
} | ||
#[no_mangle] | ||
pub extern "C" fn run() { | ||
thread_local! { pub static FOO : Foo = Foo { } ; } | ||
|
||
#[cfg(cfail1)] | ||
{ | ||
FOO.with(|_f| ()) | ||
} | ||
} | ||
|
||
pub fn main() { run() } |