| 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 dd5d073fdb3a819ea8626b313ac97fd517680389..6f553f2693e0597bfcad4061f5fc1ea20064d338 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: 20
|
| parameter count: 2
|
| -bytecode array length: 434
|
| +bytecode array length: 370
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -654,58 +654,52 @@ bytecodes: [
|
| B(Star), R(12),
|
| B(SwitchOnSmiNoFeedback), U8(0), U8(1), I8(0),
|
| B(LdaSmi), I8(79),
|
| - B(Star), R(14),
|
| - B(CallRuntime), U16(Runtime::kAbort), R(14), U8(1),
|
| + B(Star), R(13),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(13), U8(1),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| B(CreateFunctionContext), U8(1),
|
| - B(PushContext), R(14),
|
| + B(PushContext), R(13),
|
| B(Ldar), R(arg0),
|
| B(StaCurrentContextSlot), U8(4),
|
| - B(Mov), R(closure), R(15),
|
| - B(Mov), R(this), R(16),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(15), U8(2),
|
| + B(Mov), R(closure), R(14),
|
| + B(Mov), R(this), R(15),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(14), 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(18),
|
| - /* 11 E> */ B(SuspendGenerator), R(11), R(0), U8(18), U8(0),
|
| - B(Ldar), R(18),
|
| + B(Mov), R(3), R(11),
|
| + B(Mov), R(3), R(14),
|
| + /* 11 E> */ B(SuspendGenerator), R(11), R(0), U8(14), U8(0),
|
| + B(Ldar), R(14),
|
| /* 55 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(11), R(0), U8(18),
|
| + B(RestoreGeneratorRegisters), R(11), R(0), U8(14),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(11), U8(1),
|
| - B(Star), R(18),
|
| + B(Star), R(14),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(11), U8(1),
|
| B(SwitchOnSmiNoFeedback), U8(1), U8(2), I8(0),
|
| - B(Ldar), R(18),
|
| + B(Ldar), R(14),
|
| /* 11 E> */ B(Throw),
|
| - B(LdaTrue),
|
| - B(Star), R(20),
|
| - B(Mov), R(18), R(19),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(19), U8(2),
|
| - B(Star), R(16),
|
| - B(LdaZero),
|
| - B(Star), R(15),
|
| - B(JumpConstant), U8(12),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(11), U8(1),
|
| + B(Ldar), R(14),
|
| + /* 55 S> */ B(Return),
|
| B(LdaZero),
|
| B(Star), R(7),
|
| - B(Mov), R(context), R(20),
|
| - B(Mov), R(context), R(21),
|
| + B(Mov), R(context), R(16),
|
| + B(Mov), R(context), R(17),
|
| /* 35 S> */ B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(22),
|
| - B(LdaNamedProperty), R(22), U8(3), U8(3),
|
| - B(Star), R(23),
|
| - B(CallProperty0), R(23), R(22), U8(5),
|
| + B(Star), R(18),
|
| + B(LdaNamedProperty), R(18), U8(3), 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(5),
|
| /* 30 S> */ B(LdaNamedProperty), R(5), U8(4), U8(9),
|
| - B(Star), R(22),
|
| - B(CallProperty0), R(22), R(5), U8(7),
|
| + B(Star), R(18),
|
| + B(CallProperty0), R(18), R(5), U8(7),
|
| B(Star), R(6),
|
| /* 30 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(6), U8(1),
|
| B(ToBooleanLogicalNot),
|
| @@ -725,29 +719,29 @@ bytecodes: [
|
| B(Star), R(7),
|
| B(JumpLoop), U8(53), I8(0),
|
| B(Jump), U8(36),
|
| - B(Star), R(22),
|
| + B(Star), R(18),
|
| B(Ldar), R(closure),
|
| - /* 50 E> */ B(CreateCatchContext), R(22), U8(7), U8(8),
|
| - B(PushContext), R(22),
|
| - B(Star), R(21),
|
| + /* 50 E> */ B(CreateCatchContext), R(18), U8(7), U8(8),
|
| + B(PushContext), R(18),
|
| + B(Star), R(17),
|
| 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(19),
|
| + B(CallRuntime), U16(Runtime::kReThrow), R(19), U8(1),
|
| + B(PopContext), R(18),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(18),
|
| + B(Star), R(14),
|
| B(Jump), U8(7),
|
| - B(Star), R(19),
|
| + B(Star), R(15),
|
| B(LdaZero),
|
| - B(Star), R(18),
|
| + B(Star), R(14),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(20),
|
| + B(Star), R(16),
|
| B(LdaZero),
|
| B(TestEqualStrict), R(7), U8(16),
|
| B(JumpIfTrue), U8(104),
|
| @@ -764,77 +758,50 @@ bytecodes: [
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| - B(Star), R(21),
|
| + B(Star), R(17),
|
| B(LdaConstant), U8(10),
|
| - B(Star), R(22),
|
| - B(CallRuntime), U16(Runtime::kNewTypeError), R(21), U8(2),
|
| + B(Star), R(18),
|
| + B(CallRuntime), U16(Runtime::kNewTypeError), R(17), 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(17),
|
| + B(Mov), R(9), R(18),
|
| + B(Mov), R(5), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(18), U8(2),
|
| B(Jump), U8(20),
|
| - B(Star), R(22),
|
| + B(Star), R(18),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(22), U8(7), U8(11),
|
| - B(Star), R(21),
|
| + B(CreateCatchContext), R(18), U8(7), U8(11),
|
| + B(Star), R(17),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(21),
|
| - B(PushContext), R(22),
|
| - B(PopContext), R(22),
|
| + B(Ldar), R(17),
|
| + B(PushContext), R(18),
|
| + B(PopContext), R(18),
|
| 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(17),
|
| + B(Mov), R(5), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(17), 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(16),
|
| 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(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(Star), R(16),
|
| - B(LdaSmi), I8(1),
|
| - B(Star), R(15),
|
| - B(LdaTheHole),
|
| - B(SetPendingMessage),
|
| - B(Star), R(17),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(3), U8(1),
|
| - B(Ldar), R(17),
|
| - B(SetPendingMessage),
|
| + B(TestEqualStrictNoFeedback), R(14),
|
| + B(JumpIfFalse), U8(5),
|
| B(Ldar), R(15),
|
| - B(SwitchOnSmiNoFeedback), U8(13), U8(2), I8(0),
|
| - B(Jump), U8(8),
|
| - B(Ldar), R(16),
|
| - /* 55 S> */ B(Return),
|
| - B(Ldar), R(16),
|
| B(ReThrow),
|
| B(LdaUndefined),
|
| + B(Star), R(14),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(11), U8(1),
|
| + B(Ldar), R(14),
|
| /* 55 S> */ B(Return),
|
| ]
|
| constant pool: [
|
| - Smi [55],
|
| - Smi [24],
|
| + Smi [53],
|
| + Smi [14],
|
| Smi [7],
|
| SYMBOL_TYPE,
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| @@ -845,15 +812,11 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["return"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
| FIXED_ARRAY_TYPE,
|
| - Smi [295],
|
| - Smi [6],
|
| - Smi [9],
|
| ]
|
| handlers: [
|
| - [60, 395, 401],
|
| - [120, 238, 244],
|
| - [123, 202, 204],
|
| - [304, 314, 316],
|
| + [108, 226, 232],
|
| + [111, 190, 192],
|
| + [292, 302, 304],
|
| ]
|
|
|
| ---
|
| @@ -863,9 +826,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 24
|
| +frame size: 20
|
| parameter count: 2
|
| -bytecode array length: 528
|
| +bytecode array length: 453
|
| bytecodes: [
|
| B(Mov), R(new_target), R(10),
|
| B(Ldar), R(new_target),
|
| @@ -876,52 +839,46 @@ bytecodes: [
|
| B(Star), R(11),
|
| B(SwitchOnSmiNoFeedback), U8(0), U8(2), I8(0),
|
| B(LdaSmi), I8(79),
|
| - B(Star), R(13),
|
| - B(CallRuntime), U16(Runtime::kAbort), R(13), U8(1),
|
| + B(Star), R(12),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(12), U8(1),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(11),
|
| B(CreateFunctionContext), U8(1),
|
| - B(PushContext), R(13),
|
| + B(PushContext), R(12),
|
| B(Ldar), R(arg0),
|
| B(StaCurrentContextSlot), U8(4),
|
| - B(Mov), R(closure), R(14),
|
| - B(Mov), R(this), R(15),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(14), U8(2),
|
| + B(Mov), R(closure), R(13),
|
| + B(Mov), R(this), R(14),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(13), 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(17),
|
| - /* 11 E> */ B(SuspendGenerator), R(10), R(0), U8(17), U8(0),
|
| - B(Ldar), R(17),
|
| + B(Mov), R(2), R(10),
|
| + B(Mov), R(2), R(13),
|
| + /* 11 E> */ B(SuspendGenerator), R(10), R(0), U8(13), U8(0),
|
| + B(Ldar), R(13),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(17),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(13),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(11),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(10), U8(1),
|
| - B(Star), R(17),
|
| + B(Star), R(13),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(10), U8(1),
|
| B(SwitchOnSmiNoFeedback), U8(2), U8(2), I8(0),
|
| - B(Ldar), R(17),
|
| + B(Ldar), R(13),
|
| /* 11 E> */ B(Throw),
|
| - B(LdaTrue),
|
| - B(Star), R(19),
|
| - B(Mov), R(17), R(18),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(18), U8(2),
|
| - B(Star), R(15),
|
| - B(LdaZero),
|
| - B(Star), R(14),
|
| - B(JumpConstant), U8(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(13),
|
| + /* 49 S> */ B(Return),
|
| B(LdaZero),
|
| B(Star), R(6),
|
| - B(Mov), R(context), R(19),
|
| - B(Mov), R(context), R(20),
|
| + B(Mov), R(context), R(15),
|
| + B(Mov), R(context), R(16),
|
| /* 35 S> */ B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(21),
|
| - B(LdaNamedProperty), R(21), U8(4), U8(3),
|
| - B(Star), R(22),
|
| - B(CallProperty0), R(22), R(21), U8(5),
|
| + B(Star), R(17),
|
| + B(LdaNamedProperty), R(17), U8(4), U8(3),
|
| + B(Star), R(18),
|
| + B(CallProperty0), R(18), R(17), U8(5),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(4),
|
| @@ -931,18 +888,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(17),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(17), U8(1),
|
| /* 30 S> */ B(LdaNamedProperty), R(4), U8(6), U8(9),
|
| - B(Star), R(21),
|
| - B(CallProperty0), R(21), R(4), U8(7),
|
| + B(Star), R(17),
|
| + B(CallProperty0), R(17), 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(7), U8(11),
|
| - B(JumpIfToBooleanTrue), U8(89),
|
| + B(JumpIfToBooleanTrue), U8(79),
|
| B(LdaNamedProperty), R(5), U8(8), U8(13),
|
| B(Star), R(7),
|
| B(LdaSmi), I8(2),
|
| @@ -950,59 +907,54 @@ bytecodes: [
|
| B(Mov), R(7), R(3),
|
| /* 21 E> */ B(StackCheck),
|
| B(Mov), R(3), R(0),
|
| - /* 40 S> */ B(LdaFalse),
|
| - B(Star), R(22),
|
| - B(Mov), R(0), R(21),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(21), U8(2),
|
| - B(Star), R(21),
|
| - B(LdaSmi), I8(1),
|
| - B(SuspendGenerator), R(10), R(0), U8(21), U8(0),
|
| - B(Ldar), R(21),
|
| + /* 40 S> */ B(LdaSmi), I8(1),
|
| + B(Mov), R(0), R(17),
|
| + B(SuspendGenerator), R(10), R(0), U8(17), U8(0),
|
| + B(LdaFalse),
|
| + B(Star), R(19),
|
| + B(Mov), R(17), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(18), U8(2),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(21),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(17),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(11),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(10), U8(1),
|
| - B(Star), R(21),
|
| + B(Star), R(17),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(10), U8(1),
|
| B(SwitchOnSmiNoFeedback), U8(9), U8(2), I8(0),
|
| - B(Ldar), R(21),
|
| + B(Ldar), R(17),
|
| /* 40 E> */ B(Throw),
|
| - B(LdaTrue),
|
| - B(Star), R(23),
|
| - B(Mov), R(21), R(22),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(22), U8(2),
|
| - B(Star), R(18),
|
| B(LdaZero),
|
| - B(Star), R(17),
|
| + B(Star), R(13),
|
| + B(Mov), R(17), R(14),
|
| B(Jump), U8(56),
|
| B(LdaZero),
|
| B(Star), R(6),
|
| - B(JumpLoop), U8(135), I8(0),
|
| + B(JumpLoop), U8(125), I8(0),
|
| B(Jump), U8(36),
|
| - B(Star), R(21),
|
| + B(Star), R(17),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(21), U8(11), U8(12),
|
| - B(PushContext), R(21),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(17), U8(11), U8(12),
|
| + B(PushContext), R(17),
|
| + B(Star), R(16),
|
| 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(18),
|
| + B(CallRuntime), U16(Runtime::kReThrow), R(18), U8(1),
|
| + B(PopContext), R(17),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(17),
|
| + B(Star), R(13),
|
| B(Jump), U8(8),
|
| - B(Star), R(18),
|
| + B(Star), R(14),
|
| B(LdaSmi), I8(1),
|
| - B(Star), R(17),
|
| + B(Star), R(13),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(19),
|
| + B(Star), R(15),
|
| B(LdaZero),
|
| B(TestEqualStrict), R(6), U8(16),
|
| B(JumpIfTrue), U8(104),
|
| @@ -1019,89 +971,61 @@ bytecodes: [
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| - B(Star), R(20),
|
| + B(Star), R(16),
|
| B(LdaConstant), U8(14),
|
| - B(Star), R(21),
|
| - B(CallRuntime), U16(Runtime::kNewTypeError), R(20), U8(2),
|
| + B(Star), R(17),
|
| + B(CallRuntime), U16(Runtime::kNewTypeError), R(16), 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(16),
|
| + B(Mov), R(8), R(17),
|
| + B(Mov), R(4), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(17), U8(2),
|
| B(Jump), U8(20),
|
| - B(Star), R(21),
|
| + B(Star), R(17),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(21), U8(11), U8(15),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(17), U8(11), U8(15),
|
| + B(Star), R(16),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(20),
|
| - B(PushContext), R(21),
|
| - B(PopContext), R(21),
|
| + B(Ldar), R(16),
|
| + B(PushContext), R(17),
|
| + B(PopContext), R(17),
|
| 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(16),
|
| + B(Mov), R(4), R(17),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(16), 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(15),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(17),
|
| + B(Ldar), R(13),
|
| B(SwitchOnSmiNoFeedback), U8(16), 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(LdaTrue),
|
| - B(Star), R(18),
|
| - 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(Jump), U8(12),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| B(Ldar), R(14),
|
| - B(SwitchOnSmiNoFeedback), U8(19), U8(2), I8(0),
|
| - B(Jump), U8(8),
|
| - B(Ldar), R(15),
|
| /* 49 S> */ B(Return),
|
| - B(Ldar), R(15),
|
| + B(Ldar), R(14),
|
| B(ReThrow),
|
| B(LdaUndefined),
|
| + B(Star), R(13),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(13),
|
| /* 49 S> */ B(Return),
|
| ]
|
| constant pool: [
|
| - Smi [55],
|
| - Smi [129],
|
| - Smi [24],
|
| + Smi [53],
|
| + Smi [117],
|
| + Smi [14],
|
| Smi [7],
|
| SYMBOL_TYPE,
|
| - Smi [88],
|
| + Smi [87],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["done"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["value"],
|
| - Smi [24],
|
| + Smi [15],
|
| Smi [7],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [".catch"],
|
| FIXED_ARRAY_TYPE,
|
| @@ -1109,16 +1033,12 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
| FIXED_ARRAY_TYPE,
|
| Smi [6],
|
| - Smi [14],
|
| - Smi [389],
|
| - Smi [6],
|
| - Smi [9],
|
| + Smi [13],
|
| ]
|
| handlers: [
|
| - [60, 489, 495],
|
| - [120, 320, 326],
|
| - [123, 284, 286],
|
| - [387, 397, 399],
|
| + [108, 298, 304],
|
| + [111, 262, 264],
|
| + [365, 375, 377],
|
| ]
|
|
|
| ---
|
| @@ -1340,9 +1260,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 27
|
| +frame size: 26
|
| parameter count: 2
|
| -bytecode array length: 546
|
| +bytecode array length: 537
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -1353,35 +1273,35 @@ bytecodes: [
|
| B(Star), R(12),
|
| B(SwitchOnSmiNoFeedback), U8(0), U8(1), I8(0),
|
| B(LdaSmi), I8(79),
|
| - B(Star), R(14),
|
| - B(CallRuntime), U16(Runtime::kAbort), R(14), U8(1),
|
| + B(Star), R(13),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(13), U8(1),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| B(CreateFunctionContext), U8(1),
|
| - B(PushContext), R(14),
|
| + B(PushContext), R(13),
|
| B(Ldar), R(arg0),
|
| B(StaCurrentContextSlot), U8(4),
|
| - B(Mov), R(closure), R(15),
|
| - B(Mov), R(this), R(16),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(15), U8(2),
|
| + B(Mov), R(closure), R(14),
|
| + B(Mov), R(this), R(15),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateJSGeneratorObject), R(14), U8(2),
|
| B(Star), R(2),
|
| /* 16 E> */ B(StackCheck),
|
| B(LdaUndefined),
|
| - B(Star), R(15),
|
| - B(CallJSRuntime), U8(%async_function_promise_create), R(15), U8(1),
|
| + B(Star), R(14),
|
| + B(CallJSRuntime), U8(%async_function_promise_create), R(14), U8(1),
|
| B(Star), R(3),
|
| - B(Mov), R(context), R(17),
|
| + B(Mov), R(context), R(16),
|
| B(Mov), R(2), R(11),
|
| - B(Mov), R(context), R(18),
|
| + B(Mov), R(context), R(17),
|
| B(LdaZero),
|
| B(Star), R(7),
|
| + B(Mov), R(context), R(20),
|
| B(Mov), R(context), R(21),
|
| - B(Mov), R(context), R(22),
|
| /* 40 S> */ B(LdaImmutableCurrentContextSlot), U8(4),
|
| + B(Star), R(22),
|
| + B(LdaNamedProperty), R(22), U8(1), U8(3),
|
| B(Star), R(23),
|
| - B(LdaNamedProperty), R(23), U8(1), U8(3),
|
| - B(Star), R(24),
|
| - B(CallProperty0), R(24), R(23), U8(5),
|
| + B(CallProperty0), R(23), R(22), U8(5),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(5),
|
| @@ -1391,18 +1311,18 @@ bytecodes: [
|
| /* 40 E> */ B(TestEqualStrictNoFeedback), R(12),
|
| B(JumpIfTrue), U8(11),
|
| B(LdaSmi), I8(79),
|
| - B(Star), R(23),
|
| - B(CallRuntime), U16(Runtime::kAbort), R(23), U8(1),
|
| + B(Star), R(22),
|
| + B(CallRuntime), U16(Runtime::kAbort), R(22), U8(1),
|
| /* 35 S> */ B(LdaNamedProperty), R(5), U8(3), U8(9),
|
| - B(Star), R(23),
|
| - B(CallProperty0), R(23), R(5), U8(7),
|
| + B(Star), R(22),
|
| + B(CallProperty0), R(22), R(5), U8(7),
|
| B(Star), R(6),
|
| /* 35 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(6), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(6), U8(1),
|
| B(LdaNamedProperty), R(6), U8(4), U8(11),
|
| - B(JumpIfToBooleanTrue), U8(95),
|
| + B(JumpIfToBooleanTrue), U8(86),
|
| B(LdaNamedProperty), R(6), U8(5), U8(13),
|
| B(Star), R(8),
|
| B(LdaSmi), I8(2),
|
| @@ -1411,63 +1331,59 @@ bytecodes: [
|
| /* 26 E> */ B(StackCheck),
|
| B(Mov), R(4), R(0),
|
| /* 45 S> */ B(LdaUndefined),
|
| - B(Star), R(23),
|
| - B(Mov), R(2), R(24),
|
| - B(Mov), R(4), R(25),
|
| - B(Mov), R(3), R(26),
|
| - /* 51 E> */ B(CallJSRuntime), U8(%async_function_await_uncaught), R(23), U8(4),
|
| + B(Star), R(22),
|
| + B(Mov), R(2), R(23),
|
| + B(Mov), R(4), R(24),
|
| + B(Mov), R(3), R(25),
|
| + /* 51 E> */ B(CallJSRuntime), U8(%async_function_await_uncaught), R(22), U8(4),
|
| B(LdaZero),
|
| - B(Mov), R(3), R(23),
|
| - B(SuspendGenerator), R(11), R(0), U8(23), U8(2),
|
| - B(Ldar), R(23),
|
| + B(Mov), R(3), R(22),
|
| + B(SuspendGenerator), R(11), R(0), U8(22), U8(2),
|
| + B(Ldar), R(22),
|
| /* 54 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(11), R(0), U8(23),
|
| + B(RestoreGeneratorRegisters), R(11), R(0), U8(22),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(11), U8(1),
|
| - B(Star), R(23),
|
| + B(Star), R(22),
|
| B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(11), U8(1),
|
| B(SwitchOnSmiNoFeedback), U8(6), U8(2), I8(0),
|
| - B(Ldar), R(23),
|
| + B(Ldar), R(22),
|
| /* 45 E> */ B(ReThrow),
|
| - B(LdaTrue),
|
| - B(Star), R(25),
|
| - B(Mov), R(23), R(24),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(24), U8(2),
|
| - B(Star), R(20),
|
| B(LdaZero),
|
| - B(Star), R(19),
|
| + B(Star), R(18),
|
| + B(Mov), R(22), R(19),
|
| B(Jump), U8(60),
|
| B(LdaZero),
|
| B(Star), R(7),
|
| - B(JumpLoop), U8(141), I8(0),
|
| + B(JumpLoop), U8(132), I8(0),
|
| B(Jump), U8(40),
|
| - B(Star), R(23),
|
| - B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(23), U8(8), U8(9),
|
| B(Star), R(22),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(22), U8(8), U8(9),
|
| + B(Star), R(21),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(22),
|
| - B(PushContext), R(23),
|
| + B(Ldar), R(21),
|
| + B(PushContext), R(22),
|
| 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(24),
|
| - B(CallRuntime), U16(Runtime::kReThrow), R(24), U8(1),
|
| - B(PopContext), R(23),
|
| + B(Star), R(23),
|
| + B(CallRuntime), U16(Runtime::kReThrow), R(23), U8(1),
|
| + B(PopContext), R(22),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(19),
|
| + B(Star), R(18),
|
| B(Jump), U8(8),
|
| - B(Star), R(20),
|
| - B(LdaSmi), I8(1),
|
| B(Star), R(19),
|
| + B(LdaSmi), I8(1),
|
| + B(Star), R(18),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(21),
|
| + B(Star), R(20),
|
| B(LdaZero),
|
| B(TestEqualStrict), R(7), U8(16),
|
| B(JumpIfTrue), U8(104),
|
| @@ -1484,98 +1400,98 @@ bytecodes: [
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| - B(Star), R(22),
|
| + B(Star), R(21),
|
| B(LdaConstant), U8(11),
|
| - B(Star), R(23),
|
| - B(CallRuntime), U16(Runtime::kNewTypeError), R(22), U8(2),
|
| + B(Star), R(22),
|
| + B(CallRuntime), U16(Runtime::kNewTypeError), R(21), U8(2),
|
| B(Throw),
|
| - B(Mov), R(context), R(22),
|
| - B(Mov), R(9), R(23),
|
| - B(Mov), R(5), R(24),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(23), U8(2),
|
| + 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(Jump), U8(20),
|
| - B(Star), R(23),
|
| - B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(23), U8(8), U8(12),
|
| B(Star), R(22),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(22), U8(8), U8(12),
|
| + B(Star), R(21),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(22),
|
| - B(PushContext), R(23),
|
| - B(PopContext), R(23),
|
| + B(Ldar), R(21),
|
| + B(PushContext), R(22),
|
| + B(PopContext), R(22),
|
| B(Jump), U8(27),
|
| - 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(9), R(21),
|
| + B(Mov), R(5), R(22),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(21), 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(21),
|
| + B(Ldar), R(20),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(19),
|
| + B(Ldar), R(18),
|
| B(SwitchOnSmiNoFeedback), U8(13), U8(2), I8(0),
|
| B(Jump), U8(13),
|
| B(LdaZero),
|
| - B(Star), R(15),
|
| - B(Mov), R(20), R(16),
|
| + B(Star), R(14),
|
| + B(Mov), R(19), R(15),
|
| B(Jump), U8(83),
|
| - B(Ldar), R(20),
|
| + B(Ldar), R(19),
|
| B(ReThrow),
|
| B(LdaUndefined),
|
| - B(Star), R(19),
|
| + B(Star), R(18),
|
| B(LdaUndefined),
|
| - B(Star), R(21),
|
| - B(Mov), R(3), R(20),
|
| - B(CallJSRuntime), U8(%promise_resolve), R(19), U8(3),
|
| + B(Star), R(20),
|
| + B(Mov), R(3), R(19),
|
| + B(CallJSRuntime), U8(%promise_resolve), R(18), U8(3),
|
| B(LdaZero),
|
| - B(Star), R(15),
|
| - B(Mov), R(3), R(16),
|
| + B(Star), R(14),
|
| + B(Mov), R(3), R(15),
|
| B(Jump), U8(59),
|
| B(Jump), U8(45),
|
| - B(Star), R(19),
|
| - B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(19), U8(8), U8(15),
|
| B(Star), R(18),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(18), U8(8), U8(15),
|
| + B(Star), R(17),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(18),
|
| - B(PushContext), R(19),
|
| + B(Ldar), R(17),
|
| + B(PushContext), R(18),
|
| B(LdaUndefined),
|
| - B(Star), R(20),
|
| + B(Star), R(19),
|
| B(LdaImmutableCurrentContextSlot), U8(4),
|
| - B(Star), R(22),
|
| + B(Star), R(21),
|
| B(LdaFalse),
|
| - B(Star), R(23),
|
| - B(Mov), R(3), R(21),
|
| - B(CallJSRuntime), U8(%promise_internal_reject), R(20), U8(4),
|
| - B(PopContext), R(19),
|
| + B(Star), R(22),
|
| + B(Mov), R(3), R(20),
|
| + B(CallJSRuntime), U8(%promise_internal_reject), R(19), U8(4),
|
| + B(PopContext), R(18),
|
| B(LdaZero),
|
| - B(Star), R(15),
|
| - B(Mov), R(3), R(16),
|
| + B(Star), R(14),
|
| + B(Mov), R(3), R(15),
|
| B(Jump), U8(14),
|
| B(LdaSmi), I8(-1),
|
| - B(Star), R(15),
|
| + B(Star), R(14),
|
| B(Jump), U8(8),
|
| - B(Star), R(16),
|
| - B(LdaSmi), I8(1),
|
| B(Star), R(15),
|
| + B(LdaSmi), I8(1),
|
| + B(Star), R(14),
|
| B(LdaTheHole),
|
| B(SetPendingMessage),
|
| - B(Star), R(17),
|
| + B(Star), R(16),
|
| B(LdaUndefined),
|
| - B(Star), R(18),
|
| - B(Mov), R(3), R(19),
|
| - B(CallJSRuntime), U8(%async_function_promise_release), R(18), U8(2),
|
| - B(Ldar), R(17),
|
| + B(Star), R(17),
|
| + B(Mov), R(3), R(18),
|
| + B(CallJSRuntime), U8(%async_function_promise_release), R(17), U8(2),
|
| + B(Ldar), R(16),
|
| B(SetPendingMessage),
|
| - B(Ldar), R(15),
|
| + B(Ldar), R(14),
|
| B(SwitchOnSmiNoFeedback), U8(16), U8(2), I8(0),
|
| B(Jump), U8(8),
|
| - B(Ldar), R(16),
|
| + B(Ldar), R(15),
|
| /* 54 S> */ B(Return),
|
| - B(Ldar), R(16),
|
| + B(Ldar), R(15),
|
| B(ReThrow),
|
| B(LdaUndefined),
|
| /* 54 S> */ B(Return),
|
| @@ -1587,7 +1503,7 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["done"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["value"],
|
| - Smi [24],
|
| + Smi [15],
|
| Smi [7],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [".catch"],
|
| FIXED_ARRAY_TYPE,
|
| @@ -1601,10 +1517,10 @@ constant pool: [
|
| Smi [9],
|
| ]
|
| handlers: [
|
| - [70, 501, 507],
|
| - [73, 456, 458],
|
| - [79, 289, 295],
|
| - [82, 249, 251],
|
| - [356, 366, 368],
|
| + [70, 492, 498],
|
| + [73, 447, 449],
|
| + [79, 280, 286],
|
| + [82, 240, 242],
|
| + [347, 357, 359],
|
| ]
|
|
|
|
|