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"
25 /// An object containing the capability of hashing and adding hash
26 /// attributes onto a DIE.
28 // Collection of all attributes used in hashing a particular DIE.
30 #define HANDLE_DIE_HASH_ATTR(NAME) DIEValue NAME;
31 #include "DIEHashAttributes.def"
35 DIEHash(AsmPrinter
*A
= nullptr) : AP(A
) {}
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
);
66 /// Adds \param Str to the hash and includes a NULL byte.
67 void addString(StringRef Str
);
69 /// Collects the attributes of DIE \param Die into the \param Attrs
71 void collectAttributes(const DIE
&Die
, DIEAttrs
&Attrs
);
73 /// Hashes the attributes in \param Attrs in order.
74 void hashAttributes(const DIEAttrs
&Attrs
, dwarf::Tag Tag
);
76 /// Hashes the data in a block like DIEValue, e.g. DW_FORM_block or
78 void hashBlockData(const DIE::const_value_range
&Values
);
80 /// Hashes the contents pointed to in the .debug_loc section.
81 void hashLocList(const DIELocList
&LocList
);
83 /// Hashes an individual attribute.
84 void hashAttribute(const DIEValue
&Value
, dwarf::Tag Tag
);
86 /// Hashes an attribute that refers to another DIE.
87 void hashDIEEntry(dwarf::Attribute Attribute
, dwarf::Tag Tag
,
90 /// Hashes a reference to a named type in such a way that is
91 /// independent of whether that type is described by a declaration or a
93 void hashShallowTypeReference(dwarf::Attribute Attribute
, const DIE
&Entry
,
96 /// Hashes a reference to a previously referenced type DIE.
97 void hashRepeatedTypeReference(dwarf::Attribute Attribute
,
100 void hashNestedType(const DIE
&Die
, StringRef Name
);
105 DenseMap
<const DIE
*, unsigned> Numbering
;