mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-18 02:16:43 +00:00
write the symbol table for function bodies
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36610 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d309c75b7d
commit
be1f993f2d
@ -683,6 +683,36 @@ static void WriteInstruction(const Instruction &I, ValueEnumerator &VE,
|
|||||||
Vals.clear();
|
Vals.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Emit names for globals/functions etc.
|
||||||
|
static void WriteValueSymbolTable(const ValueSymbolTable &VST,
|
||||||
|
const ValueEnumerator &VE,
|
||||||
|
BitstreamWriter &Stream) {
|
||||||
|
if (VST.empty()) return;
|
||||||
|
Stream.EnterSubblock(bitc::VALUE_SYMTAB_BLOCK_ID, 3);
|
||||||
|
|
||||||
|
// FIXME: Set up the abbrev, we know how many values there are!
|
||||||
|
// FIXME: We know if the type names can use 7-bit ascii.
|
||||||
|
SmallVector<unsigned, 64> NameVals;
|
||||||
|
|
||||||
|
for (ValueSymbolTable::const_iterator SI = VST.begin(), SE = VST.end();
|
||||||
|
SI != SE; ++SI) {
|
||||||
|
unsigned AbbrevToUse = 0;
|
||||||
|
|
||||||
|
// VST_ENTRY: [valueid, namelen, namechar x N]
|
||||||
|
NameVals.push_back(VE.getValueID(SI->getValue()));
|
||||||
|
|
||||||
|
NameVals.push_back(SI->getKeyLength());
|
||||||
|
for (const char *P = SI->getKeyData(),
|
||||||
|
*E = SI->getKeyData()+SI->getKeyLength(); P != E; ++P)
|
||||||
|
NameVals.push_back((unsigned char)*P);
|
||||||
|
|
||||||
|
// Emit the finished record.
|
||||||
|
Stream.EmitRecord(bitc::VST_CODE_ENTRY, NameVals, AbbrevToUse);
|
||||||
|
NameVals.clear();
|
||||||
|
}
|
||||||
|
Stream.ExitBlock();
|
||||||
|
}
|
||||||
|
|
||||||
/// WriteFunction - Emit a function body to the module stream.
|
/// WriteFunction - Emit a function body to the module stream.
|
||||||
static void WriteFunction(const Function &F, ValueEnumerator &VE,
|
static void WriteFunction(const Function &F, ValueEnumerator &VE,
|
||||||
BitstreamWriter &Stream) {
|
BitstreamWriter &Stream) {
|
||||||
@ -709,6 +739,9 @@ static void WriteFunction(const Function &F, ValueEnumerator &VE,
|
|||||||
for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; ++I)
|
for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; ++I)
|
||||||
WriteInstruction(*I, VE, Stream, Vals);
|
WriteInstruction(*I, VE, Stream, Vals);
|
||||||
|
|
||||||
|
// Emit names for all the instructions etc.
|
||||||
|
WriteValueSymbolTable(F.getValueSymbolTable(), VE, Stream);
|
||||||
|
|
||||||
VE.purgeFunction();
|
VE.purgeFunction();
|
||||||
Stream.ExitBlock();
|
Stream.ExitBlock();
|
||||||
}
|
}
|
||||||
@ -746,36 +779,6 @@ static void WriteTypeSymbolTable(const TypeSymbolTable &TST,
|
|||||||
Stream.ExitBlock();
|
Stream.ExitBlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit names for globals/functions etc.
|
|
||||||
static void WriteValueSymbolTable(const ValueSymbolTable &VST,
|
|
||||||
const ValueEnumerator &VE,
|
|
||||||
BitstreamWriter &Stream) {
|
|
||||||
if (VST.empty()) return;
|
|
||||||
Stream.EnterSubblock(bitc::VALUE_SYMTAB_BLOCK_ID, 3);
|
|
||||||
|
|
||||||
// FIXME: Set up the abbrev, we know how many values there are!
|
|
||||||
// FIXME: We know if the type names can use 7-bit ascii.
|
|
||||||
SmallVector<unsigned, 64> NameVals;
|
|
||||||
|
|
||||||
for (ValueSymbolTable::const_iterator SI = VST.begin(), SE = VST.end();
|
|
||||||
SI != SE; ++SI) {
|
|
||||||
unsigned AbbrevToUse = 0;
|
|
||||||
|
|
||||||
// VST_ENTRY: [valueid, namelen, namechar x N]
|
|
||||||
NameVals.push_back(VE.getValueID(SI->getValue()));
|
|
||||||
|
|
||||||
NameVals.push_back(SI->getKeyLength());
|
|
||||||
for (const char *P = SI->getKeyData(),
|
|
||||||
*E = SI->getKeyData()+SI->getKeyLength(); P != E; ++P)
|
|
||||||
NameVals.push_back((unsigned char)*P);
|
|
||||||
|
|
||||||
// Emit the finished record.
|
|
||||||
Stream.EmitRecord(bitc::VST_CODE_ENTRY, NameVals, AbbrevToUse);
|
|
||||||
NameVals.clear();
|
|
||||||
}
|
|
||||||
Stream.ExitBlock();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// WriteModule - Emit the specified module to the bitstream.
|
/// WriteModule - Emit the specified module to the bitstream.
|
||||||
static void WriteModule(const Module *M, BitstreamWriter &Stream) {
|
static void WriteModule(const Module *M, BitstreamWriter &Stream) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user