diff options
author | Chris Lattner <sabre@nondot.org> | 2005-05-06 20:42:57 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-05-06 20:42:57 +0000 |
commit | f2e1c1969fdb840502d2ac0f0454cc0ffcffff5b (patch) | |
tree | 34c1d299eeff6e47548a76a17479d13e0970bb36 /llvm/lib/Bytecode | |
parent | 53bdd312111fe09f2c9cfc4950b91d467b0cf436 (diff) | |
download | bcm5719-llvm-f2e1c1969fdb840502d2ac0f0454cc0ffcffff5b.tar.gz bcm5719-llvm-f2e1c1969fdb840502d2ac0f0454cc0ffcffff5b.zip |
encode function calling convs in the bytecode file. invoke and call are
still to come.
llvm-svn: 21749
Diffstat (limited to 'llvm/lib/Bytecode')
-rw-r--r-- | llvm/lib/Bytecode/Reader/Reader.cpp | 8 | ||||
-rw-r--r-- | llvm/lib/Bytecode/Writer/Writer.cpp | 9 |
2 files changed, 16 insertions, 1 deletions
diff --git a/llvm/lib/Bytecode/Reader/Reader.cpp b/llvm/lib/Bytecode/Reader/Reader.cpp index 24875e42fd1..8e46083082f 100644 --- a/llvm/lib/Bytecode/Reader/Reader.cpp +++ b/llvm/lib/Bytecode/Reader/Reader.cpp @@ -1886,6 +1886,14 @@ void BytecodeReader::ParseModuleGlobalInfo() { if ((Flags & (1 << 4)) == 0) FunctionSignatureList.push_back(Func); + // Look at the low bits. If there is a calling conv here, apply it, + // read it as a vbr. + Flags &= 15; + if (Flags) + Func->setCallingConv(Flags-1); + else + Func->setCallingConv(read_vbr_uint()); + if (Handler) Handler->handleFunctionDeclaration(Func); // Get the next function signature. diff --git a/llvm/lib/Bytecode/Writer/Writer.cpp b/llvm/lib/Bytecode/Writer/Writer.cpp index 63cb2d0c5a1..4cf4cf5a97d 100644 --- a/llvm/lib/Bytecode/Writer/Writer.cpp +++ b/llvm/lib/Bytecode/Writer/Writer.cpp @@ -923,10 +923,17 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) { assert(Slot != -1 && "Module slot calculator is broken!"); assert(Slot >= Type::FirstDerivedTyID && "Derived type not in range!"); assert(((Slot << 5) >> 5) == Slot && "Slot # too big!"); - unsigned ID = (Slot << 5) + 1; + unsigned ID = (Slot << 5); + + if (I->getCallingConv() < 15) + ID += I->getCallingConv()+1; + if (I->isExternal()) // If external, we don't have an FunctionInfo block. ID |= 1 << 4; output_vbr(ID); + + if (I->getCallingConv() >= 15) + output_vbr(I->getCallingConv()); } output_vbr((unsigned)Table.getSlot(Type::VoidTy) << 5); |