summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2016-04-10 09:28:39 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2016-04-10 09:28:39 +0000
commit32761a6cee1d0dee366b885b7b9c777e67885688 (patch)
treed6bec92bebfb216f4126356e55518842c2f476a1 /Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp
parenta4e969f4965059196ca948db781e52f7cfebf19e (diff)
downloadWebKitGtk-tarball-32761a6cee1d0dee366b885b7b9c777e67885688.tar.gz
webkitgtk-2.4.11webkitgtk-2.4.11
Diffstat (limited to 'Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp')
-rw-r--r--Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp20
1 files changed, 11 insertions, 9 deletions
diff --git a/Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp b/Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp
index e2cb00048..ede8a3643 100644
--- a/Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp
+++ b/Source/JavaScriptCore/bytecode/PreciseJumpTargets.cpp
@@ -26,8 +26,6 @@
#include "config.h"
#include "PreciseJumpTargets.h"
-#include "JSCInlines.h"
-
namespace JSC {
template <size_t vectorSize>
@@ -54,7 +52,6 @@ static void getJumpTargetsForBytecodeOffset(CodeBlock* codeBlock, Interpreter* i
case op_jnlesseq:
case op_jngreater:
case op_jngreatereq:
- case op_save: // The jump of op_save is purely for calculating liveness.
out.append(bytecodeOffset + current[3].u.operand);
break;
case op_switch_imm:
@@ -74,6 +71,15 @@ static void getJumpTargetsForBytecodeOffset(CodeBlock* codeBlock, Interpreter* i
out.append(bytecodeOffset + current[2].u.operand);
break;
}
+ case op_get_pnames:
+ out.append(bytecodeOffset + current[5].u.operand);
+ break;
+ case op_next_pname:
+ out.append(bytecodeOffset + current[6].u.operand);
+ break;
+ case op_check_has_instance:
+ out.append(bytecodeOffset + current[4].u.operand);
+ break;
case op_loop_hint:
out.append(bytecodeOffset);
break;
@@ -91,12 +97,9 @@ void computePreciseJumpTargets(CodeBlock* codeBlock, Vector<unsigned, 32>& out)
if (!codeBlock->numberOfJumpTargets())
return;
- for (unsigned i = codeBlock->numberOfExceptionHandlers(); i--;) {
+ for (unsigned i = codeBlock->numberOfExceptionHandlers(); i--;)
out.append(codeBlock->exceptionHandler(i).target);
- out.append(codeBlock->exceptionHandler(i).start);
- out.append(codeBlock->exceptionHandler(i).end);
- }
-
+
Interpreter* interpreter = codeBlock->vm()->interpreter;
Instruction* instructionsBegin = codeBlock->instructions().begin();
unsigned instructionCount = codeBlock->instructions().size();
@@ -120,7 +123,6 @@ void computePreciseJumpTargets(CodeBlock* codeBlock, Vector<unsigned, 32>& out)
lastValue = value;
}
out.resize(toIndex);
- out.shrinkToFit();
}
void findJumpTargetsForBytecodeOffset(CodeBlock* codeBlock, unsigned bytecodeOffset, Vector<unsigned, 1>& out)