| 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..93925265600bc66c1e791e0d9265a56d307d49b5 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: 446
|
| +bytecode array length: 382
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -654,65 +654,59 @@ 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(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(15),
|
| + B(Mov), R(3), R(14),
|
| + /* 11 E> */ B(SuspendGenerator), R(14), R(0), U8(15), U8(0),
|
| + B(Ldar), R(15),
|
| /* 55 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(11), R(0), U8(19),
|
| + B(RestoreGeneratorRegisters), R(11), R(0), U8(15),
|
| 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(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(20),
|
| - B(JumpIfTrue), U8(28),
|
| - B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(20),
|
| - B(JumpIfTrue), U8(19),
|
| - B(LdaTrue),
|
| - B(Star), R(22),
|
| - B(Mov), R(19), R(21),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(21), U8(2),
|
| + 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(Star), R(15),
|
| - B(JumpConstant), U8(10),
|
| - B(Ldar), R(19),
|
| + B(TestEqualStrictNoFeedback), R(16),
|
| + B(JumpIfTrue), U8(18),
|
| + B(LdaSmi), I8(2),
|
| + B(TestEqualStrictNoFeedback), R(16),
|
| + B(JumpIfTrue), U8(9),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(11), U8(1),
|
| + B(Ldar), R(15),
|
| + /* 55 S> */ B(Return),
|
| + B(Ldar), R(15),
|
| /* 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(16),
|
| + B(Mov), R(context), R(17),
|
| /* 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(18),
|
| + B(LdaNamedProperty), R(18), U8(1), 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(2), 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),
|
| @@ -732,29 +726,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(5), U8(6),
|
| - B(PushContext), R(22),
|
| - B(Star), R(21),
|
| + /* 50 E> */ B(CreateCatchContext), R(18), U8(5), U8(6),
|
| + 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),
|
| @@ -771,76 +765,49 @@ 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(8),
|
| - 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(5), U8(9),
|
| - B(Star), R(21),
|
| + B(CreateCatchContext), R(18), U8(5), U8(9),
|
| + 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(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),
|
| + 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 [58],
|
| + Smi [56],
|
| SYMBOL_TYPE,
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["next"],
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE ["done"],
|
| @@ -850,15 +817,11 @@ 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],
|
| + [120, 238, 244],
|
| + [123, 202, 204],
|
| + [304, 314, 316],
|
| ]
|
|
|
| ---
|
| @@ -868,9 +831,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 26
|
| +frame size: 21
|
| parameter count: 2
|
| -bytecode array length: 552
|
| +bytecode array length: 477
|
| bytecodes: [
|
| B(Mov), R(new_target), R(10),
|
| B(Ldar), R(new_target),
|
| @@ -881,59 +844,53 @@ 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(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(14),
|
| + B(Mov), R(2), R(13),
|
| + /* 11 E> */ B(SuspendGenerator), R(13), R(0), U8(14), U8(0),
|
| + B(Ldar), R(14),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(18),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(14),
|
| 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(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(19),
|
| - B(JumpIfTrue), U8(28),
|
| - B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(19),
|
| - B(JumpIfTrue), U8(19),
|
| - B(LdaTrue),
|
| - B(Star), R(21),
|
| - B(Mov), R(18), R(20),
|
| - B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(20), U8(2),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(13), U8(1),
|
| + B(Star), R(14),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(13), U8(1),
|
| B(Star), R(15),
|
| B(LdaZero),
|
| - B(Star), R(14),
|
| - B(JumpConstant), U8(14),
|
| - B(Ldar), R(18),
|
| + B(TestEqualStrictNoFeedback), R(15),
|
| + B(JumpIfTrue), U8(18),
|
| + B(LdaSmi), I8(2),
|
| + B(TestEqualStrictNoFeedback), R(15),
|
| + B(JumpIfTrue), U8(9),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorClose), R(10), U8(1),
|
| + B(Ldar), R(14),
|
| + /* 49 S> */ B(Return),
|
| + B(Ldar), R(14),
|
| /* 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(15),
|
| + B(Mov), R(context), R(16),
|
| /* 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(17),
|
| + B(LdaNamedProperty), R(17), U8(2), 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),
|
| @@ -943,18 +900,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(4), 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(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 +919,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(18),
|
| + B(Mov), R(2), R(17),
|
| + /* 46 E> */ B(SuspendGenerator), R(17), R(0), U8(18), U8(0),
|
| + B(LdaFalse),
|
| + B(Star), R(20),
|
| + B(Mov), R(18), R(19),
|
| + B(InvokeIntrinsic), U8(Runtime::k_CreateIterResultObject), R(19), U8(2),
|
| /* 49 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(10), R(0), U8(22),
|
| + B(RestoreGeneratorRegisters), R(10), R(0), U8(18),
|
| 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(17), U8(1),
|
| + B(Star), R(18),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(17), U8(1),
|
| + B(Star), R(19),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(23),
|
| - B(JumpIfTrue), U8(28),
|
| - B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(23),
|
| + B(TestEqualStrictNoFeedback), R(19),
|
| 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(19),
|
| + B(JumpIfTrue), U8(10),
|
| B(LdaZero),
|
| - B(Star), R(17),
|
| + B(Star), R(13),
|
| + B(Mov), R(18), R(14),
|
| B(Jump), U8(59),
|
| - B(Ldar), R(22),
|
| + B(Ldar), R(18),
|
| /* 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(17),
|
| B(Ldar), R(closure),
|
| - B(CreateCatchContext), R(21), U8(7), U8(8),
|
| - B(PushContext), R(21),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(17), U8(7), U8(8),
|
| + 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),
|
| @@ -1038,83 +990,55 @@ 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(10),
|
| - 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(7), U8(11),
|
| - B(Star), R(20),
|
| + B(CreateCatchContext), R(17), U8(7), U8(11),
|
| + 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(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(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(15), 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 [58],
|
| - Smi [141],
|
| + Smi [56],
|
| + Smi [129],
|
| 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 +1048,12 @@ constant pool: [
|
| ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
| FIXED_ARRAY_TYPE,
|
| Smi [6],
|
| - Smi [14],
|
| - Smi [404],
|
| - Smi [6],
|
| - Smi [9],
|
| + Smi [13],
|
| ]
|
| handlers: [
|
| - [60, 513, 519],
|
| - [132, 344, 350],
|
| - [135, 308, 310],
|
| - [411, 421, 423],
|
| + [120, 322, 328],
|
| + [123, 286, 288],
|
| + [389, 399, 401],
|
| ]
|
|
|
| ---
|
| @@ -1355,9 +1275,9 @@ snippet: "
|
| }
|
| f([1, 2, 3]);
|
| "
|
| -frame size: 28
|
| +frame size: 27
|
| parameter count: 2
|
| -bytecode array length: 558
|
| +bytecode array length: 549
|
| bytecodes: [
|
| B(Mov), R(new_target), R(11),
|
| B(Ldar), R(new_target),
|
| @@ -1368,35 +1288,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),
|
| @@ -1406,18 +1326,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(107),
|
| + B(JumpIfToBooleanTrue), U8(98),
|
| B(LdaNamedProperty), R(6), U8(5), U8(13),
|
| B(Star), R(8),
|
| B(LdaSmi), I8(2),
|
| @@ -1426,70 +1346,66 @@ bytecodes: [
|
| /* 26 E> */ B(StackCheck),
|
| B(Mov), R(4), R(0),
|
| /* 45 S> */ B(LdaUndefined),
|
| - B(Star), R(24),
|
| - B(Mov), R(2), R(25),
|
| - B(Mov), R(4), R(26),
|
| - B(Mov), R(3), R(27),
|
| - /* 51 E> */ B(CallJSRuntime), U8(%async_function_await_uncaught), R(24), U8(4),
|
| + 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(LdaZero),
|
| - B(Mov), R(2), R(23),
|
| - B(Mov), R(3), R(24),
|
| - B(SuspendGenerator), R(23), R(0), U8(24), U8(2),
|
| - B(Ldar), R(24),
|
| + B(Mov), R(2), R(22),
|
| + B(Mov), R(3), R(23),
|
| + B(SuspendGenerator), R(22), R(0), U8(23), U8(2),
|
| + B(Ldar), R(23),
|
| /* 54 S> */ B(Return),
|
| - B(RestoreGeneratorRegisters), R(11), R(0), U8(24),
|
| + B(RestoreGeneratorRegisters), R(11), R(0), U8(23),
|
| B(LdaSmi), I8(-2),
|
| B(Star), R(12),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(23), U8(1),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetInputOrDebugPos), R(22), U8(1),
|
| + B(Star), R(23),
|
| + B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(22), U8(1),
|
| B(Star), R(24),
|
| - B(InvokeIntrinsic), U8(Runtime::k_GeneratorGetResumeMode), R(23), U8(1),
|
| - B(Star), R(25),
|
| B(LdaZero),
|
| - B(TestEqualStrictNoFeedback), R(25),
|
| - B(JumpIfTrue), U8(28),
|
| - B(LdaSmi), I8(2),
|
| - B(TestEqualStrictNoFeedback), R(25),
|
| + B(TestEqualStrictNoFeedback), R(24),
|
| 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(LdaSmi), I8(2),
|
| + B(TestEqualStrictNoFeedback), R(24),
|
| + B(JumpIfTrue), U8(10),
|
| B(LdaZero),
|
| - B(Star), R(19),
|
| + B(Star), R(18),
|
| + B(Mov), R(23), R(19),
|
| B(Jump), U8(63),
|
| - B(Ldar), R(24),
|
| + B(Ldar), R(23),
|
| /* 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),
|
| - B(CreateCatchContext), R(23), U8(6), U8(7),
|
| B(Star), R(22),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(22), U8(6), U8(7),
|
| + 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),
|
| @@ -1506,98 +1422,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(9),
|
| - 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(6), U8(10),
|
| B(Star), R(22),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(22), U8(6), U8(10),
|
| + 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(11), 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(6), U8(13),
|
| B(Star), R(18),
|
| + B(Ldar), R(closure),
|
| + B(CreateCatchContext), R(18), U8(6), U8(13),
|
| + 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(14), 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),
|
| @@ -1621,10 +1537,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],
|
| ]
|
|
|
|
|