1 | //===-- Instrumentation.cpp - TransformUtils Infrastructure ---------------===// |
2 | // |
3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
4 | // See https://llvm.org/LICENSE.txt for license information. |
5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
6 | // |
7 | //===----------------------------------------------------------------------===// |
8 | // |
9 | // This file defines the common initialization infrastructure for the |
10 | // Instrumentation library. |
11 | // |
12 | //===----------------------------------------------------------------------===// |
13 | |
14 | #include "llvm/Transforms/Utils/Instrumentation.h" |
15 | #include "llvm/IR/DiagnosticInfo.h" |
16 | #include "llvm/IR/DiagnosticPrinter.h" |
17 | #include "llvm/IR/IntrinsicInst.h" |
18 | #include "llvm/IR/Module.h" |
19 | #include "llvm/TargetParser/Triple.h" |
20 | |
21 | using namespace llvm; |
22 | |
23 | static cl::opt<bool> ClIgnoreRedundantInstrumentation( |
24 | "ignore-redundant-instrumentation" , |
25 | cl::desc("Ignore redundant instrumentation" ), cl::Hidden, cl::init(Val: false)); |
26 | |
27 | /// Check if module has flag attached, if not add the flag. |
28 | bool llvm::checkIfAlreadyInstrumented(Module &M, StringRef Flag) { |
29 | if (!M.getModuleFlag(Key: Flag)) { |
30 | M.addModuleFlag(Behavior: Module::ModFlagBehavior::Override, Key: Flag, Val: 1); |
31 | return false; |
32 | } |
33 | if (ClIgnoreRedundantInstrumentation) |
34 | return true; |
35 | std::string diagInfo = |
36 | "Redundant instrumentation detected, with module flag: " + |
37 | std::string(Flag); |
38 | M.getContext().diagnose( |
39 | DI: DiagnosticInfoInstrumentation(diagInfo, DiagnosticSeverity::DS_Warning)); |
40 | return true; |
41 | } |
42 | |
43 | /// Moves I before IP. Returns new insert point. |
44 | static BasicBlock::iterator moveBeforeInsertPoint(BasicBlock::iterator I, |
45 | BasicBlock::iterator IP) { |
46 | // If I is IP, move the insert point down. |
47 | if (I == IP) { |
48 | ++IP; |
49 | } else { |
50 | // Otherwise, move I before IP and return IP. |
51 | I->moveBefore(InsertPos: IP); |
52 | } |
53 | return IP; |
54 | } |
55 | |
56 | /// Instrumentation passes often insert conditional checks into entry blocks. |
57 | /// Call this function before splitting the entry block to move instructions |
58 | /// that must remain in the entry block up before the split point. Static |
59 | /// allocas and llvm.localescape calls, for example, must remain in the entry |
60 | /// block. |
61 | BasicBlock::iterator llvm::PrepareToSplitEntryBlock(BasicBlock &BB, |
62 | BasicBlock::iterator IP) { |
63 | assert(&BB.getParent()->getEntryBlock() == &BB); |
64 | for (auto I = IP, E = BB.end(); I != E; ++I) { |
65 | bool KeepInEntry = false; |
66 | if (auto *AI = dyn_cast<AllocaInst>(Val&: I)) { |
67 | if (AI->isStaticAlloca()) |
68 | KeepInEntry = true; |
69 | } else if (auto *II = dyn_cast<IntrinsicInst>(Val&: I)) { |
70 | if (II->getIntrinsicID() == llvm::Intrinsic::localescape) |
71 | KeepInEntry = true; |
72 | } |
73 | if (KeepInEntry) |
74 | IP = moveBeforeInsertPoint(I, IP); |
75 | } |
76 | return IP; |
77 | } |
78 | |
79 | // Create a constant for Str so that we can pass it to the run-time lib. |
80 | GlobalVariable *llvm::createPrivateGlobalForString(Module &M, StringRef Str, |
81 | bool AllowMerging, |
82 | Twine NamePrefix) { |
83 | Constant *StrConst = ConstantDataArray::getString(Context&: M.getContext(), Initializer: Str); |
84 | // We use private linkage for module-local strings. If they can be merged |
85 | // with another one, we set the unnamed_addr attribute. |
86 | GlobalVariable *GV = |
87 | new GlobalVariable(M, StrConst->getType(), true, |
88 | GlobalValue::PrivateLinkage, StrConst, NamePrefix); |
89 | if (AllowMerging) |
90 | GV->setUnnamedAddr(GlobalValue::UnnamedAddr::Global); |
91 | GV->setAlignment(Align(1)); // Strings may not be merged w/o setting |
92 | // alignment explicitly. |
93 | return GV; |
94 | } |
95 | |
96 | Comdat *llvm::getOrCreateFunctionComdat(Function &F, Triple &T) { |
97 | if (auto Comdat = F.getComdat()) |
98 | return Comdat; |
99 | assert(F.hasName()); |
100 | Module *M = F.getParent(); |
101 | |
102 | // Make a new comdat for the function. Use the "no duplicates" selection kind |
103 | // if the object file format supports it. For COFF we restrict it to non-weak |
104 | // symbols. |
105 | Comdat *C = M->getOrInsertComdat(Name: F.getName()); |
106 | if (T.isOSBinFormatELF() || (T.isOSBinFormatCOFF() && !F.isWeakForLinker())) |
107 | C->setSelectionKind(Comdat::NoDeduplicate); |
108 | F.setComdat(C); |
109 | return C; |
110 | } |
111 | |
112 | void llvm::setGlobalVariableLargeSection(const Triple &TargetTriple, |
113 | GlobalVariable &GV) { |
114 | // Limit to x86-64 ELF. |
115 | if (TargetTriple.getArch() != Triple::x86_64 || |
116 | TargetTriple.getObjectFormat() != Triple::ELF) |
117 | return; |
118 | // Limit to medium/large code models. |
119 | std::optional<CodeModel::Model> CM = GV.getParent()->getCodeModel(); |
120 | if (!CM || (*CM != CodeModel::Medium && *CM != CodeModel::Large)) |
121 | return; |
122 | GV.setCodeModel(CodeModel::Large); |
123 | } |
124 | |