forked from google/autofdo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
profile_update.cc
80 lines (68 loc) · 2.77 KB
/
profile_update.cc
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
// Copyright 2014 Google Inc. All rights reserved.
//
// 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
//
// http://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.
// Updates the AutoFDO profile using the module info and debug info stored
// in the new binary.
#include <map>
#include <set>
#include <string>
#include <utility>
#include <vector>
#include <memory>
#include "base/common.h"
#include "base/logging.h"
#include "addr2line.h"
#include "gcov.h"
#include "profile_reader.h"
#include "profile_writer.h"
#include "symbol_map.h"
#include "module_grouper.h"
DEFINE_string(input, "fbdata.afdo",
"Input file name of the old profile.");
DEFINE_string(output, "fbdata.afdo",
"Output file name of the new profile.");
DEFINE_string(binary, "",
"New binary that has updated module and debug info (built with "
"-gmlt and -frecord-compilation-info-in-elf).");
using autofdo::SymbolMap;
using autofdo::ModuleGrouper;
using autofdo::Addr2line;
using autofdo::AutoFDOProfileReader;
using autofdo::AutoFDOProfileWriter;
int main(int argc, char **argv) {
google::ParseCommandLineFlags(&argc, &argv, true);
google::InitGoogleLogging(argv[0]);
// Step 1. Read the binary to build top-level symbol map to include symbol's
// start address and size.
SymbolMap symbol_map(FLAGS_binary);
// Step 2. Read in profile to annotate on symbol map and add inlined symbols
AutoFDOProfileReader reader(&symbol_map, NULL, false);
reader.ReadFromFile(FLAGS_input);
// Step 3. Traverse the symbol map to get sampled symbols
std::map<uint64, uint64> sampled_functions =
symbol_map.GetLegacySymbolStartAddressSizeMap();
// Step 4. Read debug info in binary for the sampled symbols
std::unique_ptr<Addr2line> addr2line(Addr2line::CreateWithSampledFunctions(
FLAGS_binary, &sampled_functions));
// Step 5. Use the debug info to update the symbol map (add module info)
symbol_map.UpdateSymbolMap(addr2line.get(), sampled_functions);
symbol_map.CalculateThreshold();
auto grouper = ModuleGrouper::GroupModule(
FLAGS_binary, GCOV_ELF_SECTION_NAME, &symbol_map);
AutoFDOProfileWriter writer(&symbol_map, &grouper->module_map(),
FLAGS_gcov_version);
if (!writer.WriteToFile(FLAGS_output)) {
LOG(FATAL) << "Error writing to " << FLAGS_output;
}
return 0;
}