forked from google/autofdo
-
Notifications
You must be signed in to change notification settings - Fork 1
/
branch_frequencies.h
34 lines (30 loc) · 1.15 KB
/
branch_frequencies.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
#ifndef AUTOFDO_BRANCH_FREQUENCIES_H_
#define AUTOFDO_BRANCH_FREQUENCIES_H_
#include <cstdint>
#include "binary_address_branch.h"
#include "third_party/abseil/absl/algorithm/container.h"
#include "third_party/abseil/absl/container/flat_hash_map.h"
namespace devtools_crosstool_autofdo
{
// `BranchFrequencies` represents the taken/not-taken frequencies for
// the branches in a binary.
struct BranchFrequencies
{
// Computes the sum of all taken branch counters.
int64_t GetNumberOfTakenBranchCounters() const
{
return absl::c_accumulate(
taken_branch_counters, 0,
[](int64_t cnt, const auto &v)
{ return cnt + v.second; });
}
// The number of times each branch was taken, keyed by the binary address of
// its source and destination.
absl::flat_hash_map<BinaryAddressBranch, int64_t> taken_branch_counters;
// The number of times each branch was not taken, keyed by the binary address
// of the instruction.
absl::flat_hash_map<BinaryAddressNotTakenBranch, int64_t>
not_taken_branch_counters;
};
} // namespace devtools_crosstool_autofdo
#endif // AUTOFDO_BRANCH_FREQUENCIES_H_