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

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

Issue 2917263002: Move generator-close on exception from the generator function to the GeneratorResume builtin. (Closed)
Patch Set: Scope for the old unused context register Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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],
]

Powered by Google App Engine
This is Rietveld 408576698