003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/lib/DebugInfo/PDB/Native
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
lib
/
DebugInfo
/
PDB
/
Native
/
📁
..
📄
DbiModuleDescriptor.cpp
(2.5 KB)
📄
DbiModuleDescriptorBuilder.cpp
(6.63 KB)
📄
DbiModuleList.cpp
(8.3 KB)
📄
DbiStream.cpp
(12.8 KB)
📄
DbiStreamBuilder.cpp
(14.82 KB)
📄
EnumTables.cpp
(1.33 KB)
📄
GSIStreamBuilder.cpp
(17.23 KB)
📄
GlobalsStream.cpp
(6.56 KB)
📄
Hash.cpp
(2.39 KB)
📄
HashTable.cpp
(2.55 KB)
📄
InfoStream.cpp
(3.94 KB)
📄
InfoStreamBuilder.cpp
(2.67 KB)
📄
InjectedSourceStream.cpp
(2.31 KB)
📄
ModuleDebugStream.cpp
(4.74 KB)
📄
NamedStreamMap.cpp
(4.2 KB)
📄
NativeCompilandSymbol.cpp
(2.22 KB)
📄
NativeEnumGlobals.cpp
(1.87 KB)
📄
NativeEnumInjectedSources.cpp
(4.05 KB)
📄
NativeEnumLineNumbers.cpp
(1.44 KB)
📄
NativeEnumModules.cpp
(1.36 KB)
📄
NativeEnumTypes.cpp
(2.62 KB)
📄
NativeExeSymbol.cpp
(3.25 KB)
📄
NativeFunctionSymbol.cpp
(2.12 KB)
📄
NativeLineNumber.cpp
(1.88 KB)
📄
NativePublicSymbol.cpp
(1.92 KB)
📄
NativeRawSymbol.cpp
(14.98 KB)
📄
NativeSession.cpp
(12.36 KB)
📄
NativeSourceFile.cpp
(1.47 KB)
📄
NativeSymbolEnumerator.cpp
(4.24 KB)
📄
NativeTypeArray.cpp
(2.6 KB)
📄
NativeTypeBuiltin.cpp
(1.67 KB)
📄
NativeTypeEnum.cpp
(12.55 KB)
📄
NativeTypeFunctionSig.cpp
(7.3 KB)
📄
NativeTypePointer.cpp
(6.41 KB)
📄
NativeTypeTypedef.cpp
(1.05 KB)
📄
NativeTypeUDT.cpp
(6.93 KB)
📄
NativeTypeVTShape.cpp
(1.42 KB)
📄
PDBFile.cpp
(16.2 KB)
📄
PDBFileBuilder.cpp
(11 KB)
📄
PDBStringTable.cpp
(4.53 KB)
📄
PDBStringTableBuilder.cpp
(6.88 KB)
📄
PublicsStream.cpp
(3.89 KB)
📄
RawError.cpp
(2.13 KB)
📄
SymbolCache.cpp
(22.39 KB)
📄
SymbolStream.cpp
(1.4 KB)
📄
TpiHashing.cpp
(4.32 KB)
📄
TpiStream.cpp
(7.85 KB)
📄
TpiStreamBuilder.cpp
(6.32 KB)
Editing: PDBStringTable.cpp
//===- PDBStringTable.cpp - PDB String Table ---------------------*- 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 // //===----------------------------------------------------------------------===// #include "llvm/DebugInfo/PDB/Native/PDBStringTable.h" #include "llvm/ADT/ArrayRef.h" #include "llvm/DebugInfo/PDB/Native/Hash.h" #include "llvm/DebugInfo/PDB/Native/RawError.h" #include "llvm/DebugInfo/PDB/Native/RawTypes.h" #include "llvm/Support/BinaryStreamReader.h" #include "llvm/Support/Endian.h" using namespace llvm; using namespace llvm::support; using namespace llvm::pdb; uint32_t PDBStringTable::getByteSize() const { return Header->ByteSize; } uint32_t PDBStringTable::getNameCount() const { return NameCount; } uint32_t PDBStringTable::getHashVersion() const { return Header->HashVersion; } uint32_t PDBStringTable::getSignature() const { return Header->Signature; } Error PDBStringTable::readHeader(BinaryStreamReader &Reader) { if (auto EC = Reader.readObject(Header)) return EC; if (Header->Signature != PDBStringTableSignature) return make_error<RawError>(raw_error_code::corrupt_file, "Invalid hash table signature"); if (Header->HashVersion != 1 && Header->HashVersion != 2) return make_error<RawError>(raw_error_code::corrupt_file, "Unsupported hash version"); assert(Reader.bytesRemaining() == 0); return Error::success(); } Error PDBStringTable::readStrings(BinaryStreamReader &Reader) { BinaryStreamRef Stream; if (auto EC = Reader.readStreamRef(Stream)) return EC; if (auto EC = Strings.initialize(Stream)) { return joinErrors(std::move(EC), make_error<RawError>(raw_error_code::corrupt_file, "Invalid hash table byte length")); } assert(Reader.bytesRemaining() == 0); return Error::success(); } const codeview::DebugStringTableSubsectionRef & PDBStringTable::getStringTable() const { return Strings; } Error PDBStringTable::readHashTable(BinaryStreamReader &Reader) { const support::ulittle32_t *HashCount; if (auto EC = Reader.readObject(HashCount)) return EC; if (auto EC = Reader.readArray(IDs, *HashCount)) { return joinErrors(std::move(EC), make_error<RawError>(raw_error_code::corrupt_file, "Could not read bucket array")); } return Error::success(); } Error PDBStringTable::readEpilogue(BinaryStreamReader &Reader) { if (auto EC = Reader.readInteger(NameCount)) return EC; assert(Reader.bytesRemaining() == 0); return Error::success(); } Error PDBStringTable::reload(BinaryStreamReader &Reader) { BinaryStreamReader SectionReader; std::tie(SectionReader, Reader) = Reader.split(sizeof(PDBStringTableHeader)); if (auto EC = readHeader(SectionReader)) return EC; std::tie(SectionReader, Reader) = Reader.split(Header->ByteSize); if (auto EC = readStrings(SectionReader)) return EC; // We don't know how long the hash table is until we parse it, so let the // function responsible for doing that figure it out. if (auto EC = readHashTable(Reader)) return EC; std::tie(SectionReader, Reader) = Reader.split(sizeof(uint32_t)); if (auto EC = readEpilogue(SectionReader)) return EC; assert(Reader.bytesRemaining() == 0); return Error::success(); } Expected<StringRef> PDBStringTable::getStringForID(uint32_t ID) const { return Strings.getString(ID); } Expected<uint32_t> PDBStringTable::getIDForString(StringRef Str) const { uint32_t Hash = (Header->HashVersion == 1) ? hashStringV1(Str) : hashStringV2(Str); size_t Count = IDs.size(); uint32_t Start = Hash % Count; for (size_t I = 0; I < Count; ++I) { // The hash is just a starting point for the search, but if it // doesn't work we should find the string no matter what, because // we iterate the entire array. uint32_t Index = (Start + I) % Count; // If we find 0, it means the item isn't in the hash table. uint32_t ID = IDs[Index]; if (ID == 0) return make_error<RawError>(raw_error_code::no_entry); auto ExpectedStr = getStringForID(ID); if (!ExpectedStr) return ExpectedStr.takeError(); if (*ExpectedStr == Str) return ID; } return make_error<RawError>(raw_error_code::no_entry); } FixedStreamArray<support::ulittle32_t> PDBStringTable::name_ids() const { return IDs; }
Upload File
Create Folder