summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/jit/JIT.cpp
diff options
context:
space:
mode:
authorLiang Qi <liang.qi@theqtcompany.com>2015-03-18 10:34:44 +0100
committerLiang Qi <liang.qi@theqtcompany.com>2015-03-18 10:34:59 +0100
commit8b00fdada15a53c7764472435cffe04f22c3522f (patch)
tree31756dd9b97a6be3ab5ee58c70f6c34b94024e10 /Source/JavaScriptCore/jit/JIT.cpp
parent8e72001f4b51b4695065842882aa5898a7340ecd (diff)
parent1ee472207c63905ab4455e676ee3ffd3263ab2cb (diff)
downloadqtwebkit-8b00fdada15a53c7764472435cffe04f22c3522f.tar.gz
Merge remote-tracking branch 'origin/5.5' into dev
Change-Id: I0cf3a38a8cccbfdeb7942b712d3d878441601c87
Diffstat (limited to 'Source/JavaScriptCore/jit/JIT.cpp')
-rw-r--r--Source/JavaScriptCore/jit/JIT.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/Source/JavaScriptCore/jit/JIT.cpp b/Source/JavaScriptCore/jit/JIT.cpp
index 8e003c782..9b46d8792 100644
--- a/Source/JavaScriptCore/jit/JIT.cpp
+++ b/Source/JavaScriptCore/jit/JIT.cpp
@@ -74,7 +74,7 @@ JIT::JIT(VM* vm, CodeBlock* codeBlock)
: m_interpreter(vm->interpreter)
, m_vm(vm)
, m_codeBlock(codeBlock)
- , m_labels(codeBlock ? codeBlock->numberOfInstructions() : 0)
+ , m_labels(0)
, m_bytecodeOffset((unsigned)-1)
, m_propertyAccessInstructionIndex(UINT_MAX)
, m_byValInstructionIndex(UINT_MAX)
@@ -96,6 +96,7 @@ JIT::JIT(VM* vm, CodeBlock* codeBlock)
, m_shouldEmitProfiling(false)
#endif
{
+ m_labels.reserveCapacity(codeBlock ? codeBlock->numberOfInstructions() : 0);
}
#if ENABLE(DFG_JIT)
@@ -174,6 +175,7 @@ void JIT::privateCompileMainPass()
m_globalResolveInfoIndex = 0;
m_callLinkInfoIndex = 0;
+ m_labels.resize(instructionCount);
for (m_bytecodeOffset = 0; m_bytecodeOffset < instructionCount; ) {
if (m_disassembler)
@@ -694,6 +696,7 @@ JITCode JIT::privateCompile(CodePtr* functionEntryArityCheck, JITCompilationEffo
if (patchBuffer.didFailToAllocate())
return JITCode();
+ ASSERT(m_labels.size() >= m_codeBlock->instructionCount());
// Translate vPC offsets into addresses in JIT generated code, for switch tables.
for (unsigned i = 0; i < m_switches.size(); ++i) {
SwitchRecord record = m_switches[i];