summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin Enderby <enderby@apple.com>2010-09-30 16:38:07 +0000
committerKevin Enderby <enderby@apple.com>2010-09-30 16:38:07 +0000
commitbad267fa05854d89e1e7b86e9333b6ee17b11266 (patch)
treee6ae4a25c1304617b797568d4444233fddf98b57
parentf25bc19e171fb501ac9a11cf99527e0e3f6a43b7 (diff)
downloadbcm5719-llvm-bad267fa05854d89e1e7b86e9333b6ee17b11266.tar.gz
bcm5719-llvm-bad267fa05854d89e1e7b86e9333b6ee17b11266.zip
Adds getPointerSize() to the AsmBackend which will be needed by the final patch
for the dwarf .loc support to emit dwarf line number tables. llvm-svn: 115153
-rw-r--r--llvm/include/llvm/Target/TargetAsmBackend.h3
-rw-r--r--llvm/lib/Target/ARM/ARMAsmBackend.cpp8
-rw-r--r--llvm/lib/Target/X86/X86AsmBackend.cpp23
3 files changed, 34 insertions, 0 deletions
diff --git a/llvm/include/llvm/Target/TargetAsmBackend.h b/llvm/include/llvm/Target/TargetAsmBackend.h
index 979595ad4f4..b0a7af6371e 100644
--- a/llvm/include/llvm/Target/TargetAsmBackend.h
+++ b/llvm/include/llvm/Target/TargetAsmBackend.h
@@ -101,6 +101,9 @@ public:
/// has no actual object file contents.
virtual bool isVirtualSection(const MCSection &Section) const = 0;
+ /// getPointerSize - Get the pointer size in bytes.
+ virtual unsigned getPointerSize() const = 0;
+
/// ApplyFixup - Apply the \arg Value for given \arg Fixup into the provided
/// data fragment, at the offset specified by the fixup and following the
/// fixup kind as appropriate.
diff --git a/llvm/lib/Target/ARM/ARMAsmBackend.cpp b/llvm/lib/Target/ARM/ARMAsmBackend.cpp
index f13c2bbf482..9de6eba09fa 100644
--- a/llvm/lib/Target/ARM/ARMAsmBackend.cpp
+++ b/llvm/lib/Target/ARM/ARMAsmBackend.cpp
@@ -84,6 +84,10 @@ public:
/*IsLittleEndian=*/true,
/*HasRelocationAddend=*/false);
}
+
+ unsigned getPointerSize() const {
+ return 4;
+ };
};
// Fixme: can we raise this to share code between Darwin and ELF?
@@ -116,6 +120,10 @@ public:
return new MachObjectWriter(OS, /*Is64Bit=*/false);
}
+ unsigned getPointerSize() const {
+ return 4;
+ };
+
virtual bool doesSectionRequireSymbols(const MCSection &Section) const {
return false;
}
diff --git a/llvm/lib/Target/X86/X86AsmBackend.cpp b/llvm/lib/Target/X86/X86AsmBackend.cpp
index d9c6daa2cc2..cabc6015aa6 100644
--- a/llvm/lib/Target/X86/X86AsmBackend.cpp
+++ b/llvm/lib/Target/X86/X86AsmBackend.cpp
@@ -211,6 +211,10 @@ public:
ELFX86_32AsmBackend(const Target &T, Triple::OSType OSType)
: ELFX86AsmBackend(T, OSType) {}
+ unsigned getPointerSize() const {
+ return 4;
+ }
+
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
return new ELFObjectWriter(OS, /*Is64Bit=*/false,
OSType,
@@ -224,6 +228,10 @@ public:
ELFX86_64AsmBackend(const Target &T, Triple::OSType OSType)
: ELFX86AsmBackend(T, OSType) {}
+ unsigned getPointerSize() const {
+ return 8;
+ }
+
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
return new ELFObjectWriter(OS, /*Is64Bit=*/true,
OSType,
@@ -241,6 +249,13 @@ public:
HasScatteredSymbols = true;
}
+ unsigned getPointerSize() const {
+ if (Is64Bit)
+ return 8;
+ else
+ return 4;
+ }
+
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
return createWinCOFFObjectWriter(OS, Is64Bit);
}
@@ -272,6 +287,10 @@ public:
DarwinX86_32AsmBackend(const Target &T)
: DarwinX86AsmBackend(T) {}
+ unsigned getPointerSize() const {
+ return 4;
+ }
+
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
return new MachObjectWriter(OS, /*Is64Bit=*/false);
}
@@ -284,6 +303,10 @@ public:
HasReliableSymbolDifference = true;
}
+ unsigned getPointerSize() const {
+ return 8;
+ }
+
MCObjectWriter *createObjectWriter(raw_ostream &OS) const {
return new MachObjectWriter(OS, /*Is64Bit=*/true);
}
OpenPOWER on IntegriCloud