diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
commit | 32761a6cee1d0dee366b885b7b9c777e67885688 (patch) | |
tree | d6bec92bebfb216f4126356e55518842c2f476a1 /Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h | |
parent | a4e969f4965059196ca948db781e52f7cfebf19e (diff) | |
download | WebKitGtk-tarball-32761a6cee1d0dee366b885b7b9c777e67885688.tar.gz |
webkitgtk-2.4.11webkitgtk-2.4.11
Diffstat (limited to 'Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h')
-rw-r--r-- | Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h | 79 |
1 files changed, 1 insertions, 78 deletions
diff --git a/Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h b/Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h index a875e4906..5a919a29e 100644 --- a/Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h +++ b/Source/JavaScriptCore/bytecode/UnlinkedInstructionStream.h @@ -33,12 +33,10 @@ namespace JSC { class UnlinkedInstructionStream { - WTF_MAKE_FAST_ALLOCATED; public: - explicit UnlinkedInstructionStream(const Vector<UnlinkedInstruction, 0, UnsafeVectorOverflow>&); + explicit UnlinkedInstructionStream(const Vector<UnlinkedInstruction>&); unsigned count() const { return m_instructionCount; } - size_t sizeInBytes() const; class Reader { public: @@ -71,81 +69,6 @@ private: unsigned m_instructionCount; }; -// Unlinked instructions are packed in a simple stream format. -// -// The first byte is always the opcode. -// It's followed by an opcode-dependent number of argument values. -// The first 3 bits of each value determines the format: -// -// 5-bit positive integer (1 byte total) -// 5-bit negative integer (1 byte total) -// 13-bit positive integer (2 bytes total) -// 13-bit negative integer (2 bytes total) -// 5-bit constant register index, based at 0x40000000 (1 byte total) -// 13-bit constant register index, based at 0x40000000 (2 bytes total) -// 32-bit raw value (5 bytes total) - -enum PackedValueType { - Positive5Bit = 0, - Negative5Bit, - Positive13Bit, - Negative13Bit, - ConstantRegister5Bit, - ConstantRegister13Bit, - Full32Bit -}; - -ALWAYS_INLINE UnlinkedInstructionStream::Reader::Reader(const UnlinkedInstructionStream& stream) - : m_stream(stream) - , m_index(0) -{ -} - -ALWAYS_INLINE unsigned char UnlinkedInstructionStream::Reader::read8() -{ - return m_stream.m_data.data()[m_index++]; -} - -ALWAYS_INLINE unsigned UnlinkedInstructionStream::Reader::read32() -{ - const unsigned char* data = &m_stream.m_data.data()[m_index]; - unsigned char type = data[0] >> 5; - - switch (type) { - case Positive5Bit: - m_index++; - return data[0]; - case Negative5Bit: - m_index++; - return 0xffffffe0 | data[0]; - case Positive13Bit: - m_index += 2; - return ((data[0] & 0x1F) << 8) | data[1]; - case Negative13Bit: - m_index += 2; - return 0xffffe000 | ((data[0] & 0x1F) << 8) | data[1]; - case ConstantRegister5Bit: - m_index++; - return 0x40000000 | (data[0] & 0x1F); - case ConstantRegister13Bit: - m_index += 2; - return 0x40000000 | ((data[0] & 0x1F) << 8) | data[1]; - default: - ASSERT(type == Full32Bit); - m_index += 5; - return data[1] | data[2] << 8 | data[3] << 16 | data[4] << 24; - } -} - -ALWAYS_INLINE const UnlinkedInstruction* UnlinkedInstructionStream::Reader::next() -{ - m_unpackedBuffer[0].u.opcode = static_cast<OpcodeID>(read8()); - unsigned opLength = opcodeLength(m_unpackedBuffer[0].u.opcode); - for (unsigned i = 1; i < opLength; ++i) - m_unpackedBuffer[i].u.index = read32(); - return m_unpackedBuffer; -} - } // namespace JSC #endif // UnlinkedInstructionStream_h |