mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-19 14:44:39 +00:00
Bitcode: Stop using MODULE_CODE_METADATA_VALUES
The motivation for MODULE_CODE_METADATA_VALUES was to enable an -flto=thin scheme where: 1. First, one function is cherry-picked from a bitcode file. 2. Later, another function is cherry-picked. 3. Later, ... 4. Finally, the metadata needed by all the previous functions is loaded. This was abandoned in favour of: 1. Calculate the superset of functions needed from a Module. 2. Link all functions at once. Delayed metadata reading no longer serves a purpose. It also adds a few complication, since we can't count on metadata being properly parsed when exiting the BitcodeReader. After discussing with Teresa, we agreed to remove it. The code that depended on this was removed/updated in r264326. llvm-svn: 264378
This commit is contained in:
parent
e37e9f43b7
commit
68f5624356
@ -103,8 +103,7 @@ enum { BITCODE_CURRENT_EPOCH = 0 };
|
||||
// ALIAS: [alias value type, addrspace, aliasee val#, linkage, visibility]
|
||||
MODULE_CODE_ALIAS = 14,
|
||||
|
||||
// METADATA_VALUES: [numvals]
|
||||
MODULE_CODE_METADATA_VALUES = 15,
|
||||
MODULE_CODE_METADATA_VALUES_UNUSED = 15,
|
||||
|
||||
// SOURCE_FILENAME: [namechar x N]
|
||||
MODULE_CODE_SOURCE_FILENAME = 16,
|
||||
|
@ -146,11 +146,6 @@ class BitcodeReader : public GVMaterializer {
|
||||
uint64_t VSTOffset = 0;
|
||||
// Contains an arbitrary and optional string identifying the bitcode producer
|
||||
std::string ProducerIdentification;
|
||||
// Number of module level metadata records specified by the
|
||||
// MODULE_CODE_METADATA_VALUES record.
|
||||
unsigned NumModuleMDs = 0;
|
||||
// Support older bitcode without the MODULE_CODE_METADATA_VALUES record.
|
||||
bool SeenModuleValuesRecord = false;
|
||||
|
||||
std::vector<Type*> TypeList;
|
||||
BitcodeReaderValueList ValueList;
|
||||
@ -1893,20 +1888,6 @@ static int64_t unrotateSign(uint64_t U) { return U & 1 ? ~(U >> 1) : U >> 1; }
|
||||
std::error_code BitcodeReader::parseMetadata(bool ModuleLevel) {
|
||||
IsMetadataMaterialized = true;
|
||||
unsigned NextMetadataNo = MetadataList.size();
|
||||
if (ModuleLevel && SeenModuleValuesRecord) {
|
||||
// Now that we are parsing the module level metadata, we want to restart
|
||||
// the numbering of the MD values, and replace temp MD created earlier
|
||||
// with their real values. If we saw a METADATA_VALUE record then we
|
||||
// would have set the MetadataList size to the number specified in that
|
||||
// record, to support parsing function-level metadata first, and we need
|
||||
// to reset back to 0 to fill the MetadataList in with the parsed module
|
||||
// The function-level metadata parsing should have reset the MetadataList
|
||||
// size back to the value reported by the METADATA_VALUE record, saved in
|
||||
// NumModuleMDs.
|
||||
assert(NumModuleMDs == MetadataList.size() &&
|
||||
"Expected MetadataList to only contain module level values");
|
||||
NextMetadataNo = 0;
|
||||
}
|
||||
|
||||
if (Stream.EnterSubBlock(bitc::METADATA_BLOCK_ID))
|
||||
return error("Invalid record");
|
||||
@ -1940,9 +1921,6 @@ std::error_code BitcodeReader::parseMetadata(bool ModuleLevel) {
|
||||
return error("Malformed block");
|
||||
case BitstreamEntry::EndBlock:
|
||||
MetadataList.tryToResolveCycles();
|
||||
assert((!(ModuleLevel && SeenModuleValuesRecord) ||
|
||||
NumModuleMDs == MetadataList.size()) &&
|
||||
"Inconsistent bitcode: METADATA_VALUES mismatch");
|
||||
return std::error_code();
|
||||
case BitstreamEntry::Record:
|
||||
// The interesting case.
|
||||
@ -3708,28 +3686,6 @@ std::error_code BitcodeReader::parseModule(uint64_t ResumeBit,
|
||||
return error("Invalid record");
|
||||
VSTOffset = Record[0];
|
||||
break;
|
||||
/// MODULE_CODE_METADATA_VALUES: [numvals]
|
||||
case bitc::MODULE_CODE_METADATA_VALUES:
|
||||
if (Record.size() < 1)
|
||||
return error("Invalid record");
|
||||
assert(!IsMetadataMaterialized);
|
||||
// This record contains the number of metadata values in the module-level
|
||||
// METADATA_BLOCK. It is used to support lazy parsing of metadata as
|
||||
// a postpass, where we will parse function-level metadata first.
|
||||
// This is needed because the ids of metadata are assigned implicitly
|
||||
// based on their ordering in the bitcode, with the function-level
|
||||
// metadata ids starting after the module-level metadata ids. Otherwise,
|
||||
// we would have to parse the module-level metadata block to prime the
|
||||
// MetadataList when we are lazy loading metadata during function
|
||||
// importing. Initialize the MetadataList size here based on the
|
||||
// record value, regardless of whether we are doing lazy metadata
|
||||
// loading, so that we have consistent handling and assertion
|
||||
// checking in parseMetadata for module-level metadata.
|
||||
NumModuleMDs = Record[0];
|
||||
SeenModuleValuesRecord = true;
|
||||
assert(MetadataList.size() == 0);
|
||||
MetadataList.resize(NumModuleMDs);
|
||||
break;
|
||||
/// MODULE_CODE_SOURCE_FILENAME: [namechar x N]
|
||||
case bitc::MODULE_CODE_SOURCE_FILENAME:
|
||||
SmallString<128> ValueName;
|
||||
@ -5288,12 +5244,8 @@ std::error_code BitcodeReader::findFunctionInStream(
|
||||
void BitcodeReader::releaseBuffer() { Buffer.release(); }
|
||||
|
||||
std::error_code BitcodeReader::materialize(GlobalValue *GV) {
|
||||
// In older bitcode we must materialize the metadata before parsing
|
||||
// any functions, in order to set up the MetadataList properly.
|
||||
if (!SeenModuleValuesRecord) {
|
||||
if (std::error_code EC = materializeMetadata())
|
||||
return EC;
|
||||
}
|
||||
if (std::error_code EC = materializeMetadata())
|
||||
return EC;
|
||||
|
||||
Function *F = dyn_cast<Function>(GV);
|
||||
// If it's not a function or is already material, ignore the request.
|
||||
|
@ -803,23 +803,6 @@ static uint64_t WriteModuleInfo(const Module *M, const ValueEnumerator &VE,
|
||||
Vals.clear();
|
||||
}
|
||||
|
||||
// Write a record indicating the number of module-level metadata IDs
|
||||
// This is needed because the ids of metadata are assigned implicitly
|
||||
// based on their ordering in the bitcode, with the function-level
|
||||
// metadata ids starting after the module-level metadata ids. For
|
||||
// function importing where we lazy load the metadata as a postpass,
|
||||
// we want to avoid parsing the module-level metadata before parsing
|
||||
// the imported functions.
|
||||
{
|
||||
BitCodeAbbrev *Abbv = new BitCodeAbbrev();
|
||||
Abbv->Add(BitCodeAbbrevOp(bitc::MODULE_CODE_METADATA_VALUES));
|
||||
Abbv->Add(BitCodeAbbrevOp(BitCodeAbbrevOp::VBR, 6));
|
||||
unsigned MDValsAbbrev = Stream.EmitAbbrev(Abbv);
|
||||
Vals.push_back(VE.numMDs());
|
||||
Stream.EmitRecord(bitc::MODULE_CODE_METADATA_VALUES, Vals, MDValsAbbrev);
|
||||
Vals.clear();
|
||||
}
|
||||
|
||||
// Emit the module's source file name.
|
||||
{
|
||||
StringEncoding Bits = getStringEncoding(M->getSourceFileName().data(),
|
||||
|
@ -172,7 +172,7 @@ static const char *GetCodeName(unsigned CodeID, unsigned BlockID,
|
||||
STRINGIFY_CODE(MODULE_CODE, PURGEVALS)
|
||||
STRINGIFY_CODE(MODULE_CODE, GCNAME)
|
||||
STRINGIFY_CODE(MODULE_CODE, VSTOFFSET)
|
||||
STRINGIFY_CODE(MODULE_CODE, METADATA_VALUES)
|
||||
STRINGIFY_CODE(MODULE_CODE, METADATA_VALUES_UNUSED)
|
||||
STRINGIFY_CODE(MODULE_CODE, SOURCE_FILENAME)
|
||||
}
|
||||
case bitc::IDENTIFICATION_BLOCK_ID:
|
||||
|
Loading…
x
Reference in New Issue
Block a user