OSDN Git Service

Add the start of DIE hashing for DWARF4 type units and split dwarf
[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/Support/MD5.h"
15
16 namespace llvm {
17
18 class CompileUnit;
19
20 /// \brief An object containing the capability of hashing and adding hash
21 /// attributes onto a DIE.
22 class DIEHash {
23   // The entry for a particular attribute.
24   struct AttrEntry {
25     const DIEValue *Val;
26     const DIEAbbrevData *Desc;
27   };
28
29   // Collection of all attributes used in hashing a particular DIE.
30   struct DIEAttrs {
31     AttrEntry DW_AT_name;
32   };
33
34 public:
35   /// \brief Computes the ODR signature
36   uint64_t computeDIEODRSignature(DIE *Die);
37
38   /// \brief Computes the CU signature
39   uint64_t computeCUSignature(DIE *Die);
40
41   // Helper routines to process parts of a DIE.
42 private:
43   /// \brief Adds the parent context of \param Die to the hash.
44   void addParentContext(DIE *Die);
45
46   /// \brief Adds the attributes of \param Die to the hash.
47   void addAttributes(DIE *Die);
48
49   /// \brief Computes the full DWARF4 7.27 hash of the DIE.
50   void computeHash(DIE *Die);
51
52   // Routines that add DIEValues to the hash.
53 private:
54   /// \brief Encodes and adds \param Value to the hash as a ULEB128.
55   void addULEB128(uint64_t Value);
56
57   /// \brief Adds \param Str to the hash and includes a NULL byte.
58   void addString(StringRef Str);
59
60   /// \brief Collects the attributes of DIE \param Die into the \param Attrs
61   /// structure.
62   void collectAttributes(DIE *Die, DIEAttrs Attrs);
63
64   /// \brief Hashes the attributes in \param Attrs in order.
65   void hashAttributes(DIEAttrs Attrs);
66
67   /// \brief Hashes an individual attribute.
68   void hashAttribute(AttrEntry Attr);
69
70 private:
71   MD5 Hash;
72 };
73 }