blob: f7793b918ca520c5fb920228c9a61faca3b01f92 [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
12#include "llvm/MC/MCAtom.h"
Daniel Dunbarecc63f82009-06-23 22:01:43 +000013#include "llvm/MC/MCSection.h"
14#include "llvm/MC/MCSymbol.h"
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000015#include "llvm/MC/MCValue.h"
Daniel Dunbarecc63f82009-06-23 22:01:43 +000016using namespace llvm;
17
18MCContext::MCContext()
19{
20}
21
22MCContext::~MCContext() {
23}
24
25MCSection *MCContext::GetSection(const char *Name) {
26 MCSection *&Entry = Sections[Name];
27
28 if (!Entry)
Daniel Dunbara11af532009-06-24 01:03:06 +000029 Entry = new (*this) MCSection(Name);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000030
31 return Entry;
32}
33
34MCAtom *MCContext::CreateAtom(MCSection *Section) {
Daniel Dunbara11af532009-06-24 01:03:06 +000035 return new (*this) MCAtom(Section);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000036}
37
38MCSymbol *MCContext::CreateSymbol(MCAtom *Atom, const char *Name) {
39 assert(Name[0] != '\0' && "Normal symbols cannot be unnamed!");
40
41 // Create and bind the symbol, and ensure that names are unique.
42 MCSymbol *&Entry = Symbols[Name];
43 assert(!Entry && "Duplicate symbol definition!");
Daniel Dunbara11af532009-06-24 01:03:06 +000044 return Entry = new (*this) MCSymbol(Atom, Name, false);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000045}
46
Chris Lattnerc69485e2009-06-24 04:31:49 +000047/// GetOrCreateSymbol - Lookup the symbol inside with the specified
48/// @param Name. If it exists, return it. If not, create a forward
49/// reference and return it.
50///
51/// @param Name - The symbol name, which must be unique across all symbols.
52MCSymbol *MCContext::GetOrCreateSymbol(const char *Name) {
53 MCSymbol *&Entry = Symbols[Name];
54 if (Entry) return Entry;
55
56 // FIXME: is a null atom the right way to make a forward ref?
57 return Entry = new (*this) MCSymbol(0, Name, false);
58}
59
60
Daniel Dunbarecc63f82009-06-23 22:01:43 +000061MCSymbol *MCContext::CreateTemporarySymbol(MCAtom *Atom, const char *Name) {
62 // If unnamed, just create a symbol.
63 if (Name[0] == '\0')
Daniel Dunbara11af532009-06-24 01:03:06 +000064 new (*this) MCSymbol(Atom, "", true);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000065
66 // Otherwise create as usual.
67 MCSymbol *&Entry = Symbols[Name];
68 assert(!Entry && "Duplicate symbol definition!");
Daniel Dunbara11af532009-06-24 01:03:06 +000069 return Entry = new (*this) MCSymbol(Atom, Name, true);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000070}
71
72MCSymbol *MCContext::LookupSymbol(const char *Name) const {
73 return Symbols.lookup(Name);
74}
75
76void MCContext::ClearSymbolValue(MCSymbol *Sym) {
77 SymbolValues.erase(Sym);
78}
79
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000080void MCContext::SetSymbolValue(MCSymbol *Sym, const MCValue &Value) {
Daniel Dunbarecc63f82009-06-23 22:01:43 +000081 SymbolValues[Sym] = Value;
82}
83
Daniel Dunbarba1da8a2009-06-23 23:39:15 +000084const MCValue *MCContext::GetSymbolValue(MCSymbol *Sym) const {
85 DenseMap<MCSymbol*, MCValue>::iterator it = SymbolValues.find(Sym);
Daniel Dunbarecc63f82009-06-23 22:01:43 +000086
87 if (it == SymbolValues.end())
88 return 0;
89
90 return &it->second;
91}