1 //===-- llvm/CodeGen/DIEHash.h - Dwarf Hashing Framework -------*- C++ -*--===//
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
7 //===----------------------------------------------------------------------===//
9 // This file contains support for DWARF4 hashing of DIEs.
11 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_LIB_CODEGEN_ASMPRINTER_DIEHASH_H
14 #define LLVM_LIB_CODEGEN_ASMPRINTER_DIEHASH_H
16 #include "llvm/ADT/DenseMap.h"
17 #include "llvm/CodeGen/DIE.h"
18 #include "llvm/Support/MD5.h"
24 /// An object containing the capability of hashing and adding hash
25 /// attributes onto a DIE.
27 // Collection of all attributes used in hashing a particular DIE.
29 #define HANDLE_DIE_HASH_ATTR(NAME) DIEValue NAME;
30 #include "DIEHashAttributes.def"
34 DIEHash(AsmPrinter
*A
= nullptr, DwarfCompileUnit
*CU
= nullptr)
37 /// Computes the CU signature.
38 uint64_t computeCUSignature(StringRef DWOName
, const DIE
&Die
);
40 /// Computes the type signature.
41 uint64_t computeTypeSignature(const DIE
&Die
);
43 // Helper routines to process parts of a DIE.
45 /// Adds the parent context of \param Parent to the hash.
46 void addParentContext(const DIE
&Parent
);
48 /// Adds the attributes of \param Die to the hash.
49 void addAttributes(const DIE
&Die
);
51 /// Computes the full DWARF4 7.27 hash of the DIE.
52 void computeHash(const DIE
&Die
);
54 // Routines that add DIEValues to the hash.
56 /// Adds \param Value to the hash.
57 void update(uint8_t Value
) { Hash
.update(Value
); }
59 /// Encodes and adds \param Value to the hash as a ULEB128.
60 void addULEB128(uint64_t Value
);
62 /// Encodes and adds \param Value to the hash as a SLEB128.
63 void addSLEB128(int64_t Value
);
65 void hashRawTypeReference(const DIE
&Entry
);
68 /// Adds \param Str to the hash and includes a NULL byte.
69 void addString(StringRef Str
);
71 /// Collects the attributes of DIE \param Die into the \param Attrs
73 void collectAttributes(const DIE
&Die
, DIEAttrs
&Attrs
);
75 /// Hashes the attributes in \param Attrs in order.
76 void hashAttributes(const DIEAttrs
&Attrs
, dwarf::Tag Tag
);
78 /// Hashes the data in a block like DIEValue, e.g. DW_FORM_block or
80 void hashBlockData(const DIE::const_value_range
&Values
);
82 /// Hashes the contents pointed to in the .debug_loc section.
83 void hashLocList(const DIELocList
&LocList
);
85 /// Hashes an individual attribute.
86 void hashAttribute(const DIEValue
&Value
, dwarf::Tag Tag
);
88 /// Hashes an attribute that refers to another DIE.
89 void hashDIEEntry(dwarf::Attribute Attribute
, dwarf::Tag Tag
,
92 /// Hashes a reference to a named type in such a way that is
93 /// independent of whether that type is described by a declaration or a
95 void hashShallowTypeReference(dwarf::Attribute Attribute
, const DIE
&Entry
,
98 /// Hashes a reference to a previously referenced type DIE.
99 void hashRepeatedTypeReference(dwarf::Attribute Attribute
,
102 void hashNestedType(const DIE
&Die
, StringRef Name
);
107 DwarfCompileUnit
*CU
;
108 DenseMap
<const DIE
*, unsigned> Numbering
;