0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
1 //===-- llvm/CodeGen/DIEHash.h - Dwarf Hashing Framework -------*- C++ -*--===//
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
2 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
3 // The LLVM Compiler Infrastructure
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
4 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
5 // This file is distributed under the University of Illinois Open Source
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
6 // License. See LICENSE.TXT for details.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
7 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
8 //===----------------------------------------------------------------------===//
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
9 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
10 // This file contains support for DWARF4 hashing of DIEs.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
11 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
12 //===----------------------------------------------------------------------===//
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
13
|
77
|
14 #ifndef LLVM_LIB_CODEGEN_ASMPRINTER_DIEHASH_H
|
|
15 #define LLVM_LIB_CODEGEN_ASMPRINTER_DIEHASH_H
|
|
16
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
17 #include "llvm/ADT/DenseMap.h"
|
83
|
18 #include "llvm/CodeGen/DIE.h"
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
19 #include "llvm/Support/MD5.h"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
20
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
21 namespace llvm {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
22
|
77
|
23 class AsmPrinter;
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
24 class CompileUnit;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
25
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
26 /// \brief An object containing the capability of hashing and adding hash
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
27 /// attributes onto a DIE.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
28 class DIEHash {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
29 // Collection of all attributes used in hashing a particular DIE.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
30 struct DIEAttrs {
|
95
|
31 DIEValue DW_AT_name;
|
|
32 DIEValue DW_AT_accessibility;
|
|
33 DIEValue DW_AT_address_class;
|
|
34 DIEValue DW_AT_allocated;
|
|
35 DIEValue DW_AT_artificial;
|
|
36 DIEValue DW_AT_associated;
|
|
37 DIEValue DW_AT_binary_scale;
|
|
38 DIEValue DW_AT_bit_offset;
|
|
39 DIEValue DW_AT_bit_size;
|
|
40 DIEValue DW_AT_bit_stride;
|
|
41 DIEValue DW_AT_byte_size;
|
|
42 DIEValue DW_AT_byte_stride;
|
|
43 DIEValue DW_AT_const_expr;
|
|
44 DIEValue DW_AT_const_value;
|
|
45 DIEValue DW_AT_containing_type;
|
|
46 DIEValue DW_AT_count;
|
|
47 DIEValue DW_AT_data_bit_offset;
|
|
48 DIEValue DW_AT_data_location;
|
|
49 DIEValue DW_AT_data_member_location;
|
|
50 DIEValue DW_AT_decimal_scale;
|
|
51 DIEValue DW_AT_decimal_sign;
|
|
52 DIEValue DW_AT_default_value;
|
|
53 DIEValue DW_AT_digit_count;
|
|
54 DIEValue DW_AT_discr;
|
|
55 DIEValue DW_AT_discr_list;
|
|
56 DIEValue DW_AT_discr_value;
|
|
57 DIEValue DW_AT_encoding;
|
|
58 DIEValue DW_AT_enum_class;
|
|
59 DIEValue DW_AT_endianity;
|
|
60 DIEValue DW_AT_explicit;
|
|
61 DIEValue DW_AT_is_optional;
|
|
62 DIEValue DW_AT_location;
|
|
63 DIEValue DW_AT_lower_bound;
|
|
64 DIEValue DW_AT_mutable;
|
|
65 DIEValue DW_AT_ordering;
|
|
66 DIEValue DW_AT_picture_string;
|
|
67 DIEValue DW_AT_prototyped;
|
|
68 DIEValue DW_AT_small;
|
|
69 DIEValue DW_AT_segment;
|
|
70 DIEValue DW_AT_string_length;
|
|
71 DIEValue DW_AT_threads_scaled;
|
|
72 DIEValue DW_AT_upper_bound;
|
|
73 DIEValue DW_AT_use_location;
|
|
74 DIEValue DW_AT_use_UTF8;
|
|
75 DIEValue DW_AT_variable_parameter;
|
|
76 DIEValue DW_AT_virtuality;
|
|
77 DIEValue DW_AT_visibility;
|
|
78 DIEValue DW_AT_vtable_elem_location;
|
|
79 DIEValue DW_AT_type;
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
80
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
81 // Insert any additional ones here...
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
82 };
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
83
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
84 public:
|
77
|
85 DIEHash(AsmPrinter *A = nullptr) : AP(A) {}
|
|
86
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
87 /// \brief Computes the ODR signature.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
88 uint64_t computeDIEODRSignature(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
89
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
90 /// \brief Computes the CU signature.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
91 uint64_t computeCUSignature(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
92
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
93 /// \brief Computes the type signature.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
94 uint64_t computeTypeSignature(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
95
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
96 // Helper routines to process parts of a DIE.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
97 private:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
98 /// \brief Adds the parent context of \param Die to the hash.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
99 void addParentContext(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
100
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
101 /// \brief Adds the attributes of \param Die to the hash.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
102 void addAttributes(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
103
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
104 /// \brief Computes the full DWARF4 7.27 hash of the DIE.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
105 void computeHash(const DIE &Die);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
106
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
107 // Routines that add DIEValues to the hash.
|
77
|
108 public:
|
|
109 /// \brief Adds \param Value to the hash.
|
|
110 void update(uint8_t Value) { Hash.update(Value); }
|
|
111
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
112 /// \brief Encodes and adds \param Value to the hash as a ULEB128.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
113 void addULEB128(uint64_t Value);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
114
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
115 /// \brief Encodes and adds \param Value to the hash as a SLEB128.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
116 void addSLEB128(int64_t Value);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
117
|
77
|
118 private:
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
119 /// \brief Adds \param Str to the hash and includes a NULL byte.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
120 void addString(StringRef Str);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
121
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
122 /// \brief Collects the attributes of DIE \param Die into the \param Attrs
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
123 /// structure.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
124 void collectAttributes(const DIE &Die, DIEAttrs &Attrs);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
125
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
126 /// \brief Hashes the attributes in \param Attrs in order.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
127 void hashAttributes(const DIEAttrs &Attrs, dwarf::Tag Tag);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
128
|
77
|
129 /// \brief Hashes the data in a block like DIEValue, e.g. DW_FORM_block or
|
|
130 /// DW_FORM_exprloc.
|
95
|
131 void hashBlockData(const DIE::const_value_range &Values);
|
77
|
132
|
|
133 /// \brief Hashes the contents pointed to in the .debug_loc section.
|
|
134 void hashLocList(const DIELocList &LocList);
|
|
135
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
136 /// \brief Hashes an individual attribute.
|
95
|
137 void hashAttribute(DIEValue Value, dwarf::Tag Tag);
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
138
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
139 /// \brief Hashes an attribute that refers to another DIE.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
140 void hashDIEEntry(dwarf::Attribute Attribute, dwarf::Tag Tag,
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
141 const DIE &Entry);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
142
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
143 /// \brief Hashes a reference to a named type in such a way that is
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
144 /// independent of whether that type is described by a declaration or a
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
145 /// definition.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
146 void hashShallowTypeReference(dwarf::Attribute Attribute, const DIE &Entry,
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
147 StringRef Name);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
148
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
149 /// \brief Hashes a reference to a previously referenced type DIE.
|
33
|
150 void hashRepeatedTypeReference(dwarf::Attribute Attribute,
|
|
151 unsigned DieNumber);
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
152
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
153 void hashNestedType(const DIE &Die, StringRef Name);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
154
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
155 private:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
156 MD5 Hash;
|
77
|
157 AsmPrinter *AP;
|
0
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
158 DenseMap<const DIE *, unsigned> Numbering;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
159 };
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
160 }
|
77
|
161
|
|
162 #endif
|