Index: test/cctest/interpreter/bytecode_expectations/Generators.golden |
diff --git a/test/cctest/interpreter/bytecode_expectations/Generators.golden b/test/cctest/interpreter/bytecode_expectations/Generators.golden |
index 580cc98b72519687e2f3118751ff959e39652e3a..424189d719362a5fdff08944787032c8e4198535 100644 |
--- a/test/cctest/interpreter/bytecode_expectations/Generators.golden |
+++ b/test/cctest/interpreter/bytecode_expectations/Generators.golden |
@@ -13,17 +13,17 @@ ignition generators: yes |
snippet: " |
function* f() { } |
" |
-frame size: 11 |
+frame size: 10 |
parameter count: 1 |
-bytecode array length: 201 |
+bytecode array length: 193 |
bytecodes: [ |
B(Ldar), R(new_target), |
- B(JumpIfUndefined), U8(15), |
- B(CallRuntime), U16(Runtime::kResumeIgnitionGenerator), R(new_target), U8(1), |
+ B(JumpIfUndefined), U8(12), |
+ B(ResumeGenerator), R(new_target), |
B(Star), R(1), |
B(LdaZero), |
B(TestEqualStrict), R(1), |
- B(JumpIfTrue), U8(54), |
+ B(JumpIfTrue), U8(49), |
B(Illegal), |
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1), |
B(PushContext), R(0), |
@@ -41,32 +41,31 @@ bytecodes: [ |
B(LdaContextSlot), R(context), U8(5), |
B(Star), R(5), |
B(LdaZero), |
- B(Star), R(6), |
- B(CallRuntime), U16(Runtime::kSuspendIgnitionGenerator), R(5), U8(2), |
+ B(SuspendGenerator), R(5), |
B(Ldar), R(4), |
B(Return), |
B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(5), U8(1), |
- B(Star), R(7), |
+ B(Star), R(6), |
B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(5), U8(1), |
- B(Star), R(8), |
+ B(Star), R(7), |
B(LdaZero), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(31), |
B(LdaSmi), U8(2), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(7), R(9), |
+ B(Mov), R(6), R(8), |
B(LdaTrue), |
- B(Star), R(10), |
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2), |
+ B(Star), R(9), |
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2), |
B(Star), R(2), |
B(LdaZero), |
B(Star), R(1), |
B(Jump), U8(38), |
- B(Ldar), R(7), |
+ B(Ldar), R(6), |
B(Throw), |
- B(Ldar), R(7), |
+ B(Ldar), R(6), |
B(LdaUndefined), |
B(Star), R(4), |
B(LdaTrue), |
@@ -110,27 +109,27 @@ bytecodes: [ |
constant pool: [ |
] |
handlers: [ |
- [33, 137, 143], |
+ [30, 129, 135], |
] |
--- |
snippet: " |
function* f() { yield 42 } |
" |
-frame size: 11 |
+frame size: 10 |
parameter count: 1 |
-bytecode array length: 298 |
+bytecode array length: 285 |
bytecodes: [ |
B(Ldar), R(new_target), |
- B(JumpIfUndefined), U8(21), |
- B(CallRuntime), U16(Runtime::kResumeIgnitionGenerator), R(new_target), U8(1), |
+ B(JumpIfUndefined), U8(18), |
+ B(ResumeGenerator), R(new_target), |
B(Star), R(1), |
B(LdaZero), |
B(TestEqualStrict), R(1), |
- B(JumpIfTrue), U8(60), |
+ B(JumpIfTrue), U8(55), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(1), |
- B(JumpIfTrueConstant), U8(0), |
+ B(JumpIfTrue), U8(125), |
B(Illegal), |
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1), |
B(PushContext), R(0), |
@@ -148,32 +147,31 @@ bytecodes: [ |
B(LdaContextSlot), R(context), U8(5), |
B(Star), R(5), |
B(LdaZero), |
- B(Star), R(6), |
- B(CallRuntime), U16(Runtime::kSuspendIgnitionGenerator), R(5), U8(2), |
+ B(SuspendGenerator), R(5), |
B(Ldar), R(4), |
B(Return), |
B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(5), U8(1), |
- B(Star), R(7), |
+ B(Star), R(6), |
B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(5), U8(1), |
- B(Star), R(8), |
+ B(Star), R(7), |
B(LdaZero), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(31), |
B(LdaSmi), U8(2), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(7), R(9), |
+ B(Mov), R(6), R(8), |
B(LdaTrue), |
- B(Star), R(10), |
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2), |
+ B(Star), R(9), |
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2), |
B(Star), R(2), |
B(LdaZero), |
B(Star), R(1), |
- B(Jump), U8(120), |
- B(Ldar), R(7), |
+ B(Jump), U8(115), |
+ B(Ldar), R(6), |
B(Throw), |
- B(Ldar), R(7), |
+ B(Ldar), R(6), |
B(LdaSmi), U8(42), |
B(Star), R(4), |
B(LdaFalse), |
@@ -183,32 +181,31 @@ bytecodes: [ |
B(LdaContextSlot), R(context), U8(5), |
B(Star), R(4), |
B(LdaSmi), U8(1), |
- B(Star), R(5), |
- B(CallRuntime), U16(Runtime::kSuspendIgnitionGenerator), R(4), U8(2), |
+ B(SuspendGenerator), R(4), |
B(Ldar), R(6), |
B(Return), |
B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(4), U8(1), |
- B(Star), R(7), |
+ B(Star), R(5), |
B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(4), U8(1), |
- B(Star), R(8), |
+ B(Star), R(7), |
B(LdaZero), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(32), |
B(LdaSmi), U8(2), |
- B(TestEqualStrict), R(8), |
+ B(TestEqualStrict), R(7), |
B(JumpIfTrue), U8(23), |
B(Jump), U8(2), |
- B(Mov), R(7), R(9), |
+ B(Mov), R(5), R(8), |
B(LdaTrue), |
- B(Star), R(10), |
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(9), U8(2), |
+ B(Star), R(9), |
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(8), U8(2), |
B(Star), R(2), |
B(LdaSmi), U8(1), |
B(Star), R(1), |
B(Jump), U8(38), |
- B(Ldar), R(7), |
+ B(Ldar), R(5), |
B(Throw), |
- B(Ldar), R(7), |
+ B(Ldar), R(5), |
B(LdaUndefined), |
B(Star), R(4), |
B(LdaTrue), |
@@ -255,27 +252,26 @@ bytecodes: [ |
B(Return), |
] |
constant pool: [ |
- kInstanceTypeDontCare, |
] |
handlers: [ |
- [39, 225, 231], |
+ [36, 212, 218], |
] |
--- |
snippet: " |
function* f() { for (let x of [42]) yield x } |
" |
-frame size: 17 |
+frame size: 16 |
parameter count: 1 |
-bytecode array length: 786 |
+bytecode array length: 773 |
bytecodes: [ |
B(Ldar), R(new_target), |
- B(JumpIfUndefined), U8(21), |
- B(CallRuntime), U16(Runtime::kResumeIgnitionGenerator), R(new_target), U8(1), |
+ B(JumpIfUndefined), U8(18), |
+ B(ResumeGenerator), R(new_target), |
B(Star), R(3), |
B(LdaZero), |
B(TestEqualStrict), R(3), |
- B(JumpIfTrue), U8(60), |
+ B(JumpIfTrue), U8(55), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(3), |
B(JumpIfTrueConstant), U8(8), |
@@ -296,32 +292,31 @@ bytecodes: [ |
B(LdaContextSlot), R(context), U8(5), |
B(Star), R(7), |
B(LdaZero), |
- B(Star), R(8), |
- B(CallRuntime), U16(Runtime::kSuspendIgnitionGenerator), R(7), U8(2), |
+ B(SuspendGenerator), R(7), |
B(Ldar), R(6), |
B(Return), |
B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(7), U8(1), |
- B(Star), R(9), |
+ B(Star), R(8), |
B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(7), U8(1), |
- B(Star), R(10), |
+ B(Star), R(9), |
B(LdaZero), |
- B(TestEqualStrict), R(10), |
+ B(TestEqualStrict), R(9), |
B(JumpIfTrue), U8(31), |
B(LdaSmi), U8(2), |
- B(TestEqualStrict), R(10), |
+ B(TestEqualStrict), R(9), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(9), R(11), |
+ B(Mov), R(8), R(10), |
B(LdaTrue), |
- B(Star), R(12), |
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(11), U8(2), |
+ B(Star), R(11), |
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(10), U8(2), |
B(Star), R(4), |
B(LdaZero), |
B(Star), R(3), |
B(JumpConstant), U8(16), |
- B(Ldar), R(9), |
+ B(Ldar), R(8), |
B(Throw), |
- B(Ldar), R(9), |
+ B(Ldar), R(8), |
B(LdaConstant), U8(0), |
B(Star), R(6), |
B(Ldar), R(closure), |
@@ -391,25 +386,24 @@ bytecodes: [ |
B(LdaContextSlot), R(1), U8(5), |
B(Star), R(10), |
B(LdaSmi), U8(1), |
- B(Star), R(11), |
- B(CallRuntime), U16(Runtime::kSuspendIgnitionGenerator), R(10), U8(2), |
+ B(SuspendGenerator), R(10), |
B(Ldar), R(12), |
B(Return), |
B(CallRuntime), U16(Runtime::kGeneratorGetInput), R(10), U8(1), |
- B(Star), R(13), |
+ B(Star), R(11), |
B(CallRuntime), U16(Runtime::kGeneratorGetResumeMode), R(10), U8(1), |
- B(Star), R(14), |
+ B(Star), R(13), |
B(LdaZero), |
- B(TestEqualStrict), R(14), |
+ B(TestEqualStrict), R(13), |
B(JumpIfTrue), U8(45), |
B(LdaSmi), U8(2), |
- B(TestEqualStrict), R(14), |
+ B(TestEqualStrict), R(13), |
B(JumpIfTrue), U8(36), |
B(Jump), U8(2), |
- B(Mov), R(13), R(15), |
+ B(Mov), R(11), R(14), |
B(LdaTrue), |
- B(Star), R(16), |
- B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(15), U8(2), |
+ B(Star), R(15), |
+ B(CallRuntime), U16(Runtime::kCreateIterResultObject), R(14), U8(2), |
B(PopContext), R(2), |
B(PopContext), R(2), |
B(PopContext), R(2), |
@@ -421,13 +415,13 @@ bytecodes: [ |
B(LdaZero), |
B(Star), R(6), |
B(Jump), U8(78), |
- B(Ldar), R(13), |
+ B(Ldar), R(11), |
B(Throw), |
- B(Ldar), R(13), |
+ B(Ldar), R(11), |
B(PopContext), R(2), |
B(LdaZero), |
B(StaContextSlot), R(1), U8(9), |
- B(Wide), B(Jump), U16(-210), |
+ B(Wide), B(Jump), U16(-205), |
B(Jump), U8(49), |
B(Star), R(11), |
B(LdaConstant), U8(10), |
@@ -621,9 +615,9 @@ constant pool: [ |
kInstanceTypeDontCare, |
] |
handlers: [ |
- [39, 704, 710], |
- [154, 440, 446], |
- [157, 391, 393], |
- [548, 563, 565], |
+ [36, 691, 697], |
+ [146, 427, 433], |
+ [149, 378, 380], |
+ [535, 550, 552], |
] |