2009-09-20 06:45:52 +00:00
|
|
|
//===-- llvm/CodeGen/X86COFFMachineModuleInfo.cpp -------------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This is an MMI implementation for X86 COFF (windows) targets.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "X86COFFMachineModuleInfo.h"
|
|
|
|
#include "X86MachineFunctionInfo.h"
|
|
|
|
#include "llvm/DerivedTypes.h"
|
|
|
|
#include "llvm/Function.h"
|
2010-01-16 00:51:39 +00:00
|
|
|
#include "llvm/MC/MCContext.h"
|
|
|
|
#include "llvm/MC/MCSymbol.h"
|
2009-09-20 06:45:52 +00:00
|
|
|
#include "llvm/Target/TargetData.h"
|
|
|
|
#include "llvm/ADT/SmallString.h"
|
|
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
|
2010-03-12 19:42:40 +00:00
|
|
|
X86COFFMachineModuleInfo::~X86COFFMachineModuleInfo() {
|
2009-09-20 06:45:52 +00:00
|
|
|
}
|
|
|
|
|
2010-03-12 19:42:40 +00:00
|
|
|
/// DecorateCygMingName - Query FunctionInfoMap and use this information for
|
|
|
|
/// various name decorations for Cygwin and MingW.
|
2010-03-12 19:48:03 +00:00
|
|
|
MCSymbol *X86COFFMachineModuleInfo::DecorateCygMingName(MCSymbol *NameSym,
|
|
|
|
MCContext &Ctx,
|
|
|
|
const Function *F,
|
|
|
|
const TargetData &TD) {
|
2009-09-20 06:45:52 +00:00
|
|
|
// 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)
|
2010-03-12 19:48:03 +00:00
|
|
|
return NameSym;
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2010-02-12 15:28:40 +00:00
|
|
|
unsigned ArgWords = 0;
|
2010-03-12 19:31:03 +00:00
|
|
|
|
|
|
|
// Calculate arguments sizes
|
|
|
|
for (Function::const_arg_iterator AI = F->arg_begin(), AE = F->arg_end();
|
|
|
|
AI != AE; ++AI) {
|
|
|
|
const Type *Ty = AI->getType();
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2010-03-12 19:31:03 +00:00
|
|
|
// 'Dereference' type in case of byval parameter attribute
|
|
|
|
if (AI->hasByValAttr())
|
|
|
|
Ty = cast<PointerType>(Ty)->getElementType();
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2010-03-12 19:31:03 +00:00
|
|
|
// Size should be aligned to DWORD boundary
|
|
|
|
ArgWords += ((TD.getTypeAllocSize(Ty) + 3)/4)*4;
|
|
|
|
}
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2009-09-20 06:45:52 +00:00
|
|
|
const FunctionType *FT = F->getFunctionType();
|
2010-03-12 19:48:03 +00:00
|
|
|
|
|
|
|
SmallString<128> Name(NameSym->getName().begin(), NameSym->getName().end());
|
|
|
|
|
2009-09-20 06:45:52 +00:00
|
|
|
// "Pure" variadic functions do not receive @0 suffix.
|
|
|
|
if (!FT->isVarArg() || FT->getNumParams() == 0 ||
|
|
|
|
(FT->getNumParams() == 1 && F->hasStructRetAttr()))
|
2010-02-12 15:28:40 +00:00
|
|
|
raw_svector_ostream(Name) << '@' << ArgWords;
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2010-02-12 15:28:40 +00:00
|
|
|
if (CC == CallingConv::X86_FastCall) {
|
2009-09-20 06:45:52 +00:00
|
|
|
if (Name[0] == '_')
|
|
|
|
Name[0] = '@';
|
|
|
|
else
|
|
|
|
Name.insert(Name.begin(), '@');
|
2010-02-12 15:28:40 +00:00
|
|
|
}
|
2010-03-12 19:42:40 +00:00
|
|
|
|
2010-03-12 19:48:03 +00:00
|
|
|
return Ctx.GetOrCreateSymbol(Name.str());
|
2009-09-20 06:45:52 +00:00
|
|
|
}
|