annotate llvm/lib/ExecutionEngine/JITLink/EHFrameSupportImpl.h @ 181:df311c476dd5

CreateIdentifierInfo in ParseCbC (not yet worked)
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 31 May 2020 12:30:11 +0900
parents 1d019706d866
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===------- EHFrameSupportImpl.h - JITLink eh-frame utils ------*- C++ -*-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8 //
anatofuz
parents:
diff changeset
9 // EHFrame registration support for JITLink.
anatofuz
parents:
diff changeset
10 //
anatofuz
parents:
diff changeset
11 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 #ifndef LLVM_LIB_EXECUTIONENGINE_JITLINK_EHFRAMESUPPORTIMPL_H
anatofuz
parents:
diff changeset
14 #define LLVM_LIB_EXECUTIONENGINE_JITLINK_EHFRAMESUPPORTIMPL_H
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 #include "llvm/ExecutionEngine/JITLink/EHFrameSupport.h"
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 #include "llvm/ExecutionEngine/JITLink/JITLink.h"
anatofuz
parents:
diff changeset
19 #include "llvm/Support/BinaryStreamReader.h"
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 namespace llvm {
anatofuz
parents:
diff changeset
22 namespace jitlink {
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 /// A LinkGraph pass that splits blocks in an eh-frame section into sub-blocks
anatofuz
parents:
diff changeset
25 /// representing individual eh-frames.
anatofuz
parents:
diff changeset
26 /// EHFrameSplitter should not be run without EHFrameEdgeFixer, which is
anatofuz
parents:
diff changeset
27 /// responsible for adding FDE-to-CIE edges.
anatofuz
parents:
diff changeset
28 class EHFrameSplitter {
anatofuz
parents:
diff changeset
29 public:
anatofuz
parents:
diff changeset
30 EHFrameSplitter(StringRef EHFrameSectionName);
anatofuz
parents:
diff changeset
31 Error operator()(LinkGraph &G);
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 private:
anatofuz
parents:
diff changeset
34 Error processBlock(LinkGraph &G, Block &B, LinkGraph::SplitBlockCache &Cache);
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 StringRef EHFrameSectionName;
anatofuz
parents:
diff changeset
37 };
anatofuz
parents:
diff changeset
38
anatofuz
parents:
diff changeset
39 /// A LinkGraph pass that adds missing FDE-to-CIE, FDE-to-PC and FDE-to-LSDA
anatofuz
parents:
diff changeset
40 /// edges.
anatofuz
parents:
diff changeset
41 class EHFrameEdgeFixer {
anatofuz
parents:
diff changeset
42 public:
anatofuz
parents:
diff changeset
43 EHFrameEdgeFixer(StringRef EHFrameSectionName, Edge::Kind FDEToCIE,
anatofuz
parents:
diff changeset
44 Edge::Kind FDEToPCBegin, Edge::Kind FDEToLSDA);
anatofuz
parents:
diff changeset
45 Error operator()(LinkGraph &G);
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 private:
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 struct AugmentationInfo {
anatofuz
parents:
diff changeset
50 bool AugmentationDataPresent = false;
anatofuz
parents:
diff changeset
51 bool EHDataFieldPresent = false;
anatofuz
parents:
diff changeset
52 uint8_t Fields[4] = {0x0, 0x0, 0x0, 0x0};
anatofuz
parents:
diff changeset
53 };
anatofuz
parents:
diff changeset
54
anatofuz
parents:
diff changeset
55 struct CIEInformation {
anatofuz
parents:
diff changeset
56 CIEInformation() = default;
anatofuz
parents:
diff changeset
57 CIEInformation(Symbol &CIESymbol) : CIESymbol(&CIESymbol) {}
anatofuz
parents:
diff changeset
58 Symbol *CIESymbol = nullptr;
anatofuz
parents:
diff changeset
59 bool FDEsHaveLSDAField = false;
anatofuz
parents:
diff changeset
60 };
anatofuz
parents:
diff changeset
61
anatofuz
parents:
diff changeset
62 struct EdgeTarget {
anatofuz
parents:
diff changeset
63 EdgeTarget() = default;
anatofuz
parents:
diff changeset
64 EdgeTarget(const Edge &E) : Target(&E.getTarget()), Addend(E.getAddend()) {}
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 Symbol *Target = nullptr;
anatofuz
parents:
diff changeset
67 Edge::AddendT Addend = 0;
anatofuz
parents:
diff changeset
68 };
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 using BlockEdgeMap = DenseMap<Edge::OffsetT, EdgeTarget>;
anatofuz
parents:
diff changeset
71 using CIEInfosMap = DenseMap<JITTargetAddress, CIEInformation>;
anatofuz
parents:
diff changeset
72
anatofuz
parents:
diff changeset
73 struct ParseContext {
anatofuz
parents:
diff changeset
74 ParseContext(LinkGraph &G) : G(G) {}
anatofuz
parents:
diff changeset
75
anatofuz
parents:
diff changeset
76 Expected<CIEInformation *> findCIEInfo(JITTargetAddress Address) {
anatofuz
parents:
diff changeset
77 auto I = CIEInfos.find(Address);
anatofuz
parents:
diff changeset
78 if (I == CIEInfos.end())
anatofuz
parents:
diff changeset
79 return make_error<JITLinkError>("No CIE found at address " +
anatofuz
parents:
diff changeset
80 formatv("{0:x16}", Address));
anatofuz
parents:
diff changeset
81 return &I->second;
anatofuz
parents:
diff changeset
82 }
anatofuz
parents:
diff changeset
83
anatofuz
parents:
diff changeset
84 LinkGraph &G;
anatofuz
parents:
diff changeset
85 CIEInfosMap CIEInfos;
anatofuz
parents:
diff changeset
86 BlockAddressMap AddrToBlock;
anatofuz
parents:
diff changeset
87 SymbolAddressMap AddrToSyms;
anatofuz
parents:
diff changeset
88 };
anatofuz
parents:
diff changeset
89
anatofuz
parents:
diff changeset
90 Error processBlock(ParseContext &PC, Block &B);
anatofuz
parents:
diff changeset
91 Error processCIE(ParseContext &PC, Block &B, size_t RecordOffset,
anatofuz
parents:
diff changeset
92 size_t RecordLength, size_t CIEDeltaFieldOffset);
anatofuz
parents:
diff changeset
93 Error processFDE(ParseContext &PC, Block &B, size_t RecordOffset,
anatofuz
parents:
diff changeset
94 size_t RecordLength, size_t CIEDeltaFieldOffset,
anatofuz
parents:
diff changeset
95 uint32_t CIEDelta, BlockEdgeMap &BlockEdges);
anatofuz
parents:
diff changeset
96
anatofuz
parents:
diff changeset
97 Expected<AugmentationInfo>
anatofuz
parents:
diff changeset
98 parseAugmentationString(BinaryStreamReader &RecordReader);
anatofuz
parents:
diff changeset
99 Expected<JITTargetAddress>
anatofuz
parents:
diff changeset
100 readAbsolutePointer(LinkGraph &G, BinaryStreamReader &RecordReader);
anatofuz
parents:
diff changeset
101 Expected<Symbol &> getOrCreateSymbol(ParseContext &PC, JITTargetAddress Addr);
anatofuz
parents:
diff changeset
102
anatofuz
parents:
diff changeset
103 StringRef EHFrameSectionName;
anatofuz
parents:
diff changeset
104 Edge::Kind FDEToCIE;
anatofuz
parents:
diff changeset
105 Edge::Kind FDEToPCBegin;
anatofuz
parents:
diff changeset
106 Edge::Kind FDEToLSDA;
anatofuz
parents:
diff changeset
107 };
anatofuz
parents:
diff changeset
108
anatofuz
parents:
diff changeset
109 } // end namespace jitlink
anatofuz
parents:
diff changeset
110 } // end namespace llvm
anatofuz
parents:
diff changeset
111
anatofuz
parents:
diff changeset
112 #endif // LLVM_LIB_EXECUTIONENGINE_JITLINK_EHFRAMESUPPORTIMPL_H