| 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],
|
| ]
|
|
|
|
|