Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1722)

Unified Diff: test/cctest/interpreter/bytecode_expectations/Generators.golden

Issue 1901713003: [generators] Perform state dispatch in loop header. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Address comments Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/interpreter/control-flow-builders.cc ('k') | test/mjsunit/harmony/generators.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/cctest/interpreter/bytecode_expectations/Generators.golden
diff --git a/test/cctest/interpreter/bytecode_expectations/Generators.golden b/test/cctest/interpreter/bytecode_expectations/Generators.golden
index 25babc32a3dc352658e86cb2daf8f8e96d73c026..eb9cedcc796de015db84fe4270d6ce267730986d 100644
--- a/test/cctest/interpreter/bytecode_expectations/Generators.golden
+++ b/test/cctest/interpreter/bytecode_expectations/Generators.golden
@@ -13,9 +13,9 @@ ignition generators: yes
snippet: "
function* f() { }
"
-frame size: 10
+frame size: 11
parameter count: 1
-bytecode array length: 193
+bytecode array length: 197
bytecodes: [
B(Ldar), R(new_target),
B(JumpIfUndefined), U8(12),
@@ -30,78 +30,80 @@ bytecodes: [
B(Ldar), R(this),
B(StaContextSlot), R(context), U8(4),
B(StackCheck),
- B(Mov), R(context), R(3),
+ B(Mov), R(context), R(4),
B(Ldar), R(closure),
- B(Star), R(4),
- B(LdaContextSlot), R(context), U8(4),
B(Star), R(5),
- B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(4), U8(2),
+ B(LdaContextSlot), R(context), U8(4),
+ B(Star), R(6),
+ B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2),
B(StaContextSlot), R(context), U8(5),
- B(Star), R(4),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(5),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(6),
B(LdaZero),
- B(SuspendGenerator), R(5),
- B(Ldar), R(4),
+ B(SuspendGenerator), R(6),
+ B(Ldar), R(5),
B(Return),
- B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(5), U8(1),
- B(Star), R(6),
- B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(5), U8(1),
+ B(LdaSmi), U8(-2),
+ B(Star), R(1),
+ B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(6), U8(1),
B(Star), R(7),
+ B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(6), U8(1),
+ B(Star), R(8),
B(LdaZero),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(31),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(22),
B(Jump), U8(2),
- B(Mov), R(6), R(8),
+ B(Mov), R(7), R(9),
B(LdaTrue),
- B(Star), R(9),
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2),
- B(Star), R(2),
+ B(Star), R(10),
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2),
+ B(Star), R(3),
B(LdaZero),
- B(Star), R(1),
+ B(Star), R(2),
B(Jump), U8(38),
- B(Ldar), R(6),
+ B(Ldar), R(7),
B(Throw),
- B(Ldar), R(6),
+ B(Ldar), R(7),
B(LdaUndefined),
- B(Star), R(4),
- B(LdaTrue),
B(Star), R(5),
- B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(4), U8(2),
- B(Star), R(2),
+ B(LdaTrue),
+ B(Star), R(6),
+ B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2),
+ B(Star), R(3),
B(LdaSmi), U8(1),
- B(Star), R(1),
+ B(Star), R(2),
B(Jump), U8(14),
B(LdaSmi), U8(-1),
- B(Star), R(1),
- B(Jump), U8(8),
B(Star), R(2),
+ B(Jump), U8(8),
+ B(Star), R(3),
B(LdaSmi), U8(2),
- B(Star), R(1),
+ B(Star), R(2),
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0),
- B(Star), R(3),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(4),
- B(CallRuntime), U16(Runtime::kGeneratorClose), R(4), U8(1),
- B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(3), U8(1),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(5),
+ B(CallRuntime), U16(Runtime::kGeneratorClose), R(5), U8(1),
+ B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1),
B(LdaZero),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(16),
B(LdaSmi), U8(1),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(13),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(10),
B(Jump), U8(11),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(Return),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(Return),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(ReThrow),
B(LdaUndefined),
B(Return),
@@ -109,16 +111,16 @@ bytecodes: [
constant pool: [
]
handlers: [
- [30, 129, 135],
+ [30, 133, 139],
]
---
snippet: "
function* f() { yield 42 }
"
-frame size: 10
+frame size: 11
parameter count: 1
-bytecode array length: 285
+bytecode array length: 293
bytecodes: [
B(Ldar), R(new_target),
B(JumpIfUndefined), U8(18),
@@ -129,141 +131,146 @@ bytecodes: [
B(JumpIfTrue), U8(55),
B(LdaSmi), U8(1),
B(TestEqualStrict), R(1),
- B(JumpIfTrue), U8(125),
+ B(JumpIfTrueConstant), U8(0),
B(Illegal),
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1),
B(PushContext), R(0),
B(Ldar), R(this),
B(StaContextSlot), R(context), U8(4),
B(StackCheck),
- B(Mov), R(context), R(3),
+ B(Mov), R(context), R(4),
B(Ldar), R(closure),
- B(Star), R(4),
- B(LdaContextSlot), R(context), U8(4),
B(Star), R(5),
- B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(4), U8(2),
+ B(LdaContextSlot), R(context), U8(4),
+ B(Star), R(6),
+ B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2),
B(StaContextSlot), R(context), U8(5),
- B(Star), R(4),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(5),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(6),
B(LdaZero),
- B(SuspendGenerator), R(5),
- B(Ldar), R(4),
+ B(SuspendGenerator), R(6),
+ B(Ldar), R(5),
B(Return),
- B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(5), U8(1),
- B(Star), R(6),
- B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(5), U8(1),
+ B(LdaSmi), U8(-2),
+ B(Star), R(1),
+ B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(6), U8(1),
B(Star), R(7),
+ B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(6), U8(1),
+ B(Star), R(8),
B(LdaZero),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(31),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(22),
B(Jump), U8(2),
- B(Mov), R(6), R(8),
+ B(Mov), R(7), R(9),
B(LdaTrue),
- B(Star), R(9),
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2),
- B(Star), R(2),
+ B(Star), R(10),
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2),
+ B(Star), R(3),
B(LdaZero),
- B(Star), R(1),
- B(Jump), U8(115),
- B(Ldar), R(6),
+ B(Star), R(2),
+ B(Jump), U8(119),
+ B(Ldar), R(7),
B(Throw),
- B(Ldar), R(6),
+ B(Ldar), R(7),
B(LdaSmi), U8(42),
- B(Star), R(4),
- B(LdaFalse),
B(Star), R(5),
- B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(4), U8(2),
+ B(LdaFalse),
B(Star), R(6),
+ B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2),
+ B(Star), R(7),
B(LdaContextSlot), R(context), U8(5),
- B(Star), R(4),
+ B(Star), R(5),
B(LdaSmi), U8(1),
- B(SuspendGenerator), R(4),
- B(Ldar), R(6),
+ B(SuspendGenerator), R(5),
+ B(Ldar), R(7),
B(Return),
- B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(4), U8(1),
- B(Star), R(5),
- B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(4), U8(1),
- B(Star), R(7),
+ B(LdaSmi), U8(-2),
+ B(Star), R(1),
+ B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(5), U8(1),
+ B(Star), R(6),
+ B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(5), U8(1),
+ B(Star), R(8),
B(LdaZero),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(32),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(7),
+ B(TestEqualStrict), R(8),
B(JumpIfTrue), U8(23),
B(Jump), U8(2),
- B(Mov), R(5), R(8),
+ B(Mov), R(6), R(9),
B(LdaTrue),
- B(Star), R(9),
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2),
- B(Star), R(2),
+ B(Star), R(10),
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2),
+ B(Star), R(3),
B(LdaSmi), U8(1),
- B(Star), R(1),
+ B(Star), R(2),
B(Jump), U8(38),
- B(Ldar), R(5),
+ B(Ldar), R(6),
B(Throw),
- B(Ldar), R(5),
+ B(Ldar), R(6),
B(LdaUndefined),
- B(Star), R(4),
- B(LdaTrue),
B(Star), R(5),
- B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(4), U8(2),
- B(Star), R(2),
+ B(LdaTrue),
+ B(Star), R(6),
+ B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2),
+ B(Star), R(3),
B(LdaSmi), U8(2),
- B(Star), R(1),
+ B(Star), R(2),
B(Jump), U8(14),
B(LdaSmi), U8(-1),
- B(Star), R(1),
- B(Jump), U8(8),
B(Star), R(2),
+ B(Jump), U8(8),
+ B(Star), R(3),
B(LdaSmi), U8(3),
- B(Star), R(1),
+ B(Star), R(2),
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0),
- B(Star), R(3),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(4),
- B(CallRuntime), U16(Runtime::kGeneratorClose), R(4), U8(1),
- B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(3), U8(1),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(5),
+ B(CallRuntime), U16(Runtime::kGeneratorClose), R(5), U8(1),
+ B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1),
B(LdaZero),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(22),
B(LdaSmi), U8(1),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(19),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(16),
B(LdaSmi), U8(3),
- B(TestEqualStrict), R(1),
+ B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(13),
B(Jump), U8(14),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(Return),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(Return),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(Return),
- B(Ldar), R(2),
+ B(Ldar), R(3),
B(ReThrow),
B(LdaUndefined),
B(Return),
]
constant pool: [
+ kInstanceTypeDontCare,
]
handlers: [
- [36, 212, 218],
+ [36, 220, 226],
]
---
snippet: "
function* f() { for (let x of [42]) yield x }
"
-frame size: 16
+frame size: 17
parameter count: 1
-bytecode array length: 773
+bytecode array length: 794
bytecodes: [
B(Ldar), R(new_target),
B(JumpIfUndefined), U8(18),
@@ -274,54 +281,56 @@ bytecodes: [
B(JumpIfTrue), U8(55),
B(LdaSmi), U8(1),
B(TestEqualStrict), R(3),
- B(JumpIfTrueConstant), U8(8),
+ B(JumpIfTrueConstant), U8(3),
B(Illegal),
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1),
B(PushContext), R(0),
B(Ldar), R(this),
B(StaContextSlot), R(context), U8(4),
B(StackCheck),
- B(Mov), R(context), R(5),
+ B(Mov), R(context), R(6),
B(Ldar), R(closure),
- B(Star), R(6),
- B(LdaContextSlot), R(context), U8(4),
B(Star), R(7),
- B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(6), U8(2),
+ B(LdaContextSlot), R(context), U8(4),
+ B(Star), R(8),
+ B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(7), U8(2),
B(StaContextSlot), R(context), U8(5),
- B(Star), R(6),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(7),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(8),
B(LdaZero),
- B(SuspendGenerator), R(7),
- B(Ldar), R(6),
+ B(SuspendGenerator), R(8),
+ B(Ldar), R(7),
B(Return),
- B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(7), U8(1),
- B(Star), R(8),
- B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(7), U8(1),
+ B(LdaSmi), U8(-2),
+ B(Star), R(3),
+ B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(8), U8(1),
B(Star), R(9),
+ B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(8), U8(1),
+ B(Star), R(10),
B(LdaZero),
- B(TestEqualStrict), R(9),
+ B(TestEqualStrict), R(10),
B(JumpIfTrue), U8(31),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(9),
+ B(TestEqualStrict), R(10),
B(JumpIfTrue), U8(22),
B(Jump), U8(2),
- B(Mov), R(8), R(10),
+ B(Mov), R(9), R(11),
B(LdaTrue),
- B(Star), R(11),
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(10), U8(2),
- B(Star), R(4),
+ B(Star), R(12),
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(11), U8(2),
+ B(Star), R(5),
B(LdaZero),
- B(Star), R(3),
- B(JumpConstant), U8(16),
- B(Ldar), R(8),
+ B(Star), R(4),
+ B(JumpConstant), U8(17),
+ B(Ldar), R(9),
B(Throw),
- B(Ldar), R(8),
+ B(Ldar), R(9),
B(LdaConstant), U8(0),
- B(Star), R(6),
- B(Ldar), R(closure),
B(Star), R(7),
- B(CallRuntime), U16(Runtime::kPushBlockContext), R(6), U8(2),
+ B(Ldar), R(closure),
+ B(Star), R(8),
+ B(CallRuntime), U16(Runtime::kPushBlockContext), R(7), U8(2),
B(PushContext), R(1),
B(LdaTheHole),
B(StaContextSlot), R(context), U8(4),
@@ -329,45 +338,52 @@ bytecodes: [
B(StaContextSlot), R(1), U8(10),
B(LdaZero),
B(StaContextSlot), R(1), U8(9),
- B(Mov), R(context), R(8),
B(Mov), R(context), R(9),
+ B(Mov), R(context), R(10),
B(CreateArrayLiteral), U8(1), U8(0), U8(3),
- B(Star), R(11),
+ B(Star), R(12),
B(LdaConstant), U8(2),
- B(KeyedLoadIC), R(11), U8(3),
- B(Star), R(10),
- B(Call), R(10), R(11), U8(1), U8(1),
+ B(KeyedLoadIC), R(12), U8(3),
+ B(Star), R(11),
+ B(Call), R(11), R(12), U8(1), U8(1),
B(StaContextSlot), R(1), U8(7),
+ B(LdaSmi), U8(-2),
+ B(TestEqual), R(3),
+ B(JumpIfTrue), U8(9),
+ B(LdaSmi), U8(1),
+ B(TestEqualStrict), R(3),
+ B(JumpIfTrueConstant), U8(9),
+ B(Illegal),
B(LdaContextSlot), R(1), U8(7),
+ B(Star), R(13),
+ B(LoadIC), R(13), U8(4), U8(7),
B(Star), R(12),
- B(LoadIC), R(12), U8(3), U8(7),
- B(Star), R(11),
- B(Call), R(11), R(12), U8(1), U8(5),
+ B(Call), R(12), R(13), U8(1), U8(5),
B(StaContextSlot), R(1), U8(8),
- B(Star), R(10),
- B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(10), U8(1),
+ B(Star), R(11),
+ B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(11), U8(1),
B(LogicalNot),
B(JumpIfFalse), U8(12),
B(LdaContextSlot), R(1), U8(8),
- B(Star), R(10),
- B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(10), U8(1),
+ B(Star), R(11),
+ B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(11), U8(1),
B(LdaContextSlot), R(1), U8(8),
- B(Star), R(10),
- B(LoadIC), R(10), U8(4), U8(9),
- B(JumpIfToBooleanTrueConstant), U8(9),
+ B(Star), R(11),
+ B(LoadIC), R(11), U8(5), U8(9),
+ B(JumpIfToBooleanTrueConstant), U8(10),
B(LdaSmi), U8(2),
B(StaContextSlot), R(1), U8(9),
B(LdaContextSlot), R(1), U8(8),
- B(Star), R(10),
- B(LoadIC), R(10), U8(5), U8(11),
+ B(Star), R(11),
+ B(LoadIC), R(11), U8(6), U8(11),
B(StaContextSlot), R(1), U8(6),
B(LdaContextSlot), R(1), U8(10),
B(StackCheck),
- B(LdaConstant), U8(6),
- B(Star), R(10),
- B(Ldar), R(closure),
+ B(LdaConstant), U8(7),
B(Star), R(11),
- B(CallRuntime), U16(Runtime::kPushBlockContext), R(10), U8(2),
+ B(Ldar), R(closure),
+ B(Star), R(12),
+ B(CallRuntime), U16(Runtime::kPushBlockContext), R(11), U8(2),
B(PushContext), R(2),
B(LdaTheHole),
B(StaContextSlot), R(context), U8(4),
@@ -375,35 +391,37 @@ bytecodes: [
B(StaContextSlot), R(context), U8(4),
B(LdaContextSlot), R(context), U8(4),
B(JumpIfNotHole), U8(11),
- B(LdaConstant), U8(7),
+ B(LdaConstant), U8(8),
+ B(Star), R(12),
+ B(CallRuntime), U16(Runtime::kThrowReferenceError), R(12), U8(1),
B(Star), R(11),
- B(CallRuntime), U16(Runtime::kThrowReferenceError), R(11), U8(1),
- B(Star), R(10),
B(LdaFalse),
- B(Star), R(11),
- B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(10), U8(2),
B(Star), R(12),
+ B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(11), U8(2),
+ B(Star), R(13),
B(LdaContextSlot), R(1), U8(5),
- B(Star), R(10),
+ B(Star), R(11),
B(LdaSmi), U8(1),
- B(SuspendGenerator), R(10),
- B(Ldar), R(12),
+ B(SuspendGenerator), R(11),
+ B(Ldar), R(13),
B(Return),
- B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(10), U8(1),
- B(Star), R(11),
- B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(10), U8(1),
- B(Star), R(13),
+ B(LdaSmi), U8(-2),
+ B(Star), R(3),
+ B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(11), U8(1),
+ B(Star), R(12),
+ B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(11), U8(1),
+ B(Star), R(14),
B(LdaZero),
- B(TestEqualStrict), R(13),
+ B(TestEqualStrict), R(14),
B(JumpIfTrue), U8(45),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(13),
+ B(TestEqualStrict), R(14),
B(JumpIfTrue), U8(36),
B(Jump), U8(2),
- B(Mov), R(11), R(14),
+ B(Mov), R(12), R(15),
B(LdaTrue),
- B(Star), R(15),
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(14), U8(2),
+ B(Star), R(16),
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(15), U8(2),
B(PopContext), R(2),
B(PopContext), R(2),
B(PopContext), R(2),
@@ -411,186 +429,186 @@ bytecodes: [
B(PopContext), R(2),
B(PopContext), R(2),
B(PopContext), R(2),
- B(Star), R(7),
+ B(Star), R(8),
B(LdaZero),
- B(Star), R(6),
+ B(Star), R(7),
B(Jump), U8(78),
- B(Ldar), R(11),
+ B(Ldar), R(12),
B(Throw),
- B(Ldar), R(11),
+ B(Ldar), R(12),
B(PopContext), R(2),
B(LdaZero),
B(StaContextSlot), R(1), U8(9),
- B(Wide), B(Jump), U16(-205),
+ B(Wide), B(Jump), U16(-222),
B(Jump), U8(49),
+ B(Star), R(12),
+ B(LdaConstant), U8(11),
B(Star), R(11),
- B(LdaConstant), U8(10),
- B(Star), R(10),
B(Ldar), R(closure),
- B(Star), R(12),
- B(CallRuntime), U16(Runtime::kPushCatchContext), R(10), U8(3),
- B(Star), R(9),
+ B(Star), R(13),
+ B(CallRuntime), U16(Runtime::kPushCatchContext), R(11), U8(3),
+ B(Star), R(10),
B(PushContext), R(2),
B(LdaContextSlot), R(1), U8(9),
- B(Star), R(10),
+ B(Star), R(11),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(10),
+ B(TestEqualStrict), R(11),
B(JumpIfFalse), U8(7),
B(LdaSmi), U8(1),
B(StaContextSlot), R(1), U8(9),
B(LdaContextSlot), R(context), U8(4),
- B(Star), R(10),
- B(CallRuntime), U16(Runtime::kReThrow), R(10), U8(1),
+ B(Star), R(11),
+ B(CallRuntime), U16(Runtime::kReThrow), R(11), U8(1),
B(PopContext), R(2),
B(LdaSmi), U8(-1),
- B(Star), R(6),
- B(Jump), U8(8),
B(Star), R(7),
+ B(Jump), U8(8),
+ B(Star), R(8),
B(LdaSmi), U8(1),
- B(Star), R(6),
+ B(Star), R(7),
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0),
- B(Star), R(8),
- B(LdaContextSlot), R(1), U8(9),
B(Star), R(9),
+ B(LdaContextSlot), R(1), U8(9),
+ B(Star), R(10),
B(LdaZero),
- B(TestEqualStrict), R(9),
+ B(TestEqualStrict), R(10),
B(JumpIfTrue), U8(10),
B(LdaContextSlot), R(1), U8(7),
- B(Star), R(9),
+ B(Star), R(10),
B(LdaUndefined),
- B(TestEqualStrict), R(9),
+ B(TestEqualStrict), R(10),
B(LogicalNot),
- B(JumpIfFalseConstant), U8(15),
+ B(JumpIfFalseConstant), U8(16),
B(LdaContextSlot), R(1), U8(7),
- B(Star), R(9),
- B(LoadIC), R(9), U8(11), U8(13),
+ B(Star), R(10),
+ B(LoadIC), R(10), U8(12), U8(13),
B(StaContextSlot), R(1), U8(11),
B(LdaContextSlot), R(1), U8(11),
- B(Star), R(9),
+ B(Star), R(10),
B(LdaNull),
- B(TestEqual), R(9),
+ B(TestEqual), R(10),
B(JumpIfFalse), U8(4),
- B(JumpConstant), U8(14),
+ B(JumpConstant), U8(15),
B(LdaContextSlot), R(1), U8(9),
- B(Star), R(9),
+ B(Star), R(10),
B(LdaSmi), U8(1),
- B(TestEqualStrict), R(9),
+ B(TestEqualStrict), R(10),
B(JumpIfFalse), U8(82),
B(LdaContextSlot), R(1), U8(11),
B(TypeOf),
- B(Star), R(9),
- B(LdaConstant), U8(12),
- B(TestEqualStrict), R(9),
+ B(Star), R(10),
+ B(LdaConstant), U8(13),
+ B(TestEqualStrict), R(10),
B(JumpIfFalse), U8(4),
B(Jump), U8(18),
B(Wide), B(LdaSmi), U16(129),
- B(Star), R(9),
- B(LdaConstant), U8(13),
B(Star), R(10),
- B(CallRuntime), U16(Runtime::kNewTypeError), R(9), U8(2),
+ B(LdaConstant), U8(14),
+ B(Star), R(11),
+ B(CallRuntime), U16(Runtime::kNewTypeError), R(10), U8(2),
B(Throw),
- B(Mov), R(context), R(9),
+ B(Mov), R(context), R(10),
B(LdaContextSlot), R(1), U8(11),
- B(Star), R(10),
- B(LdaContextSlot), R(1), U8(7),
B(Star), R(11),
- B(CallRuntime), U16(Runtime::k_Call), R(10), U8(2),
+ B(LdaContextSlot), R(1), U8(7),
+ B(Star), R(12),
+ B(CallRuntime), U16(Runtime::k_Call), R(11), U8(2),
B(Jump), U8(30),
+ B(Star), R(12),
+ B(LdaConstant), U8(11),
B(Star), R(11),
- B(LdaConstant), U8(10),
- B(Star), R(10),
B(Ldar), R(closure),
- B(Star), R(12),
- B(CallRuntime), U16(Runtime::kPushCatchContext), R(10), U8(3),
- B(Star), R(9),
+ B(Star), R(13),
+ B(CallRuntime), U16(Runtime::kPushCatchContext), R(11), U8(3),
+ B(Star), R(10),
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0),
- B(Ldar), R(9),
+ B(Ldar), R(10),
B(PushContext), R(2),
B(PopContext), R(2),
B(Jump), U8(44),
B(LdaContextSlot), R(1), U8(11),
- B(Star), R(9),
- B(LdaContextSlot), R(1), U8(7),
B(Star), R(10),
- B(CallRuntime), U16(Runtime::k_Call), R(9), U8(2),
+ B(LdaContextSlot), R(1), U8(7),
+ B(Star), R(11),
+ B(CallRuntime), U16(Runtime::k_Call), R(10), U8(2),
B(StaContextSlot), R(1), U8(12),
B(LdaContextSlot), R(1), U8(12),
- B(Star), R(9),
- B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(9), U8(1),
+ B(Star), R(10),
+ B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(10), U8(1),
B(JumpIfToBooleanFalse), U8(4),
B(Jump), U8(12),
B(LdaContextSlot), R(1), U8(12),
- B(Star), R(9),
- B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(9), U8(1),
- B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(8), U8(1),
+ B(Star), R(10),
+ B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(10), U8(1),
+ B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(9), U8(1),
B(LdaZero),
- B(TestEqualStrict), R(6),
+ B(TestEqualStrict), R(7),
B(JumpIfTrue), U8(10),
B(LdaSmi), U8(1),
- B(TestEqualStrict), R(6),
+ B(TestEqualStrict), R(7),
B(JumpIfTrue), U8(18),
B(Jump), U8(30),
- B(Ldar), R(7),
+ B(Ldar), R(8),
B(PopContext), R(1),
B(PopContext), R(1),
- B(Star), R(4),
+ B(Star), R(5),
B(LdaSmi), U8(1),
- B(Star), R(3),
+ B(Star), R(4),
B(Jump), U8(49),
- B(Ldar), R(7),
+ B(Ldar), R(8),
B(PopContext), R(1),
B(PopContext), R(1),
- B(Star), R(4),
+ B(Star), R(5),
B(LdaSmi), U8(2),
- B(Star), R(3),
+ B(Star), R(4),
B(Jump), U8(35),
B(PopContext), R(1),
B(LdaUndefined),
- B(Star), R(6),
- B(LdaTrue),
B(Star), R(7),
- B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(6), U8(2),
- B(Star), R(4),
+ B(LdaTrue),
+ B(Star), R(8),
+ B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(7), U8(2),
+ B(Star), R(5),
B(LdaSmi), U8(3),
- B(Star), R(3),
+ B(Star), R(4),
B(Jump), U8(14),
B(LdaSmi), U8(-1),
- B(Star), R(3),
- B(Jump), U8(8),
B(Star), R(4),
+ B(Jump), U8(8),
+ B(Star), R(5),
B(LdaSmi), U8(4),
- B(Star), R(3),
+ B(Star), R(4),
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0),
- B(Star), R(5),
- B(LdaContextSlot), R(context), U8(5),
B(Star), R(6),
- B(CallRuntime), U16(Runtime::kGeneratorClose), R(6), U8(1),
- B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(5), U8(1),
+ B(LdaContextSlot), R(context), U8(5),
+ B(Star), R(7),
+ B(CallRuntime), U16(Runtime::kGeneratorClose), R(7), U8(1),
+ B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(6), U8(1),
B(LdaZero),
- B(TestEqualStrict), R(3),
+ B(TestEqualStrict), R(4),
B(JumpIfTrue), U8(28),
B(LdaSmi), U8(1),
- B(TestEqualStrict), R(3),
+ B(TestEqualStrict), R(4),
B(JumpIfTrue), U8(25),
B(LdaSmi), U8(2),
- B(TestEqualStrict), R(3),
+ B(TestEqualStrict), R(4),
B(JumpIfTrue), U8(22),
B(LdaSmi), U8(3),
- B(TestEqualStrict), R(3),
+ B(TestEqualStrict), R(4),
B(JumpIfTrue), U8(19),
B(LdaSmi), U8(4),
- B(TestEqualStrict), R(3),
+ B(TestEqualStrict), R(4),
B(JumpIfTrue), U8(16),
B(Jump), U8(17),
- B(Ldar), R(4),
+ B(Ldar), R(5),
B(Return),
- B(Ldar), R(4),
+ B(Ldar), R(5),
B(Return),
- B(Ldar), R(4),
+ B(Ldar), R(5),
B(ReThrow),
- B(Ldar), R(4),
+ B(Ldar), R(5),
B(Return),
- B(Ldar), R(4),
+ B(Ldar), R(5),
B(ReThrow),
B(LdaUndefined),
B(Return),
@@ -599,6 +617,7 @@ constant pool: [
InstanceType::FIXED_ARRAY_TYPE,
InstanceType::FIXED_ARRAY_TYPE,
InstanceType::SYMBOL_TYPE,
+ kInstanceTypeDontCare,
InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE,
InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE,
InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE,
@@ -615,9 +634,9 @@ constant pool: [
kInstanceTypeDontCare,
]
handlers: [
- [36, 691, 697],
- [146, 427, 433],
- [149, 378, 380],
- [535, 550, 552],
+ [36, 712, 718],
+ [150, 448, 454],
+ [153, 399, 401],
+ [556, 571, 573],
]
« no previous file with comments | « src/interpreter/control-flow-builders.cc ('k') | test/mjsunit/harmony/generators.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698