mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-03 22:01:56 +00:00
Do not emit FunctionBlock blocks for external functions. This shrinks
bytecode files by about 8 bytes per external function git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17859 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97fbc500a7
commit
d6e431f45e
@ -919,6 +919,8 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) {
|
|||||||
assert(Slot >= Type::FirstDerivedTyID && "Derived type not in range!");
|
assert(Slot >= Type::FirstDerivedTyID && "Derived type not in range!");
|
||||||
assert(((Slot << 5) >> 5) == Slot && "Slot # too big!");
|
assert(((Slot << 5) >> 5) == Slot && "Slot # too big!");
|
||||||
unsigned ID = (Slot << 5) + 1;
|
unsigned ID = (Slot << 5) + 1;
|
||||||
|
if (I->isExternal()) // If external, we don't have an FunctionInfo block.
|
||||||
|
ID |= 1 << 4;
|
||||||
output_vbr(ID);
|
output_vbr(ID);
|
||||||
}
|
}
|
||||||
output_vbr((unsigned)Table.getSlot(Type::VoidTy) << 5);
|
output_vbr((unsigned)Table.getSlot(Type::VoidTy) << 5);
|
||||||
@ -942,12 +944,12 @@ void BytecodeWriter::outputInstructions(const Function *F) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BytecodeWriter::outputFunction(const Function *F) {
|
void BytecodeWriter::outputFunction(const Function *F) {
|
||||||
BytecodeBlock FunctionBlock(BytecodeFormat::FunctionBlockID, *this);
|
|
||||||
output_vbr(getEncodedLinkage(F));
|
|
||||||
|
|
||||||
// If this is an external function, there is nothing else to emit!
|
// If this is an external function, there is nothing else to emit!
|
||||||
if (F->isExternal()) return;
|
if (F->isExternal()) return;
|
||||||
|
|
||||||
|
BytecodeBlock FunctionBlock(BytecodeFormat::FunctionBlockID, *this);
|
||||||
|
output_vbr(getEncodedLinkage(F));
|
||||||
|
|
||||||
// Get slot information about the function...
|
// Get slot information about the function...
|
||||||
Table.incorporateFunction(F);
|
Table.incorporateFunction(F);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user