diff options
author | Chris Lattner <sabre@nondot.org> | 2010-05-07 17:17:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-05-07 17:17:41 +0000 |
commit | 87cffa9498f5dec19b04a3903c27466b308b1943 (patch) | |
tree | db56faa4a1b08e25d604367fcb0c82861cec9490 /llvm/lib/MC/MCContext.cpp | |
parent | d90773ebe05e8504082b59c15ffa894b4d849b98 (diff) | |
download | bcm5719-llvm-87cffa9498f5dec19b04a3903c27466b308b1943.tar.gz bcm5719-llvm-87cffa9498f5dec19b04a3903c27466b308b1943.zip |
switch MCSectionCOFF from a syntactic to semantic representation,
patch by Peter Housel!
llvm-svn: 103267
Diffstat (limited to 'llvm/lib/MC/MCContext.cpp')
-rw-r--r-- | llvm/lib/MC/MCContext.cpp | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/llvm/lib/MC/MCContext.cpp b/llvm/lib/MC/MCContext.cpp index dc757bb0bff..93388c00f87 100644 --- a/llvm/lib/MC/MCContext.cpp +++ b/llvm/lib/MC/MCContext.cpp @@ -11,6 +11,7 @@ #include "llvm/MC/MCAsmInfo.h" #include "llvm/MC/MCSectionMachO.h" #include "llvm/MC/MCSectionELF.h" +#include "llvm/MC/MCSectionCOFF.h" #include "llvm/MC/MCSymbol.h" #include "llvm/ADT/SmallString.h" #include "llvm/ADT/Twine.h" @@ -18,11 +19,13 @@ using namespace llvm; typedef StringMap<const MCSectionMachO*> MachOUniqueMapTy; typedef StringMap<const MCSectionELF*> ELFUniqueMapTy; +typedef StringMap<const MCSectionCOFF*> COFFUniqueMapTy; MCContext::MCContext(const MCAsmInfo &mai) : MAI(mai), NextUniqueID(0) { MachOUniquingMap = 0; ELFUniquingMap = 0; + COFFUniquingMap = 0; } MCContext::~MCContext() { @@ -32,6 +35,7 @@ MCContext::~MCContext() { // If we have the MachO uniquing map, free it. delete (MachOUniqueMapTy*)MachOUniquingMap; delete (ELFUniqueMapTy*)ELFUniquingMap; + delete (COFFUniqueMapTy*)COFFUniquingMap; } //===----------------------------------------------------------------------===// @@ -122,4 +126,19 @@ getELFSection(StringRef Section, unsigned Type, unsigned Flags, return Result; } - +const MCSection *MCContext:: +getCOFFSection(StringRef Section, unsigned Flags, SectionKind Kind) { + if (COFFUniquingMap == 0) + COFFUniquingMap = new COFFUniqueMapTy(); + COFFUniqueMapTy &Map = *(COFFUniqueMapTy*)COFFUniquingMap; + + // Do the lookup, if we have a hit, return it. + StringMapEntry<const MCSectionCOFF*> &Entry = Map.GetOrCreateValue(Section); + if (Entry.getValue()) return Entry.getValue(); + + MCSectionCOFF *Result = new (*this) MCSectionCOFF(Entry.getKey(), Flags, + Kind); + + Entry.setValue(Result); + return Result; +} |