summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h
diff options
context:
space:
mode:
authorScott Michel <scottm@aero.org>2008-11-07 04:36:25 +0000
committerScott Michel <scottm@aero.org>2008-11-07 04:36:25 +0000
commit34d93f85721725c8aeeb99a9f709f130c6c2c9f7 (patch)
treeec6c0f65c5b378b072845b377f96cf1d4e69b6ba /llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h
parent3391cb00fc7c3668486a27e212ea7aa794f1bd90 (diff)
downloadbcm5719-llvm-34d93f85721725c8aeeb99a9f709f130c6c2c9f7.tar.gz
bcm5719-llvm-34d93f85721725c8aeeb99a9f709f130c6c2c9f7.zip
Teach CellSPU about ELF sections and new section emitter classes.
NB: This is likely to need more work. llvm-svn: 58832
Diffstat (limited to 'llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h')
-rw-r--r--llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h33
1 files changed, 27 insertions, 6 deletions
diff --git a/llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h b/llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h
index 01036bc8c92..d10a5654059 100644
--- a/llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h
+++ b/llvm/lib/Target/CellSPU/SPUTargetAsmInfo.h
@@ -11,20 +11,41 @@
//
//===----------------------------------------------------------------------===//
-#ifndef PPCTARGETASMINFO_H
-#define PPCTARGETASMINFO_H
+#ifndef SPUTARGETASMINFO_H
+#define SPUTARGETASMINFO_H
#include "llvm/Target/TargetAsmInfo.h"
+#include "llvm/Target/ELFTargetAsmInfo.h"
+#include "SPUTargetMachine.h"
+#include "SPUSubtarget.h"
namespace llvm {
// Forward declaration.
class SPUTargetMachine;
+
+ template <class BaseTAI>
+ struct SPUTargetAsmInfo : public BaseTAI {
+ explicit SPUTargetAsmInfo(const SPUTargetMachine &TM):
+ BaseTAI(TM) {
+ /* (unused today)
+ * const SPUSubtarget *Subtarget = &TM.getSubtarget<SPUSubtarget>(); */
- struct SPUTargetAsmInfo : public TargetAsmInfo {
- SPUTargetAsmInfo(const SPUTargetMachine &TM);
+ BaseTAI::ZeroDirective = "\t.space\t";
+ BaseTAI::SetDirective = "\t.set";
+ BaseTAI::Data64bitsDirective = "\t.quad\t";
+ BaseTAI::AlignmentIsInBytes = false;
+ BaseTAI::LCOMMDirective = "\t.lcomm\t";
+ BaseTAI::InlineAsmStart = "# InlineAsm Start";
+ BaseTAI::InlineAsmEnd = "# InlineAsm End";
+ }
+ };
+
+ struct SPULinuxTargetAsmInfo : public SPUTargetAsmInfo<ELFTargetAsmInfo> {
+ explicit SPULinuxTargetAsmInfo(const SPUTargetMachine &TM);
+ virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
+ bool Global) const;
};
-
} // namespace llvm
-#endif
+#endif /* SPUTARGETASMINFO_H */
OpenPOWER on IntegriCloud