diff options
author | Hans Wennborg <hans@hanshq.net> | 2013-10-17 01:13:02 +0000 |
---|---|---|
committer | Hans Wennborg <hans@hanshq.net> | 2013-10-17 01:13:02 +0000 |
commit | b74b88edac9ab490ba428aef0bdebc957399bbd7 (patch) | |
tree | 58dfe9bdbad54da6018b7a8159f9283d9179bce0 /test/CodeGen/X86 | |
parent | 88a68cbbb57aa9caef60dbd2f63d908983e77465 (diff) | |
download | llvm-b74b88edac9ab490ba428aef0bdebc957399bbd7.tar.gz llvm-b74b88edac9ab490ba428aef0bdebc957399bbd7.tar.bz2 llvm-b74b88edac9ab490ba428aef0bdebc957399bbd7.tar.xz |
Re-commit r192758 - MC: quote tricky symbol names in asm output
The reason this got reverted was that the @feat.00 symbol which was emitted
for every TU became quoted, and on cygwin/mingw we use the gas assembler which
couldn't handle the quotes.
This commit fixes the problem by only emitting @feat.00 for win32, where we use
clang -cc1as to assemble. gas would just drop this symbol anyway, so there is no
loss there.
With @feat.00 gone, there shouldn't be quoted symbols showing up on cygwin since
it uses the Itanium ABI, which doesn't put these funny characters in symbols.
> Because of win32 mangling, we produce symbol and section names with
> funny characters in them, most notably @ characters.
>
> MC would choke on trying to parse its own assembly output. This patch addresses
> that by:
>
> - Making @ trigger quoting of symbol names
> - Also quote section names in the same way
> - Just parse section names like other identifiers (to allow for quotes)
> - Don't assume @ signifies a symbol variant if it is in a string.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@192859 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/X86')
-rw-r--r-- | test/CodeGen/X86/coff-feat00.ll | 6 | ||||
-rw-r--r-- | test/CodeGen/X86/fastcall-correct-mangling.ll | 2 | ||||
-rw-r--r-- | test/CodeGen/X86/stdcall.ll | 4 |
3 files changed, 7 insertions, 5 deletions
diff --git a/test/CodeGen/X86/coff-feat00.ll b/test/CodeGen/X86/coff-feat00.ll index 1dcd427639..048aa34345 100644 --- a/test/CodeGen/X86/coff-feat00.ll +++ b/test/CodeGen/X86/coff-feat00.ll @@ -1,7 +1,9 @@ -; RUN: llc -O0 -mtriple=i386-pc-win32 -filetype=asm -o - %s | FileCheck %s +; RUN: llc -O0 -mtriple=i386-pc-win32 -filetype=asm -o - %s | FileCheck %s --check-prefix=WIN32 +; RUN: llc -O0 -mtriple=i386-pc-cygwin -filetype=asm -o - %s | FileCheck %s --check-prefix=CYGWIN define i32 @foo() { ret i32 0 } -; CHECK: @feat.00 = 1 +; WIN32: "@feat.00" = 1 +; CYGWIN-NOT: "@feat.00" = 1 diff --git a/test/CodeGen/X86/fastcall-correct-mangling.ll b/test/CodeGen/X86/fastcall-correct-mangling.ll index 3569d36541..17addbc3e1 100644 --- a/test/CodeGen/X86/fastcall-correct-mangling.ll +++ b/test/CodeGen/X86/fastcall-correct-mangling.ll @@ -3,7 +3,7 @@ ; Check that a fastcall function gets correct mangling define x86_fastcallcc void @func(i64 %X, i8 %Y, i8 %G, i16 %Z) { -; CHECK: @func@20: +; CHECK: "@func@20": ret void } diff --git a/test/CodeGen/X86/stdcall.ll b/test/CodeGen/X86/stdcall.ll index 73826ed0b2..34f90c5ee3 100644 --- a/test/CodeGen/X86/stdcall.ll +++ b/test/CodeGen/X86/stdcall.ll @@ -5,7 +5,7 @@ define internal x86_stdcallcc void @MyFunc() nounwind { entry: -; CHECK: MyFunc@0: +; CHECK: "_MyFunc@0": ; CHECK: ret ret void } @@ -20,5 +20,5 @@ entry: @B = global %0 { void (...)* bitcast (void ()* @MyFunc to void (...)*) }, align 4 ; CHECK: _B: -; CHECK: .long _MyFunc@0 +; CHECK: .long "_MyFunc@0" |