blob: 44383ed6c7ddcca2d1474609013d15e7fefaeb1d [file] [log] [blame]
//===- StringPool.h ---------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_DWARFLINKERPARALLEL_STRINGPOOL_H
#define LLVM_DWARFLINKERPARALLEL_STRINGPOOL_H
#include "llvm/ADT/ConcurrentHashtable.h"
#include "llvm/CodeGen/DwarfStringPoolEntry.h"
#include "llvm/Support/Allocator.h"
#include "llvm/Support/PerThreadBumpPtrAllocator.h"
#include <string>
#include <string_view>
namespace llvm {
namespace dwarflinker_parallel {
/// StringEntry keeps data of the string: the length, external offset
/// and a string body which is placed right after StringEntry.
using StringEntry = StringMapEntry<DwarfStringPoolEntry *>;
class StringPoolEntryInfo {
public:
/// \returns Hash value for the specified \p Key.
static inline uint64_t getHashValue(const StringRef &Key) {
return xxh3_64bits(Key);
}
/// \returns true if both \p LHS and \p RHS are equal.
static inline bool isEqual(const StringRef &LHS, const StringRef &RHS) {
return LHS == RHS;
}
/// \returns key for the specified \p KeyData.
static inline StringRef getKey(const StringEntry &KeyData) {
return KeyData.getKey();
}
/// \returns newly created object of KeyDataTy type.
static inline StringEntry *
create(const StringRef &Key, parallel::PerThreadBumpPtrAllocator &Allocator) {
return StringEntry::create(Key, Allocator);
}
};
class StringPool
: public ConcurrentHashTableByPtr<StringRef, StringEntry,
parallel::PerThreadBumpPtrAllocator,
StringPoolEntryInfo> {
public:
StringPool()
: ConcurrentHashTableByPtr<StringRef, StringEntry,
parallel::PerThreadBumpPtrAllocator,
StringPoolEntryInfo>(Allocator) {}
StringPool(size_t InitialSize)
: ConcurrentHashTableByPtr<StringRef, StringEntry,
parallel::PerThreadBumpPtrAllocator,
StringPoolEntryInfo>(Allocator, InitialSize) {}
parallel::PerThreadBumpPtrAllocator &getAllocatorRef() { return Allocator; }
private:
parallel::PerThreadBumpPtrAllocator Allocator;
};
} // end of namespace dwarflinker_parallel
} // end namespace llvm
#endif // LLVM_DWARFLINKERPARALLEL_STRINGPOOL_H