forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
rustc: Add
_imp_
symbols later in compilation
On MSVC targets rustc will add symbols prefixed with `_imp_` to LLVM modules to "emulate" dllexported statics as that workaround is still in place after rust-lang#27438 hasn't been solved otherwise. These statics, however, were getting gc'd by ThinLTO accidentally which later would cause linking failures. This commit updates the location we add such symbols to happen just before codegen to ensure that (a) they're not eliminated by the optimizer and (b) the optimizer doesn't even worry about them. Closes rust-lang#45347
- Loading branch information
1 parent
0be6863
commit 3541ffb
Showing
4 changed files
with
115 additions
and
50 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
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
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,21 @@ | ||
// 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. | ||
|
||
// no-prefer-dynamic | ||
// compile-flags: -Z thinlto -C codegen-units=8 -C prefer-dynamic | ||
|
||
#![crate_type = "rlib"] | ||
#![crate_type = "dylib"] | ||
|
||
pub static A: u32 = 43; | ||
|
||
pub mod a { | ||
pub static A: u32 = 43; | ||
} |
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,31 @@ | ||
// 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. | ||
|
||
// aux-build:msvc-imp-present.rs | ||
// compile-flags: -Z thinlto -C codegen-units=8 | ||
// min-llvm-version: 4.0 | ||
// no-prefer-dynamic | ||
|
||
// On MSVC we have a "hack" where we emit symbols that look like `_imp_$name` | ||
// for all exported statics. This is done because we apply `dllimport` to all | ||
// imported constants and this allows everything to actually link correctly. | ||
// | ||
// The ThinLTO passes aggressively remove symbols if they can, and this test | ||
// asserts that the ThinLTO passes don't remove these compiler-generated | ||
// `_imp_*` symbols. The external library that we link in here is compiled with | ||
// ThinLTO and multiple codegen units and has a few exported constants. Note | ||
// that we also namely compile the library as both a dylib and an rlib, but we | ||
// link the rlib to ensure that we assert those generated symbols exist. | ||
|
||
extern crate msvc_imp_present as bar; | ||
|
||
fn main() { | ||
println!("{}", bar::A); | ||
} |