| Index: test/cctest/interpreter/bytecode_expectations/ForOfLoop.golden
|
| diff --git a/test/cctest/interpreter/bytecode_expectations/ForOfLoop.golden b/test/cctest/interpreter/bytecode_expectations/ForOfLoop.golden
|
| index 8048d954584d1733d54dad03c6f426ccad64a9cd..e88a3203032909f57d7ecddc728557c767351f02 100644
|
| --- a/test/cctest/interpreter/bytecode_expectations/ForOfLoop.golden
|
| +++ b/test/cctest/interpreter/bytecode_expectations/ForOfLoop.golden
|
| @@ -641,9 +641,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 24
|
| +frame size: 21
|
| parameter count: 2
|
| -bytecode array length: 446
|
| +bytecode array length: 403
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -667,52 +667,51 @@ bytecodes: [
|
| B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(15), U8(2),
|
| B(Star), R(3),
|
| /* 11 E> */ B(StackCheck),
|
| - B(Star), R(11),
|
| - B(Mov), R(context), R(17),
|
| B(LdaZero),
|
| - B(Mov), R(3), R(19),
|
| - B(Mov), R(3), R(18),
|
| - /* 11 E> */ B(SuspendGenerator), R(18), R(0), U8(19), U8(0),
|
| - B(Ldar), R(19),
|
| + B(Mov), R(3), R(11),
|
| + B(Mov), R(3), R(16),
|
| + B(Mov), R(3), R(15),
|
| + /* 11 E> */ B(SuspendGenerator), R(15), R(0), U8(16), U8(0),
|
| + B(Ldar), R(16),
|
| /* 55 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(11), R(0), U8(19),
|
| + B(RestoreGeneratorRegisters), R(11), R(0), U8(16),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(18), U8(1),
|
| - B(Star), R(19),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(18), U8(1),
|
| - B(Star), R(20),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(15), U8(1),
|
| + B(Star), R(16),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(15), U8(1),
|
| + B(Star), R(17),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(20),
|
| - B(JumpIfTrue), U8(28),
|
| + B(TestEqualStrictNoFeedback), R(17),
|
| + B(JumpIfTrue), U8(30),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(20),
|
| - B(JumpIfTrue), U8(19),
|
| + B(TestEqualStrictNoFeedback), R(17),
|
| + B(JumpIfTrue), U8(21),
|
| B(LdaTrue),
|
| - B(Star), R(22),
|
| - B(Mov), R(19), R(21),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(21), U8(2),
|
| - B(Star), R(16),
|
| - B(LdaZero),
|
| - B(Star), R(15),
|
| - B(JumpConstant), U8(10),
|
| - B(Ldar), R(19),
|
| + B(Star), R(19),
|
| + B(Mov), R(16), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(18), U8(2),
|
| + B(Star), R(20),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(11), U8(1),
|
| + B(Ldar), R(20),
|
| + /* 55 S> */ B(Return),
|
| + B(Ldar), R(16),
|
| /* 11 E> */ B(Throw),
|
| B(LdaZero),
|
| B(Star), R(7),
|
| - B(Mov), R(context), R(20),
|
| - B(Mov), R(context), R(21),
|
| + B(Mov), R(context), R(17),
|
| + B(Mov), R(context), R(18),
|
| /* 35 S> */ B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(22),
|
| - B(LdaNamedProperty), R(22), U8(1), U8(3),
|
| - B(Star), R(23),
|
| - B(CallProperty0), R(23), R(22), U8(5),
|
| + B(Star), R(19),
|
| + B(LdaNamedProperty), R(19), U8(1), U8(3),
|
| + B(Star), R(20),
|
| + B(CallProperty0), R(20), R(19), U8(5),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(5),
|
| /* 30 S> */ B(LdaNamedProperty), R(5), U8(2), U8(9),
|
| - B(Star), R(22),
|
| - B(CallProperty0), R(22), R(5), U8(7),
|
| + B(Star), R(19),
|
| + B(CallProperty0), R(19), R(5), U8(7),
|
| B(Star), R(6),
|
| /* 30 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(6), U8(1),
|
| B(ToBooleanLogicalNot),
|
| @@ -732,29 +731,29 @@ bytecodes: [
|
| B(Star), R(7),
|
| B(JumpLoop), U8(53), I8(0),
|
| B(Jump), U8(36),
|
| - B(Star), R(22),
|
| + B(Star), R(19),
|
| B(Ldar), R(closure),
|
| - /* 50 E> */ B(CreateCatchContext), R(22), U8(5), U8(6),
|
| - B(PushContext), R(22),
|
| - B(Star), R(21),
|
| + /* 50 E> */ B(CreateCatchContext), R(19), U8(5), U8(6),
|
| + B(PushContext), R(19),
|
| + B(Star), R(18),
|
| B(LdaSmi), I8(2),
|
| B(TestEqualStrict), R(7), U8(15),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(7),
|
| B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(23),
|
| - B(CallRuntime), U16(Runtime::kReThrow), R(23), U8(1),
|
| - B(PopContext), R(22),
|
| + B(Star), R(20),
|
| + B(CallRuntime), U16(Runtime::kReThrow), R(20), U8(1),
|
| + B(PopContext), R(19),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(18),
|
| + B(Star), R(15),
|
| B(Jump), U8(7),
|
| - B(Star), R(19),
|
| + B(Star), R(16),
|
| B(LdaZero),
|
| - B(Star), R(18),
|
| + B(Star), R(15),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(20),
|
| + B(Star), R(17),
|
| B(LdaZero),
|
| B(TestEqualStrict), R(7), U8(16),
|
| B(JumpIfTrue), U8(104),
|
| @@ -771,76 +770,53 @@ bytecodes: [
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| - B(Star), R(21),
|
| + B(Star), R(18),
|
| B(LdaConstant), U8(8),
|
| - B(Star), R(22),
|
| - B(CallRuntime), U16(Runtime::kNewTypeError), R(21), U8(2),
|
| + B(Star), R(19),
|
| + B(CallRuntime), U16(Runtime::kNewTypeError), R(18), U8(2),
|
| B(Throw),
|
| - B(Mov), R(context), R(21),
|
| - B(Mov), R(9), R(22),
|
| - B(Mov), R(5), R(23),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(22), U8(2),
|
| + B(Mov), R(context), R(18),
|
| + B(Mov), R(9), R(19),
|
| + B(Mov), R(5), R(20),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(19), U8(2),
|
| B(Jump), U8(20),
|
| - B(Star), R(22),
|
| + B(Star), R(19),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(22), U8(5), U8(9),
|
| - B(Star), R(21),
|
| + B(CreateCatchContext), R(19), U8(5), U8(9),
|
| + B(Star), R(18),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(21),
|
| - B(PushContext), R(22),
|
| - B(PopContext), R(22),
|
| + B(Ldar), R(18),
|
| + B(PushContext), R(19),
|
| + B(PopContext), R(19),
|
| B(Jump), U8(27),
|
| - B(Mov), R(9), R(21),
|
| - B(Mov), R(5), R(22),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(21), U8(2),
|
| + B(Mov), R(9), R(18),
|
| + B(Mov), R(5), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(18), U8(2),
|
| B(Star), R(10),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(10), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
| B(Jump), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(10), U8(1),
|
| - B(Ldar), R(20),
|
| + B(Ldar), R(17),
|
| B(SetPendingMessage),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(18),
|
| - B(JumpIfFalse), U8(11),
|
| - B(LdaSmi), I8(1),
|
| - B(Star), R(15),
|
| - B(Mov), R(19), R(16),
|
| - B(Jump), U8(31),
|
| + B(TestEqualStrictNoFeedback), R(15),
|
| + B(JumpIfFalse), U8(5),
|
| + B(Ldar), R(16),
|
| + B(ReThrow),
|
| B(LdaUndefined),
|
| - B(Star), R(18),
|
| - B(LdaTrue),
|
| - B(Star), R(19),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(18), U8(2),
|
| - B(Star), R(16),
|
| - B(LdaZero),
|
| B(Star), R(15),
|
| - B(Jump), U8(14),
|
| - B(LdaSmi), I8(-1),
|
| - B(Star), R(15),
|
| - B(Jump), U8(8),
|
| + B(LdaTrue),
|
| B(Star), R(16),
|
| - B(LdaSmi), I8(1),
|
| - B(Star), R(15),
|
| - B(LdaTheHole),
|
| - B(SetPendingMessage),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(15), U8(2),
|
| B(Star), R(17),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(3), U8(1),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(11), U8(1),
|
| B(Ldar), R(17),
|
| - B(SetPendingMessage),
|
| - B(Ldar), R(15),
|
| - B(SwitchOnSmiNoFeedback), U8(11), U8(2), I8(0),
|
| - B(Jump), U8(8),
|
| - B(Ldar), R(16),
|
| - /* 55 S> */ B(Return),
|
| - B(Ldar), R(16),
|
| - B(ReThrow),
|
| - B(LdaUndefined),
|
| /* 55 S> */ B(Return),
|
| ]
|
| constant pool: [
|
| - Smi [58],
|
| + Smi [56],
|
| SYMBOL_TYPE,
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["done"],
|
| @@ -850,12 +826,8 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["return"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
| FIXED_ARRAY_TYPE,
|
| - Smi [298],
|
| - Smi [6],
|
| - Smi [9],
|
| ]
|
| handlers: [
|
| - [60, 407, 413],
|
| [132, 250, 256],
|
| [135, 214, 216],
|
| [316, 326, 328],
|
| @@ -868,9 +840,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 26
|
| +frame size: 22
|
| parameter count: 2
|
| -bytecode array length: 552
|
| +bytecode array length: 510
|
| bytecodes: [
|
| B(Mov), R(new_target), R(10),
|
| B(Ldar), R(new_target),
|
| @@ -894,46 +866,45 @@ bytecodes: [
|
| B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(14), U8(2),
|
| B(Star), R(2),
|
| /* 11 E> */ B(StackCheck),
|
| - B(Star), R(10),
|
| - B(Mov), R(context), R(16),
|
| B(LdaZero),
|
| - B(Mov), R(2), R(18),
|
| - B(Mov), R(2), R(17),
|
| - /* 11 E> */ B(SuspendGenerator), R(17), R(0), U8(18), U8(0),
|
| - B(Ldar), R(18),
|
| + B(Mov), R(2), R(10),
|
| + B(Mov), R(2), R(15),
|
| + B(Mov), R(2), R(14),
|
| + /* 11 E> */ B(SuspendGenerator), R(14), R(0), U8(15), U8(0),
|
| + B(Ldar), R(15),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(18),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(15),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(11),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(17), U8(1),
|
| - B(Star), R(18),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(17), U8(1),
|
| - B(Star), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(14), U8(1),
|
| + B(Star), R(15),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(14), U8(1),
|
| + B(Star), R(16),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(19),
|
| - B(JumpIfTrue), U8(28),
|
| + B(TestEqualStrictNoFeedback), R(16),
|
| + B(JumpIfTrue), U8(30),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(19),
|
| - B(JumpIfTrue), U8(19),
|
| + B(TestEqualStrictNoFeedback), R(16),
|
| + B(JumpIfTrue), U8(21),
|
| B(LdaTrue),
|
| - B(Star), R(21),
|
| - B(Mov), R(18), R(20),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(20), U8(2),
|
| - B(Star), R(15),
|
| - B(LdaZero),
|
| - B(Star), R(14),
|
| - B(JumpConstant), U8(14),
|
| - B(Ldar), R(18),
|
| + B(Star), R(18),
|
| + B(Mov), R(15), R(17),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(17), U8(2),
|
| + B(Star), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(19),
|
| + /* 49 S> */ B(Return),
|
| + B(Ldar), R(15),
|
| /* 11 E> */ B(Throw),
|
| B(LdaZero),
|
| B(Star), R(6),
|
| - B(Mov), R(context), R(19),
|
| - B(Mov), R(context), R(20),
|
| + B(Mov), R(context), R(16),
|
| + B(Mov), R(context), R(17),
|
| /* 35 S> */ B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(21),
|
| - B(LdaNamedProperty), R(21), U8(2), U8(3),
|
| - B(Star), R(22),
|
| - B(CallProperty0), R(22), R(21), U8(5),
|
| + B(Star), R(18),
|
| + B(LdaNamedProperty), R(18), U8(2), U8(3),
|
| + B(Star), R(19),
|
| + B(CallProperty0), R(19), R(18), U8(5),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(4),
|
| @@ -943,18 +914,18 @@ bytecodes: [
|
| /* 35 E> */ B(TestEqualStrictNoFeedback), R(11),
|
| B(JumpIfTrue), U8(11),
|
| B(LdaSmi), I8(79),
|
| - B(Star), R(21),
|
| - B(CallRuntime), U16(Runtime::kAbort), R(21), U8(1),
|
| + B(Star), R(18),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(18), U8(1),
|
| /* 30 S> */ B(LdaNamedProperty), R(4), U8(4), U8(9),
|
| - B(Star), R(21),
|
| - B(CallProperty0), R(21), R(4), U8(7),
|
| + B(Star), R(18),
|
| + B(CallProperty0), R(18), R(4), U8(7),
|
| B(Star), R(5),
|
| /* 30 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(5), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(5), U8(1),
|
| B(LdaNamedProperty), R(5), U8(5), U8(11),
|
| - B(JumpIfToBooleanTrue), U8(101),
|
| + B(JumpIfToBooleanTrue), U8(91),
|
| B(LdaNamedProperty), R(5), U8(6), U8(13),
|
| B(Star), R(7),
|
| B(LdaSmi), I8(2),
|
| @@ -962,66 +933,61 @@ bytecodes: [
|
| B(Mov), R(7), R(3),
|
| /* 21 E> */ B(StackCheck),
|
| B(Mov), R(3), R(0),
|
| - /* 40 S> */ B(LdaFalse),
|
| - B(Star), R(23),
|
| - B(Mov), R(3), R(22),
|
| - /* 46 E> */ B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(22), U8(2),
|
| - B(Star), R(22),
|
| - B(LdaSmi), I8(1),
|
| - B(Mov), R(2), R(21),
|
| - B(SuspendGenerator), R(21), R(0), U8(22), U8(0),
|
| - B(Ldar), R(22),
|
| + /* 40 S> */ B(LdaSmi), I8(1),
|
| + B(Mov), R(0), R(19),
|
| + B(Mov), R(2), R(18),
|
| + /* 46 E> */ B(SuspendGenerator), R(18), R(0), U8(19), U8(0),
|
| + B(LdaFalse),
|
| + B(Star), R(21),
|
| + B(Mov), R(19), R(20),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(20), U8(2),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(22),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(19),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(11),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(21), U8(1),
|
| - B(Star), R(22),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(21), U8(1),
|
| - B(Star), R(23),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(18), U8(1),
|
| + B(Star), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(18), U8(1),
|
| + B(Star), R(20),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(23),
|
| - B(JumpIfTrue), U8(28),
|
| - B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(23),
|
| + B(TestEqualStrictNoFeedback), R(20),
|
| B(JumpIfTrue), U8(19),
|
| - B(LdaTrue),
|
| - B(Star), R(25),
|
| - B(Mov), R(22), R(24),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(24), U8(2),
|
| - B(Star), R(18),
|
| + B(LdaSmi), I8(2),
|
| + B(TestEqualStrictNoFeedback), R(20),
|
| + B(JumpIfTrue), U8(10),
|
| B(LdaZero),
|
| - B(Star), R(17),
|
| + B(Star), R(14),
|
| + B(Mov), R(19), R(15),
|
| B(Jump), U8(59),
|
| - B(Ldar), R(22),
|
| + B(Ldar), R(19),
|
| /* 40 E> */ B(Throw),
|
| B(LdaZero),
|
| B(Star), R(6),
|
| - B(JumpLoop), U8(147), I8(0),
|
| + B(JumpLoop), U8(137), I8(0),
|
| B(Jump), U8(36),
|
| - B(Star), R(21),
|
| + B(Star), R(18),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(21), U8(7), U8(8),
|
| - B(PushContext), R(21),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(18), U8(7), U8(8),
|
| + B(PushContext), R(18),
|
| + B(Star), R(17),
|
| B(LdaSmi), I8(2),
|
| B(TestEqualStrict), R(6), U8(15),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(6),
|
| B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(22),
|
| - B(CallRuntime), U16(Runtime::kReThrow), R(22), U8(1),
|
| - B(PopContext), R(21),
|
| + B(Star), R(19),
|
| + B(CallRuntime), U16(Runtime::kReThrow), R(19), U8(1),
|
| + B(PopContext), R(18),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(17),
|
| + B(Star), R(14),
|
| B(Jump), U8(8),
|
| - B(Star), R(18),
|
| + B(Star), R(15),
|
| B(LdaSmi), I8(1),
|
| - B(Star), R(17),
|
| + B(Star), R(14),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(19),
|
| + B(Star), R(16),
|
| B(LdaZero),
|
| B(TestEqualStrict), R(6), U8(16),
|
| B(JumpIfTrue), U8(104),
|
| @@ -1038,83 +1004,64 @@ bytecodes: [
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| - B(Star), R(20),
|
| + B(Star), R(17),
|
| B(LdaConstant), U8(10),
|
| - B(Star), R(21),
|
| - B(CallRuntime), U16(Runtime::kNewTypeError), R(20), U8(2),
|
| + B(Star), R(18),
|
| + B(CallRuntime), U16(Runtime::kNewTypeError), R(17), U8(2),
|
| B(Throw),
|
| - B(Mov), R(context), R(20),
|
| - B(Mov), R(8), R(21),
|
| - B(Mov), R(4), R(22),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(21), U8(2),
|
| + B(Mov), R(context), R(17),
|
| + B(Mov), R(8), R(18),
|
| + B(Mov), R(4), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(18), U8(2),
|
| B(Jump), U8(20),
|
| - B(Star), R(21),
|
| + B(Star), R(18),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(21), U8(7), U8(11),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(18), U8(7), U8(11),
|
| + B(Star), R(17),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(20),
|
| - B(PushContext), R(21),
|
| - B(PopContext), R(21),
|
| + B(Ldar), R(17),
|
| + B(PushContext), R(18),
|
| + B(PopContext), R(18),
|
| B(Jump), U8(27),
|
| - B(Mov), R(8), R(20),
|
| - B(Mov), R(4), R(21),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(20), U8(2),
|
| + B(Mov), R(8), R(17),
|
| + B(Mov), R(4), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(17), U8(2),
|
| B(Star), R(9),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(9), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
| B(Jump), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(9), U8(1),
|
| - B(Ldar), R(19),
|
| + B(Ldar), R(16),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(17),
|
| + B(Ldar), R(14),
|
| B(SwitchOnSmiNoFeedback), U8(12), U8(2), I8(0),
|
| - B(Jump), U8(19),
|
| - B(LdaZero),
|
| - B(Star), R(14),
|
| - B(Mov), R(18), R(15),
|
| - B(Jump), U8(40),
|
| - B(LdaSmi), I8(1),
|
| - B(Star), R(14),
|
| - B(Mov), R(18), R(15),
|
| - B(Jump), U8(31),
|
| - B(LdaUndefined),
|
| - B(Star), R(17),
|
| + B(Jump), U8(24),
|
| B(LdaTrue),
|
| B(Star), R(18),
|
| + B(Mov), R(15), R(17),
|
| B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(17), U8(2),
|
| - B(Star), R(15),
|
| - B(LdaZero),
|
| - B(Star), R(14),
|
| - B(Jump), U8(14),
|
| - B(LdaSmi), I8(-1),
|
| - B(Star), R(14),
|
| - B(Jump), U8(8),
|
| - B(Star), R(15),
|
| - B(LdaSmi), I8(1),
|
| - B(Star), R(14),
|
| - B(LdaTheHole),
|
| - B(SetPendingMessage),
|
| - B(Star), R(16),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(2), U8(1),
|
| - B(Ldar), R(16),
|
| - B(SetPendingMessage),
|
| - B(Ldar), R(14),
|
| - B(SwitchOnSmiNoFeedback), U8(15), U8(2), I8(0),
|
| - B(Jump), U8(8),
|
| - B(Ldar), R(15),
|
| + B(Star), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(19),
|
| /* 49 S> */ B(Return),
|
| B(Ldar), R(15),
|
| B(ReThrow),
|
| B(LdaUndefined),
|
| + B(Star), R(14),
|
| + B(LdaTrue),
|
| + B(Star), R(15),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(14), U8(2),
|
| + B(Star), R(16),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(16),
|
| /* 49 S> */ B(Return),
|
| ]
|
| constant pool: [
|
| - Smi [58],
|
| + Smi [56],
|
| Smi [141],
|
| SYMBOL_TYPE,
|
| - Smi [91],
|
| + Smi [90],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["done"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["value"],
|
| @@ -1124,16 +1071,12 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
| FIXED_ARRAY_TYPE,
|
| Smi [6],
|
| - Smi [14],
|
| - Smi [404],
|
| - Smi [6],
|
| - Smi [9],
|
| + Smi [25],
|
| ]
|
| handlers: [
|
| - [60, 513, 519],
|
| - [132, 344, 350],
|
| - [135, 308, 310],
|
| - [411, 421, 423],
|
| + [132, 334, 340],
|
| + [135, 298, 300],
|
| + [401, 411, 413],
|
| ]
|
|
|
| ---
|
| @@ -1357,7 +1300,7 @@ snippet: "
|
| "
|
| frame size: 28
|
| parameter count: 2
|
| -bytecode array length: 558
|
| +bytecode array length: 549
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -1417,7 +1360,7 @@ bytecodes: [
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(6), U8(1),
|
| B(LdaNamedProperty), R(6), U8(4), U8(11),
|
| - B(JumpIfToBooleanTrue), U8(107),
|
| + B(JumpIfToBooleanTrue), U8(98),
|
| B(LdaNamedProperty), R(6), U8(5), U8(13),
|
| B(Star), R(8),
|
| B(LdaSmi), I8(2),
|
| @@ -1446,23 +1389,19 @@ bytecodes: [
|
| B(Star), R(25),
|
| B(LdaZero),
|
| B(TestEqualStrictNoFeedback), R(25),
|
| - B(JumpIfTrue), U8(28),
|
| + B(JumpIfTrue), U8(19),
|
| B(LdaSmi), I8(2),
|
| B(TestEqualStrictNoFeedback), R(25),
|
| - B(JumpIfTrue), U8(19),
|
| - B(LdaTrue),
|
| - B(Star), R(27),
|
| - B(Mov), R(24), R(26),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(26), U8(2),
|
| - B(Star), R(20),
|
| + B(JumpIfTrue), U8(10),
|
| B(LdaZero),
|
| B(Star), R(19),
|
| + B(Mov), R(24), R(20),
|
| B(Jump), U8(63),
|
| B(Ldar), R(24),
|
| /* 45 E> */ B(ReThrow),
|
| B(LdaZero),
|
| B(Star), R(7),
|
| - B(JumpLoop), U8(153), I8(0),
|
| + B(JumpLoop), U8(144), I8(0),
|
| B(Jump), U8(40),
|
| B(Star), R(23),
|
| B(Ldar), R(closure),
|
| @@ -1621,10 +1560,10 @@ constant pool: [
|
| Smi [9],
|
| ]
|
| handlers: [
|
| - [70, 513, 519],
|
| - [73, 468, 470],
|
| - [79, 301, 307],
|
| - [82, 261, 263],
|
| - [368, 378, 380],
|
| + [70, 504, 510],
|
| + [73, 459, 461],
|
| + [79, 292, 298],
|
| + [82, 252, 254],
|
| + [359, 369, 371],
|
| ]
|
|
|
|
|