blob: cc1e8a9657c2c7a2a1edd8179365e4c7fc5a69b8 [file] [log] [blame]
Teresa Johnson26ab5772016-03-15 00:04:37 +00001//===-- ModuleSummaryIndex.cpp - Module Summary Index ---------------------===//
Teresa Johnsoncec0cae2016-03-14 21:18:10 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file implements the module index and summary classes for the
11// IR library.
12//
13//===----------------------------------------------------------------------===//
14
Teresa Johnson26ab5772016-03-15 00:04:37 +000015#include "llvm/IR/ModuleSummaryIndex.h"
Teresa Johnsoncec0cae2016-03-14 21:18:10 +000016#include "llvm/ADT/StringMap.h"
17using namespace llvm;
18
19// Create the combined module index/summary from multiple
20// per-module instances.
Teresa Johnson26ab5772016-03-15 00:04:37 +000021void ModuleSummaryIndex::mergeFrom(std::unique_ptr<ModuleSummaryIndex> Other,
22 uint64_t NextModuleId) {
Teresa Johnsoncec0cae2016-03-14 21:18:10 +000023
24 StringRef ModPath;
25 for (auto &OtherGlobalValInfoLists : *Other) {
Mehdi Aminiad5741b2016-04-02 05:07:53 +000026 GlobalValue::GUID ValueGUID = OtherGlobalValInfoLists.first;
Teresa Johnsoncec0cae2016-03-14 21:18:10 +000027 GlobalValueInfoList &List = OtherGlobalValInfoLists.second;
28
29 // Assert that the value info list only has one entry, since we shouldn't
30 // have duplicate names within a single per-module index.
31 assert(List.size() == 1);
32 std::unique_ptr<GlobalValueInfo> Info = std::move(List.front());
33
34 // Skip if there was no summary section.
35 if (!Info->summary())
36 continue;
37
38 // Add the module path string ref for this module if we haven't already
39 // saved a reference to it.
Mehdi Aminid7ad2212016-04-01 05:33:11 +000040 if (ModPath.empty()) {
41 auto Path = Info->summary()->modulePath();
42 ModPath = addModulePath(Path, NextModuleId, Other->getModuleHash(Path))
43 ->first();
44 } else
Teresa Johnsoncec0cae2016-03-14 21:18:10 +000045 assert(ModPath == Info->summary()->modulePath() &&
46 "Each module in the combined map should have a unique ID");
47
48 // Note the module path string ref was copied above and is still owned by
49 // the original per-module index. Reset it to the new module path
50 // string reference owned by the combined index.
51 Info->summary()->setModulePath(ModPath);
52
53 // Add new value info to existing list. There may be duplicates when
54 // combining GlobalValueMap entries, due to COMDAT values. Any local
55 // values were given unique global IDs.
56 addGlobalValueInfo(ValueGUID, std::move(Info));
57 }
58}
59
Teresa Johnson26ab5772016-03-15 00:04:37 +000060void ModuleSummaryIndex::removeEmptySummaryEntries() {
Teresa Johnsoncec0cae2016-03-14 21:18:10 +000061 for (auto MI = begin(), MIE = end(); MI != MIE;) {
62 // Only expect this to be called on a per-module index, which has a single
63 // entry per value entry list.
64 assert(MI->second.size() == 1);
65 if (!MI->second[0]->summary())
66 MI = GlobalValueMap.erase(MI);
67 else
68 ++MI;
69 }
70}
Teresa Johnsonfb7c7642016-04-05 00:40:16 +000071
Teresa Johnsonc86af332016-04-12 21:13:11 +000072// Collect for the given module the list of function it defines
73// (GUID -> Summary).
74void ModuleSummaryIndex::collectDefinedFunctionsForModule(
75 StringRef ModulePath,
Mehdi Amini2d28f7a2016-04-16 06:56:44 +000076 std::map<GlobalValue::GUID, GlobalValueSummary *> &FunctionInfoMap) const {
Teresa Johnsonc86af332016-04-12 21:13:11 +000077 for (auto &GlobalList : *this) {
78 auto GUID = GlobalList.first;
79 for (auto &GlobInfo : GlobalList.second) {
80 auto *Summary = dyn_cast_or_null<FunctionSummary>(GlobInfo->summary());
81 if (!Summary)
82 // Ignore global variable, focus on functions
83 continue;
84 // Ignore summaries from other modules.
85 if (Summary->modulePath() != ModulePath)
86 continue;
87 FunctionInfoMap[GUID] = Summary;
88 }
89 }
90}
91
Teresa Johnsonfb7c7642016-04-05 00:40:16 +000092GlobalValueInfo *
93ModuleSummaryIndex::getGlobalValueInfo(uint64_t ValueGUID,
94 bool PerModuleIndex) const {
95 auto InfoList = findGlobalValueInfoList(ValueGUID);
96 assert(InfoList != end() && "GlobalValue not found in index");
Haojian Wu591ae462016-04-05 09:07:47 +000097 assert((!PerModuleIndex || InfoList->second.size() == 1) &&
98 "Expected a single entry per global value in per-module index");
Teresa Johnsonfb7c7642016-04-05 00:40:16 +000099 auto &Info = InfoList->second[0];
100 return Info.get();
101}