blob: 63338353a1f71c42f287814f0754866db11c47f0 [file] [log] [blame]
Daniel Dunbarba1da8a2009-06-23 23:39:15 +00001//===- lib/MC/MCContext.cpp - Machine Code Context ------------------------===//
Daniel Dunbarecc63f82009-06-23 22:01:43 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "llvm/MC/MCContext.h"
11
Daniel Dunbarecc63f82009-06-23 22:01:43 +000012#include "llvm/MC/MCSection.h"
13#include "llvm/MC/MCSymbol.h"
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000014#include "llvm/MC/MCValue.h"
Daniel Dunbarecc63f82009-06-23 22:01:43 +000015using namespace llvm;
16
Chris Lattnerfcdbf4e2009-07-31 16:43:49 +000017MCContext::MCContext() {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000018}
19
20MCContext::~MCContext() {
Chris Lattnerc9d31522009-08-13 00:21:53 +000021 // NOTE: The sections are all allocated out of a bump pointer allocator,
22 // we don't need to free them here.
Daniel Dunbarecc63f82009-06-23 22:01:43 +000023}
24
Chris Lattnerfcdbf4e2009-07-31 16:43:49 +000025MCSection *MCContext::GetSection(const StringRef &Name) const {
26 StringMap<MCSection*>::const_iterator I = Sections.find(Name);
27 return I != Sections.end() ? I->second : 0;
Daniel Dunbarecc63f82009-06-23 22:01:43 +000028}
Daniel Dunbarecc63f82009-06-23 22:01:43 +000029
Daniel Dunbarb5261eb2009-07-27 21:22:30 +000030MCSymbol *MCContext::CreateSymbol(const StringRef &Name) {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000031 assert(Name[0] != '\0' && "Normal symbols cannot be unnamed!");
32
33 // Create and bind the symbol, and ensure that names are unique.
34 MCSymbol *&Entry = Symbols[Name];
35 assert(!Entry && "Duplicate symbol definition!");
Daniel Dunbar71d259b2009-06-24 17:00:42 +000036 return Entry = new (*this) MCSymbol(Name, false);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000037}
38
Daniel Dunbarb5261eb2009-07-27 21:22:30 +000039MCSymbol *MCContext::GetOrCreateSymbol(const StringRef &Name) {
Chris Lattnerc69485e2009-06-24 04:31:49 +000040 MCSymbol *&Entry = Symbols[Name];
41 if (Entry) return Entry;
42
Daniel Dunbar71d259b2009-06-24 17:00:42 +000043 return Entry = new (*this) MCSymbol(Name, false);
Chris Lattnerc69485e2009-06-24 04:31:49 +000044}
45
46
Daniel Dunbarb5261eb2009-07-27 21:22:30 +000047MCSymbol *MCContext::CreateTemporarySymbol(const StringRef &Name) {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000048 // If unnamed, just create a symbol.
Daniel Dunbarb5261eb2009-07-27 21:22:30 +000049 if (Name.empty())
Daniel Dunbar71d259b2009-06-24 17:00:42 +000050 new (*this) MCSymbol("", true);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000051
52 // Otherwise create as usual.
53 MCSymbol *&Entry = Symbols[Name];
54 assert(!Entry && "Duplicate symbol definition!");
Daniel Dunbar71d259b2009-06-24 17:00:42 +000055 return Entry = new (*this) MCSymbol(Name, true);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000056}
57
Daniel Dunbarb5261eb2009-07-27 21:22:30 +000058MCSymbol *MCContext::LookupSymbol(const StringRef &Name) const {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000059 return Symbols.lookup(Name);
60}
61
62void MCContext::ClearSymbolValue(MCSymbol *Sym) {
63 SymbolValues.erase(Sym);
64}
65
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000066void MCContext::SetSymbolValue(MCSymbol *Sym, const MCValue &Value) {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000067 SymbolValues[Sym] = Value;
68}
69
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000070const MCValue *MCContext::GetSymbolValue(MCSymbol *Sym) const {
71 DenseMap<MCSymbol*, MCValue>::iterator it = SymbolValues.find(Sym);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000072
73 if (it == SymbolValues.end())
74 return 0;
75
76 return &it->second;
77}