diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-13 05:30:22 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-13 05:30:22 +0000 |
commit | b2d3169d96ee780e6b8f43230e36e41d97ed3140 (patch) | |
tree | 3d2eb4e18adac3e51f6d742691da1f4a7865d429 /lib/Target/PowerPC | |
parent | 7c4efa6808b737b2bfc7c79872b9c16f566a7d8a (diff) | |
download | llvm-b2d3169d96ee780e6b8f43230e36e41d97ed3140.tar.gz llvm-b2d3169d96ee780e6b8f43230e36e41d97ed3140.tar.bz2 llvm-b2d3169d96ee780e6b8f43230e36e41d97ed3140.tar.xz |
fix a minor fixme. When building with SL and later tools, the ".eh" symbols
don't need to be exported from the .o files.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78892 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/PowerPC')
-rw-r--r-- | lib/Target/PowerPC/PPCTargetAsmInfo.cpp | 14 | ||||
-rw-r--r-- | lib/Target/PowerPC/PPCTargetAsmInfo.h | 5 | ||||
-rw-r--r-- | lib/Target/PowerPC/PPCTargetMachine.cpp | 5 |
3 files changed, 13 insertions, 11 deletions
diff --git a/lib/Target/PowerPC/PPCTargetAsmInfo.cpp b/lib/Target/PowerPC/PPCTargetAsmInfo.cpp index 36cf2a5570..25920da0fe 100644 --- a/lib/Target/PowerPC/PPCTargetAsmInfo.cpp +++ b/lib/Target/PowerPC/PPCTargetAsmInfo.cpp @@ -12,19 +12,21 @@ //===----------------------------------------------------------------------===// #include "PPCTargetAsmInfo.h" +#include "llvm/ADT/Triple.h" using namespace llvm; -PPCDarwinTargetAsmInfo::PPCDarwinTargetAsmInfo(bool is64Bit) { +PPCDarwinTargetAsmInfo::PPCDarwinTargetAsmInfo(const Triple &TheTriple) + : DarwinTargetAsmInfo(TheTriple) { PCSymbol = "."; CommentString = ";"; ExceptionsType = ExceptionHandling::Dwarf; - if (!is64Bit) + if (TheTriple.getArch() != Triple::ppc64) Data64bitsDirective = 0; // We can't emit a 64-bit unit in PPC32 mode. AssemblerDialect = 1; // New-Style mnemonics. } -PPCLinuxTargetAsmInfo::PPCLinuxTargetAsmInfo(bool is64Bit) { +PPCLinuxTargetAsmInfo::PPCLinuxTargetAsmInfo(const Triple &TheTriple) { CommentString = "#"; GlobalPrefix = ""; PrivateGlobalPrefix = ".L"; @@ -41,13 +43,15 @@ PPCLinuxTargetAsmInfo::PPCLinuxTargetAsmInfo(bool is64Bit) { HasLEB128 = true; // Target asm supports leb128 directives (little-endian) // Exceptions handling - if (!is64Bit) + if (TheTriple.getArch() != Triple::ppc64) { ExceptionsType = ExceptionHandling::Dwarf; + Data64bitsDirective = 0; + } AbsoluteEHSectionOffsets = false; ZeroDirective = "\t.space\t"; SetDirective = "\t.set"; - Data64bitsDirective = is64Bit ? "\t.quad\t" : 0; + AlignmentIsInBytes = false; LCOMMDirective = "\t.lcomm\t"; AssemblerDialect = 0; // Old-Style mnemonics. diff --git a/lib/Target/PowerPC/PPCTargetAsmInfo.h b/lib/Target/PowerPC/PPCTargetAsmInfo.h index c7f8862e7f..1e7e3d3745 100644 --- a/lib/Target/PowerPC/PPCTargetAsmInfo.h +++ b/lib/Target/PowerPC/PPCTargetAsmInfo.h @@ -14,17 +14,16 @@ #ifndef PPCTARGETASMINFO_H #define PPCTARGETASMINFO_H -#include "llvm/Target/TargetAsmInfo.h" #include "llvm/Target/DarwinTargetAsmInfo.h" namespace llvm { struct PPCDarwinTargetAsmInfo : public DarwinTargetAsmInfo { - explicit PPCDarwinTargetAsmInfo(bool is64Bit); + explicit PPCDarwinTargetAsmInfo(const Triple &TheTriple); }; struct PPCLinuxTargetAsmInfo : public TargetAsmInfo { - explicit PPCLinuxTargetAsmInfo(bool is64Bit); + explicit PPCLinuxTargetAsmInfo(const Triple &TheTriple); }; } // namespace llvm diff --git a/lib/Target/PowerPC/PPCTargetMachine.cpp b/lib/Target/PowerPC/PPCTargetMachine.cpp index 41f4699fc0..a0d4fdb776 100644 --- a/lib/Target/PowerPC/PPCTargetMachine.cpp +++ b/lib/Target/PowerPC/PPCTargetMachine.cpp @@ -23,10 +23,9 @@ using namespace llvm; static const TargetAsmInfo *createTargetAsmInfo(const Target &T, const StringRef &TT) { Triple TheTriple(TT); - bool isPPC64 = TheTriple.getArch() == Triple::ppc64; if (TheTriple.getOS() == Triple::Darwin) - return new PPCDarwinTargetAsmInfo(isPPC64); - return new PPCLinuxTargetAsmInfo(isPPC64); + return new PPCDarwinTargetAsmInfo(TheTriple); + return new PPCLinuxTargetAsmInfo(TheTriple); } |