Revert previous two patches while I try to find out how to make both
[oota-llvm.git] / lib / MC / MCStreamer.cpp
1 //===- lib/MC/MCStreamer.cpp - Streaming Machine Code Output --------------===//
2 //
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 #include "llvm/MC/MCStreamer.h"
12 #include "llvm/MC/MCExpr.h"
13 #include "llvm/MC/MCObjectWriter.h"
14 #include "llvm/Support/ErrorHandling.h"
15 #include "llvm/Support/raw_ostream.h"
16 #include "llvm/ADT/SmallString.h"
17 #include "llvm/ADT/Twine.h"
18 #include <cstdlib>
19 using namespace llvm;
20
21 MCStreamer::MCStreamer(MCContext &Ctx) : Context(Ctx), CurSection(0),
22                                          PrevSection(0) {
23 }
24
25 MCStreamer::~MCStreamer() {
26 }
27
28 raw_ostream &MCStreamer::GetCommentOS() {
29   // By default, discard comments.
30   return nulls();
31 }
32
33 void MCStreamer::EmitDwarfSetLineAddr(int64_t LineDelta,
34                                       const MCSymbol *Label, int PointerSize) {
35   // emit the sequence to set the address
36   EmitIntValue(dwarf::DW_LNS_extended_op, 1);
37   EmitULEB128IntValue(PointerSize + 1);
38   EmitIntValue(dwarf::DW_LNE_set_address, 1);
39   EmitSymbolValue(Label, PointerSize);
40
41   // emit the sequence for the LineDelta (from 1) and a zero address delta.
42   MCDwarfLineAddr::Emit(this, LineDelta, 0);
43 }
44
45 /// EmitIntValue - Special case of EmitValue that avoids the client having to
46 /// pass in a MCExpr for constant integers.
47 void MCStreamer::EmitIntValue(uint64_t Value, unsigned Size,
48                               unsigned AddrSpace) {
49   assert(Size <= 8);
50   char buf[8];
51   // FIXME: Endianness assumption.
52   for (unsigned i = 0; i != Size; ++i)
53     buf[i] = uint8_t(Value >> (i * 8));
54   EmitBytes(StringRef(buf, Size), AddrSpace);
55 }
56
57 /// EmitULEB128Value - Special case of EmitULEB128Value that avoids the
58 /// client having to pass in a MCExpr for constant integers.
59 void MCStreamer::EmitULEB128IntValue(uint64_t Value, unsigned AddrSpace) {
60   SmallString<32> Tmp;
61   raw_svector_ostream OSE(Tmp);
62   MCObjectWriter::EncodeULEB128(Value, OSE);
63   EmitBytes(OSE.str(), AddrSpace);
64 }
65
66 /// EmitSLEB128Value - Special case of EmitSLEB128Value that avoids the
67 /// client having to pass in a MCExpr for constant integers.
68 void MCStreamer::EmitSLEB128IntValue(int64_t Value, unsigned AddrSpace) {
69   SmallString<32> Tmp;
70   raw_svector_ostream OSE(Tmp);
71   MCObjectWriter::EncodeSLEB128(Value, OSE);
72   EmitBytes(OSE.str(), AddrSpace);
73 }
74
75 void MCStreamer::EmitSymbolValue(const MCSymbol *Sym, unsigned Size,
76                                  unsigned AddrSpace) {
77   EmitValue(MCSymbolRefExpr::Create(Sym, getContext()), Size, AddrSpace);
78 }
79
80 void MCStreamer::EmitGPRel32Value(const MCExpr *Value) {
81   report_fatal_error("unsupported directive in streamer");
82 }
83
84 /// EmitFill - Emit NumBytes bytes worth of the value specified by
85 /// FillValue.  This implements directives such as '.space'.
86 void MCStreamer::EmitFill(uint64_t NumBytes, uint8_t FillValue,
87                           unsigned AddrSpace) {
88   const MCExpr *E = MCConstantExpr::Create(FillValue, getContext());
89   for (uint64_t i = 0, e = NumBytes; i != e; ++i)
90     EmitValue(E, 1, AddrSpace);
91 }
92
93 bool MCStreamer::EmitDwarfFileDirective(unsigned FileNo,
94                                         StringRef Filename) {
95   return getContext().GetDwarfFile(Filename, FileNo) == 0;
96 }
97
98 void MCStreamer::EmitDwarfLocDirective(unsigned FileNo, unsigned Line,
99                                        unsigned Column, unsigned Flags,
100                                        unsigned Isa,
101                                        unsigned Discriminator) {
102   getContext().setCurrentDwarfLoc(FileNo, Line, Column, Flags, Isa,
103                                   Discriminator);
104 }
105
106 bool MCStreamer::EmitCFIStartProc() {
107   return false;
108 }
109
110 bool MCStreamer::EmitCFIEndProc() {
111   return false;
112 }
113
114 bool MCStreamer::EmitCFIDefCfaOffset(int64_t Offset) {
115   return false;
116 }
117
118 bool MCStreamer::EmitCFIDefCfaRegister(int64_t Register) {
119   return false;
120 }
121
122 bool MCStreamer::EmitCFIOffset(int64_t Register, int64_t Offset) {
123   return false;
124 }
125
126 bool MCStreamer::EmitCFIPersonality(const MCSymbol *Sym) {
127   return false;
128 }
129
130 bool MCStreamer::EmitCFILsda(const MCSymbol *Sym) {
131   return false;
132 }
133
134 /// EmitRawText - If this file is backed by an assembly streamer, this dumps
135 /// the specified string in the output .s file.  This capability is
136 /// indicated by the hasRawTextSupport() predicate.
137 void MCStreamer::EmitRawText(StringRef String) {
138   errs() << "EmitRawText called on an MCStreamer that doesn't support it, "
139   " something must not be fully mc'ized\n";
140   abort();
141 }
142
143 void MCStreamer::EmitRawText(const Twine &T) {
144   SmallString<128> Str;
145   T.toVector(Str);
146   EmitRawText(Str.str());
147 }