Skip to content

Commit

Permalink
Rollup merge of rust-lang#61195 - davidtwco:seg-fault-mangler, r=eddyb
Browse files Browse the repository at this point in the history
Special-case `.llvm` in mangler

Fixes rust-lang#60925 and fixes rust-lang#53912.

r? @michaelwoerister
cc @eddyb
  • Loading branch information
Centril authored May 28, 2019
2 parents 745af72 + 9c34473 commit dae331d
Show file tree
Hide file tree
Showing 4 changed files with 87 additions and 0 deletions.
3 changes: 3 additions & 0 deletions src/librustc_codegen_utils/symbol_names.rs
Original file line number Diff line number Diff line change
Expand Up @@ -629,6 +629,9 @@ impl fmt::Write for SymbolPrinter<'_, '_> {
// for ':' and '-'
'-' | ':' => self.path.temp_buf.push('.'),

// Avoid segmentation fault on some platforms, see #60925.
'm' if self.path.temp_buf.ends_with(".llv") => self.path.temp_buf.push_str("$6d$"),

// These are legal symbols
'a'..='z' | 'A'..='Z' | '0'..='9' | '_' | '.' | '$' => self.path.temp_buf.push(c),

Expand Down
37 changes: 37 additions & 0 deletions src/test/ui/issue-53912.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// compile-pass

// This test is the same code as in ui/symbol-names/issue-60925.rs but this checks that the
// reproduction compiles successfully and doesn't segfault, whereas that test just checks that the
// symbol mangling fix produces the correct result.

fn dummy() {}

mod llvm {
pub(crate) struct Foo;
}
mod foo {
pub(crate) struct Foo<T>(T);

impl Foo<::llvm::Foo> {
pub(crate) fn foo() {
for _ in 0..0 {
for _ in &[::dummy()] {
::dummy();
::dummy();
::dummy();
}
}
}
}

pub(crate) fn foo() {
Foo::foo();
Foo::foo();
}
}

pub fn foo() {
foo::foo();
}

fn main() {}
39 changes: 39 additions & 0 deletions src/test/ui/symbol-names/issue-60925.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#![feature(rustc_attrs)]

// This test is the same code as in ui/issue-53912.rs but this test checks that the symbol mangling
// fix produces the correct result, whereas that test just checks that the reproduction compiles
// successfully and doesn't segfault

fn dummy() {}

mod llvm {
pub(crate) struct Foo;
}
mod foo {
pub(crate) struct Foo<T>(T);

impl Foo<::llvm::Foo> {
#[rustc_symbol_name]
//~^ ERROR _ZN11issue_609253foo36Foo$LT$issue_60925..llv$6d$..Foo$GT$3foo17h059a991a004536adE
pub(crate) fn foo() {
for _ in 0..0 {
for _ in &[::dummy()] {
::dummy();
::dummy();
::dummy();
}
}
}
}

pub(crate) fn foo() {
Foo::foo();
Foo::foo();
}
}

pub fn foo() {
foo::foo();
}

fn main() {}
8 changes: 8 additions & 0 deletions src/test/ui/symbol-names/issue-60925.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
error: symbol-name(_ZN11issue_609253foo36Foo$LT$issue_60925..llv$6d$..Foo$GT$3foo17h059a991a004536adE)
--> $DIR/issue-60925.rs:16:9
|
LL | #[rustc_symbol_name]
| ^^^^^^^^^^^^^^^^^^^^

error: aborting due to previous error

0 comments on commit dae331d

Please sign in to comment.