-
Notifications
You must be signed in to change notification settings - Fork 145
/
reader.h
100 lines (83 loc) · 3.26 KB
/
reader.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
// 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 READER_H_
#define READER_H_
#include "third_party/absl/container/btree_map.h"
#include "third_party/absl/container/btree_set.h"
#include "third_party/absl/status/status.h"
#include "third_party/zynamics/bindiff/fixed_points.h"
#include "third_party/zynamics/bindiff/graph_util.h"
#include "third_party/zynamics/binexport/util/types.h"
namespace security::bindiff {
struct FlowGraphInfo {
Address address = 0;
const std::string* name = nullptr;
const std::string* demangled_name = nullptr;
int basic_block_count = 0;
int edge_count = 0;
int instruction_count = 0;
};
using FlowGraphInfos = absl::btree_map<Address, FlowGraphInfo>;
struct FixedPointInfo {
friend bool operator==(const FixedPointInfo& lhs, const FixedPointInfo& rhs) {
// TODO(cblichmann): Use defaulted operator==() once we're on C++20.
return lhs.primary == rhs.primary && lhs.secondary == rhs.secondary &&
lhs.basic_block_count == rhs.basic_block_count &&
lhs.edge_count == rhs.edge_count &&
lhs.instruction_count == rhs.instruction_count &&
lhs.similarity == rhs.similarity &&
lhs.confidence == rhs.confidence && lhs.flags == rhs.flags &&
lhs.algorithm == rhs.algorithm && lhs.evaluate == rhs.evaluate &&
lhs.comments_ported == rhs.comments_ported;
}
template <typename H>
friend H AbslHashValue(H h, const FixedPointInfo& info) {
return H::combine(std::move(h), info.primary, info.secondary,
info.basic_block_count, info.edge_count,
info.instruction_count, info.confidence, info.flags,
info.algorithm, info.evaluate, info.comments_ported);
}
bool IsManual() const;
Address primary;
Address secondary;
int basic_block_count;
int edge_count;
int instruction_count;
double similarity;
double confidence;
int flags;
const std::string* algorithm;
bool evaluate;
bool comments_ported;
};
using FixedPointInfos = absl::btree_set<FixedPointInfo>;
bool operator<(const FixedPointInfo& one, const FixedPointInfo& two);
class Reader {
public:
Reader() = default;
Reader(const Reader&) = delete;
Reader& operator=(const Reader&) = delete;
virtual ~Reader() = default;
virtual absl::Status Read(CallGraph& call_graph1, CallGraph& call_graph2,
FlowGraphInfos& flow_graphs1,
FlowGraphInfos& flow_graphs2,
FixedPointInfos& fixed_points) = 0;
double similarity() const { return similarity_; }
double confidence() const { return confidence_; }
protected:
double similarity_ = 0.0;
double confidence_ = 0.0;
};
} // namespace security::bindiff
#endif // READER_H_