-
Notifications
You must be signed in to change notification settings - Fork 210
/
Copy pathaddress_references.h
83 lines (71 loc) · 2.89 KB
/
address_references.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
// Copyright 2011-2024 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef ADDRESS_REFERENCES_H_
#define ADDRESS_REFERENCES_H_
#include <algorithm>
#include <vector>
#include "third_party/zynamics/binexport/entry_point.h"
#include "third_party/zynamics/binexport/util/types.h"
#include "third_party/zynamics/binexport/virtual_memory.h"
enum AddressReferenceType {
TYPE_TRUE = 0,
TYPE_FALSE = 1,
TYPE_UNCONDITIONAL = 2,
TYPE_SWITCH = 3,
TYPE_CALL_DIRECT = 4,
TYPE_CALL_INDIRECT = 5,
// TYPE_CALL_INDIRECT_VIRTUAL = 6, // This is obsolete and unused.
TYPE_DATA = 7,
TYPE_DATA_STRING = 8,
TYPE_DATA_WIDE_STRING = 9,
// DATA_PARTIAL is intended to cover the cases typically found in Aarch64 and
// RISC-V where multiple instructions are used to create an address. In the
// case of Aarch64, ADRP followed later by ADD for example, and lui or auipc
// followed by addi, lw, or sw for RISC-V. The "base" instruction will have a
// partial reference type, and the actual data reference will be on the
// instruction where the final address is put together.
TYPE_DATA_PARTIAL = 10,
};
struct AddressReference {
AddressReference(Address source, std::pair<int, int> operand_expression,
Address target, AddressReferenceType kind,
int reference_size)
: source_(source),
target_(target),
source_operand_(operand_expression.first),
source_expression_(operand_expression.second),
size_(reference_size),
kind_(static_cast<uint8_t>(kind)) {}
AddressReference(Address source, std::pair<int, int> operand_expression,
Address target, AddressReferenceType kind)
: AddressReference(source, operand_expression, target, kind,
0 /* default size */) {}
inline bool IsCall() const {
return kind_ == TYPE_CALL_DIRECT || kind_ == TYPE_CALL_INDIRECT;
}
inline bool IsBranch() const {
return kind_ == TYPE_UNCONDITIONAL || kind_ == TYPE_TRUE ||
kind_ == TYPE_FALSE || kind_ == TYPE_SWITCH;
}
Address source_;
Address target_;
int source_operand_;
int source_expression_;
int size_;
uint8_t kind_;
};
using AddressReferences = std::vector<AddressReference>;
bool operator<(const AddressReference& one, const AddressReference& two);
bool operator==(const AddressReference& one, const AddressReference& two);
#endif // ADDRESS_REFERENCES_H_