summaryrefslogtreecommitdiff
path: root/lib/Target/X86/X86COFFMachineModuleInfo.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-03-12 19:48:03 +0000
committerChris Lattner <sabre@nondot.org>2010-03-12 19:48:03 +0000
commit9c592681976f53b072cc4c26ac97fd471ceab937 (patch)
treead8ae0346d063b50f5c8e7b7d399ee70d87bda85 /lib/Target/X86/X86COFFMachineModuleInfo.cpp
parentc9747c05d1fc01678fb86b3bc4674656228269bc (diff)
downloadllvm-9c592681976f53b072cc4c26ac97fd471ceab937.tar.gz
llvm-9c592681976f53b072cc4c26ac97fd471ceab937.tar.bz2
llvm-9c592681976f53b072cc4c26ac97fd471ceab937.tar.xz
minor tidying, only do work if a function is
actually X86_StdCall or X86_FastCall. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@98374 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86COFFMachineModuleInfo.cpp')
-rw-r--r--lib/Target/X86/X86COFFMachineModuleInfo.cpp17
1 files changed, 9 insertions, 8 deletions
diff --git a/lib/Target/X86/X86COFFMachineModuleInfo.cpp b/lib/Target/X86/X86COFFMachineModuleInfo.cpp
index 8fbd20714d..2988e4f91d 100644
--- a/lib/Target/X86/X86COFFMachineModuleInfo.cpp
+++ b/lib/Target/X86/X86COFFMachineModuleInfo.cpp
@@ -28,16 +28,14 @@ X86COFFMachineModuleInfo::~X86COFFMachineModuleInfo() {
/// DecorateCygMingName - Query FunctionInfoMap and use this information for
/// various name decorations for Cygwin and MingW.
-void X86COFFMachineModuleInfo::DecorateCygMingName(MCSymbol *&NameSym,
- MCContext &Ctx,
- const Function *F,
- const TargetData &TD) {
- SmallString<128> Name(NameSym->getName().begin(), NameSym->getName().end());
-
+MCSymbol *X86COFFMachineModuleInfo::DecorateCygMingName(MCSymbol *NameSym,
+ MCContext &Ctx,
+ const Function *F,
+ const TargetData &TD) {
// We don't want to decorate non-stdcall or non-fastcall functions right now
CallingConv::ID CC = F->getCallingConv();
if (CC != CallingConv::X86_StdCall && CC != CallingConv::X86_FastCall)
- return;
+ return NameSym;
unsigned ArgWords = 0;
@@ -55,6 +53,9 @@ void X86COFFMachineModuleInfo::DecorateCygMingName(MCSymbol *&NameSym,
}
const FunctionType *FT = F->getFunctionType();
+
+ SmallString<128> Name(NameSym->getName().begin(), NameSym->getName().end());
+
// "Pure" variadic functions do not receive @0 suffix.
if (!FT->isVarArg() || FT->getNumParams() == 0 ||
(FT->getNumParams() == 1 && F->hasStructRetAttr()))
@@ -67,5 +68,5 @@ void X86COFFMachineModuleInfo::DecorateCygMingName(MCSymbol *&NameSym,
Name.insert(Name.begin(), '@');
}
- NameSym = Ctx.GetOrCreateSymbol(Name.str());
+ return Ctx.GetOrCreateSymbol(Name.str());
}