forked from microsoft/llvm-mctoll
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathModuleRaiser.h
162 lines (135 loc) · 5.97 KB
/
ModuleRaiser.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
//===-- ModuleRaiser.h ------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_TOOLS_LLVM_MCTOLL_MODULERAISER_H
#define LLVM_TOOLS_LLVM_MCTOLL_MODULERAISER_H
#include "FunctionFilter.h"
#include "llvm/CodeGen/MachineBasicBlock.h"
#include "llvm/CodeGen/MachineModuleInfo.h"
#include "llvm/MC/MCDisassembler/MCDisassembler.h"
#include "llvm/MC/MCInstrAnalysis.h"
#include "llvm/Object/ObjectFile.h"
#include "llvm/Target/TargetMachine.h"
#include <vector>
using namespace llvm;
using namespace std;
class MachineFunctionRaiser;
using namespace object;
// The ModuleRaiser class encapsulates information needed to raise a given
// module.
class ModuleRaiser {
public:
ModuleRaiser()
: M(nullptr), TM(nullptr), MMI(nullptr), MIA(nullptr), MII(nullptr),
Obj(nullptr), DisAsm(nullptr), TextSectionIndex(-1),
Arch(Triple::ArchType::UnknownArch), FFT(nullptr), InfoSet(false) {}
static void InitializeAllModuleRaisers();
void setModuleRaiserInfo(Module *M, const TargetMachine *TM,
MachineModuleInfo *MMI, const MCInstrAnalysis *MIA,
const MCInstrInfo *MII, const ObjectFile *Obj,
MCDisassembler *DisAsm) {
assert((InfoSet == false) &&
"Module Raiser information can be set only once");
this->M = M;
this->TM = TM;
this->MMI = MMI;
this->MIA = MIA;
this->MII = MII;
this->Obj = Obj;
this->DisAsm = DisAsm;
this->FFT = new FunctionFilter(*M);
InfoSet = true;
}
// Function to create a MachineFunctionRaiser corresponding to Function f.
// As noted elsewhere (llvm-mctoll.cpp), f is a place holder to allow for
// creation of MachineFunction. The Function object representing raising
// of MachineFunction is accessible by calling getRaisedFunction()
// on the MachineFunctionRaiser object.
virtual MachineFunctionRaiser *
CreateAndAddMachineFunctionRaiser(Function *F, const ModuleRaiser *,
uint64_t Start, uint64_t End) = 0;
MachineFunctionRaiser *getCurrentMachineFunctionRaiser() {
if (mfRaiserVector.size() > 0)
return mfRaiserVector.back();
return nullptr;
}
// Insert the map of raised function R to place-holder function PH pointer
// that inturn has the to corresponding MachineFunction.
bool insertPlaceholderRaisedFunctionMap(Function *R, Function *PH) {
auto V = PlaceholderRaisedFunctionMap.insert(std::make_pair(R, PH));
return V.second;
}
bool collectTextSectionRelocs(const SectionRef &);
virtual bool collectDynamicRelocations() = 0;
MachineFunction *getMachineFunction(Function *);
// Member getters
Module *getModule() const { return M; }
const TargetMachine *getTargetMachine() const { return TM; }
MachineModuleInfo *getMachineModuleInfo() const { return MMI; }
const MCInstrAnalysis *getMCInstrAnalysis() const { return MIA; }
const MCInstrInfo *getMCInstrInfo() const { return MII; }
const ObjectFile *getObjectFile() const { return Obj; }
const MCDisassembler *getMCDisassembler() const { return DisAsm; }
Triple::ArchType getArchType() { return Arch; }
bool runMachineFunctionPasses();
// Return the Function * corresponding to input binary function with
// start offset equal to that specified as argument.
Function *getFunctionAt(uint64_t) const;
// Return the Function * corresponding to input binary function from
// text relocation record with off set in the range [Loc, Loc+Size].
Function *getCalledFunctionUsingTextReloc(uint64_t Loc, uint64_t Size) const;
// Get dynamic relocation with offset 'O'
const RelocationRef *getDynRelocAtOffset(uint64_t O) const;
// Return text relocation of instruction at index 'I'. 'S' is the size of the
// instruction at index 'I'.
const RelocationRef *getTextRelocAtOffset(uint64_t I, uint64_t S) const;
int64_t getTextSectionAddress() const;
const Value *getRODataValueAt(uint64_t Offset) const;
void addRODataValueAt(Value *V, uint64_t Offset) const;
virtual ~ModuleRaiser() {
if (FFT != nullptr)
delete FFT;
}
// Get the function filter for current Module.
FunctionFilter *getFunctionFilter() const { return FFT; }
protected:
// A sequential list of MachineFunctionRaiser objects created
// as the instructions of the input binary are parsed. Each of
// these correspond to a "machine function". A machine function
// corresponds to a sequence of instructions (possibly interspersed
// by data bytes) whose start is denoted by a function symbol in
// the binary.
std::vector<MachineFunctionRaiser *> mfRaiserVector;
// A map of raised function pointer to place-holder function pointer
// that links to the MachineFunction.
DenseMap<Function *, Function *> PlaceholderRaisedFunctionMap;
// Sorted vector of text relocations
std::vector<RelocationRef> TextRelocs;
// Vector of dynamic relocation records
std::vector<RelocationRef> DynRelocs;
// Map of read-only data (i.e., from .rodata) to its corresponding global
// value.
// NOTE: A const version of ModuleRaiser object is constructed during the
// raising process. Making this map mutable since this map is expected to be
// updated throughout the raising process.
mutable std::map<uint64_t, Value *> GlobalRODataValues;
// Commonly used data structures
Module *M;
const TargetMachine *TM;
MachineModuleInfo *MMI;
const MCInstrAnalysis *MIA;
const MCInstrInfo *MII;
const ObjectFile *Obj;
MCDisassembler *DisAsm;
// Index of text section whose instructions are raised
int64_t TextSectionIndex;
Triple::ArchType Arch;
FunctionFilter *FFT;
// Flag to indicate that fields are set. Resetting is not allowed/expected.
bool InfoSet;
};
#endif // LLVM_TOOLS_LLVM_MCTOLL_MODULERAISER_H