2006-09-07 22:05:02 +00:00
|
|
|
//=====-- PPCTargetAsmInfo.h - PPC asm properties -------------*- C++ -*--====//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-29 20:36:04 +00:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2006-09-07 22:05:02 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file contains the declaration of the DarwinTargetAsmInfo class.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef PPCTARGETASMINFO_H
|
|
|
|
#define PPCTARGETASMINFO_H
|
|
|
|
|
2008-09-25 21:00:33 +00:00
|
|
|
#include "PPCTargetMachine.h"
|
2006-09-07 22:05:02 +00:00
|
|
|
#include "llvm/Target/TargetAsmInfo.h"
|
2008-08-08 18:23:25 +00:00
|
|
|
#include "llvm/Target/DarwinTargetAsmInfo.h"
|
2008-08-08 18:23:49 +00:00
|
|
|
#include "llvm/Target/ELFTargetAsmInfo.h"
|
2008-09-25 21:00:33 +00:00
|
|
|
#include "llvm/Support/Compiler.h"
|
2006-09-07 22:05:02 +00:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
2008-09-25 21:00:33 +00:00
|
|
|
template <class BaseTAI>
|
|
|
|
struct PPCTargetAsmInfo : public BaseTAI {
|
|
|
|
explicit PPCTargetAsmInfo(const PPCTargetMachine &TM):
|
|
|
|
BaseTAI(TM) {
|
|
|
|
const PPCSubtarget *Subtarget = &TM.getSubtarget<PPCSubtarget>();
|
|
|
|
bool isPPC64 = Subtarget->isPPC64();
|
|
|
|
|
|
|
|
BaseTAI::ZeroDirective = "\t.space\t";
|
|
|
|
BaseTAI::SetDirective = "\t.set";
|
|
|
|
BaseTAI::Data64bitsDirective = isPPC64 ? "\t.quad\t" : 0;
|
|
|
|
BaseTAI::AlignmentIsInBytes = false;
|
|
|
|
BaseTAI::LCOMMDirective = "\t.lcomm\t";
|
|
|
|
BaseTAI::InlineAsmStart = "# InlineAsm Start";
|
|
|
|
BaseTAI::InlineAsmEnd = "# InlineAsm End";
|
|
|
|
BaseTAI::AssemblerDialect = Subtarget->getAsmFlavor();
|
|
|
|
}
|
2008-09-25 07:38:08 +00:00
|
|
|
};
|
2008-09-24 22:22:54 +00:00
|
|
|
|
2008-09-25 21:00:33 +00:00
|
|
|
typedef PPCTargetAsmInfo<TargetAsmInfo> PPCGenericTargetAsmInfo;
|
|
|
|
|
|
|
|
EXTERN_TEMPLATE_INSTANTIATION(class PPCTargetAsmInfo<TargetAsmInfo>);
|
|
|
|
|
|
|
|
struct PPCDarwinTargetAsmInfo : public PPCTargetAsmInfo<DarwinTargetAsmInfo> {
|
2008-07-19 21:44:57 +00:00
|
|
|
explicit PPCDarwinTargetAsmInfo(const PPCTargetMachine &TM);
|
2008-02-29 22:09:08 +00:00
|
|
|
virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
|
|
|
|
bool Global) const;
|
2008-12-19 10:55:56 +00:00
|
|
|
virtual const char *getEHGlobalPrefix() const;
|
2006-09-07 22:05:02 +00:00
|
|
|
};
|
|
|
|
|
2008-09-25 21:00:33 +00:00
|
|
|
struct PPCLinuxTargetAsmInfo : public PPCTargetAsmInfo<ELFTargetAsmInfo> {
|
2008-07-19 21:44:57 +00:00
|
|
|
explicit PPCLinuxTargetAsmInfo(const PPCTargetMachine &TM);
|
2008-02-29 22:09:08 +00:00
|
|
|
virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
|
|
|
|
bool Global) const;
|
2006-12-21 20:26:09 +00:00
|
|
|
};
|
|
|
|
|
2006-09-07 22:05:02 +00:00
|
|
|
} // namespace llvm
|
|
|
|
|
|
|
|
#endif
|