OSDN Git Service

DWARF type hashing: begin implementing Step 5, summary hashing in declarable contexts
[android-x86/external-llvm.git] / lib / CodeGen / AsmPrinter / DIEHash.h
1 //===-- llvm/CodeGen/DIEHash.h - Dwarf Hashing Framework -------*- C++ -*--===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains support for DWARF4 hashing of DIEs.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "llvm/ADT/DenseMap.h"
15 #include "llvm/Support/MD5.h"
16
17 namespace llvm {
18
19 class CompileUnit;
20
21 /// \brief An object containing the capability of hashing and adding hash
22 /// attributes onto a DIE.
23 class DIEHash {
24   // The entry for a particular attribute.
25   struct AttrEntry {
26     const DIEValue *Val;
27     const DIEAbbrevData *Desc;
28   };
29
30   // Collection of all attributes used in hashing a particular DIE.
31   struct DIEAttrs {
32     AttrEntry DW_AT_name;
33     AttrEntry DW_AT_accessibility;
34     AttrEntry DW_AT_address_class;
35     AttrEntry DW_AT_allocated;
36     AttrEntry DW_AT_artificial;
37     AttrEntry DW_AT_associated;
38     AttrEntry DW_AT_binary_scale;
39     AttrEntry DW_AT_bit_offset;
40     AttrEntry DW_AT_bit_size;
41     AttrEntry DW_AT_bit_stride;
42     AttrEntry DW_AT_byte_size;
43     AttrEntry DW_AT_byte_stride;
44     AttrEntry DW_AT_const_expr;
45     AttrEntry DW_AT_const_value;
46     AttrEntry DW_AT_containing_type;
47     AttrEntry DW_AT_count;
48     AttrEntry DW_AT_data_bit_offset;
49     AttrEntry DW_AT_data_location;
50     AttrEntry DW_AT_data_member_location;
51     AttrEntry DW_AT_decimal_scale;
52     AttrEntry DW_AT_decimal_sign;
53     AttrEntry DW_AT_default_value;
54     AttrEntry DW_AT_digit_count;
55     AttrEntry DW_AT_discr;
56     AttrEntry DW_AT_discr_list;
57     AttrEntry DW_AT_discr_value;
58     AttrEntry DW_AT_encoding;
59     AttrEntry DW_AT_enum_class;
60     AttrEntry DW_AT_endianity;
61     AttrEntry DW_AT_explicit;
62     AttrEntry DW_AT_is_optional;
63     AttrEntry DW_AT_location;
64     AttrEntry DW_AT_lower_bound;
65     AttrEntry DW_AT_mutable;
66     AttrEntry DW_AT_ordering;
67     AttrEntry DW_AT_picture_string;
68     AttrEntry DW_AT_prototyped;
69     AttrEntry DW_AT_small;
70     AttrEntry DW_AT_segment;
71     AttrEntry DW_AT_string_length;
72     AttrEntry DW_AT_threads_scaled;
73     AttrEntry DW_AT_upper_bound;
74     AttrEntry DW_AT_use_location;
75     AttrEntry DW_AT_use_UTF8;
76     AttrEntry DW_AT_variable_parameter;
77     AttrEntry DW_AT_virtuality;
78     AttrEntry DW_AT_visibility;
79     AttrEntry DW_AT_vtable_elem_location;
80     AttrEntry DW_AT_type;
81
82     // Insert any additional ones here...
83   };
84
85 public:
86   /// \brief Computes the ODR signature.
87   uint64_t computeDIEODRSignature(DIE *Die);
88
89   /// \brief Computes the CU signature.
90   uint64_t computeCUSignature(DIE *Die);
91
92   /// \brief Computes the type signature.
93   uint64_t computeTypeSignature(DIE *Die);
94
95   // Helper routines to process parts of a DIE.
96 private:
97   /// \brief Adds the parent context of \param Die to the hash.
98   void addParentContext(DIE *Die);
99
100   /// \brief Adds the attributes of \param Die to the hash.
101   void addAttributes(DIE *Die);
102
103   /// \brief Computes the full DWARF4 7.27 hash of the DIE.
104   void computeHash(DIE *Die);
105
106   // Routines that add DIEValues to the hash.
107 private:
108   /// \brief Encodes and adds \param Value to the hash as a ULEB128.
109   void addULEB128(uint64_t Value);
110
111   /// \brief Encodes and adds \param Value to the hash as a SLEB128.
112   void addSLEB128(int64_t Value);
113
114   /// \brief Adds \param Str to the hash and includes a NULL byte.
115   void addString(StringRef Str);
116
117   /// \brief Collects the attributes of DIE \param Die into the \param Attrs
118   /// structure.
119   void collectAttributes(DIE *Die, DIEAttrs &Attrs);
120
121   /// \brief Hashes the attributes in \param Attrs in order.
122   void hashAttributes(const DIEAttrs &Attrs, dwarf::Tag Tag);
123
124   /// \brief Hashes an individual attribute.
125   void hashAttribute(AttrEntry Attr, dwarf::Tag Tag);
126
127 private:
128   MD5 Hash;
129   DenseMap<DIE*, unsigned> Numbering;
130 };
131 }