|           Line data    Source code 
       1             : //===- GlobalTypeTableBuilder.h ----------------------------------*- 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             : #ifndef LLVM_DEBUGINFO_CODEVIEW_GLOBALTYPETABLEBUILDER_H
      11             : #define LLVM_DEBUGINFO_CODEVIEW_GLOBALTYPETABLEBUILDER_H
      12             : 
      13             : #include "llvm/ADT/ArrayRef.h"
      14             : #include "llvm/ADT/DenseSet.h"
      15             : #include "llvm/ADT/SmallVector.h"
      16             : #include "llvm/DebugInfo/CodeView/CodeView.h"
      17             : #include "llvm/DebugInfo/CodeView/SimpleTypeSerializer.h"
      18             : #include "llvm/DebugInfo/CodeView/TypeCollection.h"
      19             : #include "llvm/DebugInfo/CodeView/TypeHashing.h"
      20             : #include "llvm/DebugInfo/CodeView/TypeIndex.h"
      21             : #include "llvm/Support/Allocator.h"
      22             : #include <cassert>
      23             : #include <cstdint>
      24             : #include <memory>
      25             : #include <vector>
      26             : 
      27             : namespace llvm {
      28             : namespace codeview {
      29             : 
      30             : class ContinuationRecordBuilder;
      31             : 
      32         614 : class GlobalTypeTableBuilder : public TypeCollection {
      33             :   /// Storage for records.  These need to outlive the TypeTableBuilder.
      34             :   BumpPtrAllocator &RecordStorage;
      35             : 
      36             :   /// A serializer that can write non-continuation leaf types.  Only used as
      37             :   /// a convenience function so that we can provide an interface method to
      38             :   /// write an unserialized record.
      39             :   SimpleTypeSerializer SimpleSerializer;
      40             : 
      41             :   /// Hash table.
      42             :   DenseMap<GloballyHashedType, TypeIndex> HashedRecords;
      43             : 
      44             :   /// Contains a list of all records indexed by TypeIndex.toArrayIndex().
      45             :   SmallVector<ArrayRef<uint8_t>, 2> SeenRecords;
      46             : 
      47             :   /// Contains a list of all hash values inexed by TypeIndex.toArrayIndex().
      48             :   SmallVector<GloballyHashedType, 2> SeenHashes;
      49             : 
      50             : public:
      51             :   explicit GlobalTypeTableBuilder(BumpPtrAllocator &Storage);
      52             :   ~GlobalTypeTableBuilder();
      53             : 
      54             :   // TypeTableCollection overrides
      55             :   Optional<TypeIndex> getFirst() override;
      56             :   Optional<TypeIndex> getNext(TypeIndex Prev) override;
      57             :   CVType getType(TypeIndex Index) override;
      58             :   StringRef getTypeName(TypeIndex Index) override;
      59             :   bool contains(TypeIndex Index) override;
      60             :   uint32_t size() override;
      61             :   uint32_t capacity() override;
      62             : 
      63             :   // public interface
      64             :   void reset();
      65             :   TypeIndex nextTypeIndex() const;
      66             : 
      67             :   BumpPtrAllocator &getAllocator() { return RecordStorage; }
      68             : 
      69             :   ArrayRef<ArrayRef<uint8_t>> records() const;
      70             :   ArrayRef<GloballyHashedType> hashes() const;
      71             : 
      72             :   template <typename CreateFunc>
      73        1998 :   TypeIndex insertRecordAs(GloballyHashedType Hash, size_t RecordSize,
      74             :                            CreateFunc Create) {
      75        1998 :     auto Result = HashedRecords.try_emplace(Hash, nextTypeIndex());
      76             : 
      77        1998 :     if (LLVM_UNLIKELY(Result.second)) {
      78        1760 :       uint8_t *Stable = RecordStorage.Allocate<uint8_t>(RecordSize);
      79             :       MutableArrayRef<uint8_t> Data(Stable, RecordSize);
      80        3482 :       SeenRecords.push_back(Create(Data));
      81        1760 :       SeenHashes.push_back(Hash);
      82             :     }
      83             : 
      84             :     // Update the caller's copy of Record to point a stable copy.
      85        1998 :     return Result.first->second;
      86             :   }
      87             : 
      88             :   TypeIndex insertRecordBytes(ArrayRef<uint8_t> Data);
      89             :   TypeIndex insertRecord(ContinuationRecordBuilder &Builder);
      90             : 
      91             :   template <typename T> TypeIndex writeLeafType(T &Record) {
      92        1828 :     ArrayRef<uint8_t> Data = SimpleSerializer.serialize(Record);
      93        1828 :     return insertRecordBytes(Data);
      94             :   }
      95             : };
      96             : 
      97             : } // end namespace codeview
      98             : } // end namespace llvm
      99             : 
     100             : #endif // LLVM_DEBUGINFO_CODEVIEW_MERGINGTYPETABLEBUILDER_H
 |