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 f09af84f6fef3bf0f6a19a23b659a912dc3ba641..361ea44561d97e1911929e18aae7135b5b90098d 100644 |
--- a/test/cctest/interpreter/bytecode_expectations/Generators.golden |
+++ b/test/cctest/interpreter/bytecode_expectations/Generators.golden |
@@ -16,7 +16,7 @@ snippet: " |
" |
frame size: 11 |
parameter count: 1 |
-bytecode array length: 199 |
+bytecode array length: 202 |
bytecodes: [ |
B(Ldar), R(new_target), |
B(JumpIfUndefined), U8(20), |
@@ -24,7 +24,7 @@ bytecodes: [ |
B(Star), R(1), |
B(LdaZero), |
B(TestEqualStrict), R(1), |
- B(JumpIfTrue), U8(55), |
+ B(JumpIfTrue), U8(56), |
B(LdaSmi), U8(76), |
B(Star), R(2), |
B(CallRuntime), U16(Runtime::kAbort), R(2), U8(1), |
@@ -34,13 +34,14 @@ bytecodes: [ |
B(StaContextSlot), R(context), U8(4), |
/* 11 E> */ B(StackCheck), |
B(Mov), R(context), R(4), |
- B(Ldar), R(closure), |
- B(Star), R(5), |
- B(LdrContextSlot), R(context), U8(4), R(6), |
+ B(LdaContextSlot), R(context), U8(4), |
+ B(Star), R(6), |
+ B(Mov), R(closure), R(5), |
B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2), |
B(StaContextSlot), R(context), U8(5), |
B(Star), R(5), |
- B(LdrContextSlot), R(context), U8(5), R(6), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(6), |
B(LdaZero), |
B(SuspendGenerator), R(6), |
B(Ldar), R(5), |
@@ -58,17 +59,18 @@ bytecodes: [ |
B(TestEqualStrict), R(8), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(7), R(9), |
B(LdaTrue), |
B(Star), R(10), |
+ B(Mov), R(7), R(9), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(9), U8(2), |
B(Star), R(3), |
B(LdaZero), |
B(Star), R(2), |
- B(Jump), U8(35), |
+ B(Jump), U8(36), |
B(Ldar), R(7), |
B(Throw), |
- B(LdrUndefined), R(5), |
+ B(LdaUndefined), |
+ B(Star), R(5), |
B(LdaTrue), |
B(Star), R(6), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), |
@@ -84,7 +86,8 @@ bytecodes: [ |
B(Star), R(2), |
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), |
B(Star), R(4), |
- B(LdrContextSlot), R(context), U8(5), R(5), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(5), |
B(CallRuntime), U16(Runtime::k_GeneratorClose), R(5), U8(1), |
B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1), |
B(LdaZero), |
@@ -109,7 +112,7 @@ bytecodes: [ |
constant pool: [ |
] |
handlers: [ |
- [38, 136, 142], |
+ [38, 138, 144], |
] |
--- |
@@ -119,7 +122,7 @@ snippet: " |
" |
frame size: 11 |
parameter count: 1 |
-bytecode array length: 292 |
+bytecode array length: 296 |
bytecodes: [ |
B(Ldar), R(new_target), |
B(JumpIfUndefined), U8(26), |
@@ -127,7 +130,7 @@ bytecodes: [ |
B(Star), R(1), |
B(LdaZero), |
B(TestEqualStrict), R(1), |
- B(JumpIfTrue), U8(61), |
+ B(JumpIfTrue), U8(62), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(1), |
B(JumpIfTrueConstant), U8(0), |
@@ -140,13 +143,14 @@ bytecodes: [ |
B(StaContextSlot), R(context), U8(4), |
/* 11 E> */ B(StackCheck), |
B(Mov), R(context), R(4), |
- B(Ldar), R(closure), |
- B(Star), R(5), |
- B(LdrContextSlot), R(context), U8(4), R(6), |
+ B(LdaContextSlot), R(context), U8(4), |
+ B(Star), R(6), |
+ B(Mov), R(closure), R(5), |
B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2), |
B(StaContextSlot), R(context), U8(5), |
B(Star), R(5), |
- B(LdrContextSlot), R(context), U8(5), R(6), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(6), |
B(LdaZero), |
B(SuspendGenerator), R(6), |
B(Ldar), R(5), |
@@ -164,14 +168,14 @@ bytecodes: [ |
B(TestEqualStrict), R(8), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(7), R(9), |
B(LdaTrue), |
B(Star), R(10), |
+ B(Mov), R(7), R(9), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(9), U8(2), |
B(Star), R(3), |
B(LdaZero), |
B(Star), R(2), |
- B(Jump), U8(113), |
+ B(Jump), U8(115), |
B(Ldar), R(7), |
B(Throw), |
/* 16 S> */ B(LdaSmi), U8(42), |
@@ -180,7 +184,8 @@ bytecodes: [ |
B(Star), R(6), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), |
B(Star), R(7), |
- B(LdrContextSlot), R(context), U8(5), R(5), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(5), |
B(LdaSmi), U8(1), |
B(SuspendGenerator), R(5), |
B(Ldar), R(7), |
@@ -198,17 +203,18 @@ bytecodes: [ |
B(TestEqualStrict), R(8), |
B(JumpIfTrue), U8(23), |
B(Jump), U8(2), |
- B(Mov), R(6), R(9), |
B(LdaTrue), |
B(Star), R(10), |
+ B(Mov), R(6), R(9), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(9), U8(2), |
B(Star), R(3), |
B(LdaSmi), U8(1), |
B(Star), R(2), |
- B(Jump), U8(35), |
+ B(Jump), U8(36), |
B(Ldar), R(6), |
B(Throw), |
- B(LdrUndefined), R(5), |
+ B(LdaUndefined), |
+ B(Star), R(5), |
B(LdaTrue), |
B(Star), R(6), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), |
@@ -224,7 +230,8 @@ bytecodes: [ |
B(Star), R(2), |
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), |
B(Star), R(4), |
- B(LdrContextSlot), R(context), U8(5), R(5), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(5), |
B(CallRuntime), U16(Runtime::k_GeneratorClose), R(5), U8(1), |
B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1), |
B(LdaZero), |
@@ -255,7 +262,7 @@ constant pool: [ |
kInstanceTypeDontCare, |
] |
handlers: [ |
- [44, 220, 226], |
+ [44, 223, 229], |
] |
--- |
@@ -265,7 +272,7 @@ snippet: " |
" |
frame size: 17 |
parameter count: 1 |
-bytecode array length: 784 |
+bytecode array length: 801 |
bytecodes: [ |
B(Ldar), R(new_target), |
B(JumpIfUndefined), U8(26), |
@@ -273,7 +280,7 @@ bytecodes: [ |
B(Star), R(3), |
B(LdaZero), |
B(TestEqualStrict), R(3), |
- B(JumpIfTrue), U8(61), |
+ B(JumpIfTrue), U8(62), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(3), |
B(JumpIfTrueConstant), U8(3), |
@@ -286,13 +293,14 @@ bytecodes: [ |
B(StaContextSlot), R(context), U8(4), |
/* 11 E> */ B(StackCheck), |
B(Mov), R(context), R(6), |
- B(Ldar), R(closure), |
- B(Star), R(7), |
- B(LdrContextSlot), R(context), U8(4), R(8), |
+ B(LdaContextSlot), R(context), U8(4), |
+ B(Star), R(8), |
+ B(Mov), R(closure), R(7), |
B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(7), U8(2), |
B(StaContextSlot), R(context), U8(5), |
B(Star), R(7), |
- B(LdrContextSlot), R(context), U8(5), R(8), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(8), |
B(LdaZero), |
B(SuspendGenerator), R(8), |
B(Ldar), R(7), |
@@ -310,9 +318,9 @@ bytecodes: [ |
B(TestEqualStrict), R(10), |
B(JumpIfTrue), U8(22), |
B(Jump), U8(2), |
- B(Mov), R(9), R(11), |
B(LdaTrue), |
B(Star), R(12), |
+ B(Mov), R(9), R(11), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(11), U8(2), |
B(Star), R(5), |
B(LdaZero), |
@@ -322,8 +330,7 @@ bytecodes: [ |
B(Throw), |
B(LdaConstant), U8(0), |
B(Star), R(7), |
- B(Ldar), R(closure), |
- B(Star), R(8), |
+ B(Mov), R(closure), R(8), |
B(CallRuntime), U16(Runtime::kPushBlockContext), R(7), U8(2), |
B(PushContext), R(1), |
B(LdaTheHole), |
@@ -337,7 +344,8 @@ bytecodes: [ |
/* 30 S> */ B(CreateArrayLiteral), U8(1), U8(0), U8(3), |
B(Star), R(12), |
/* 30 E> */ B(LdaConstant), U8(2), |
- B(LdrKeyedProperty), R(12), U8(3), R(11), |
+ B(LdaKeyedProperty), R(12), U8(3), |
+ B(Star), R(11), |
/* 30 E> */ B(Call), R(11), R(12), U8(1), U8(1), |
/* 30 E> */ B(StaContextSlot), R(1), U8(7), |
B(LdaSmi), U8(-2), |
@@ -349,30 +357,34 @@ bytecodes: [ |
B(LdaSmi), U8(76), |
B(Star), R(11), |
B(CallRuntime), U16(Runtime::kAbort), R(11), U8(1), |
- /* 27 S> */ B(LdrContextSlot), R(1), U8(7), R(13), |
- B(LdrNamedProperty), R(13), U8(4), U8(7), R(12), |
+ /* 27 S> */ B(LdaContextSlot), R(1), U8(7), |
+ B(Star), R(13), |
+ B(LdaNamedProperty), R(13), U8(4), U8(7), |
+ B(Star), R(12), |
/* 27 E> */ B(Call), R(12), R(13), U8(1), U8(5), |
/* 27 E> */ B(StaContextSlot), R(1), U8(8), |
B(Star), R(11), |
B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(11), U8(1), |
B(ToBooleanLogicalNot), |
- B(JumpIfFalse), U8(11), |
- B(LdrContextSlot), R(1), U8(8), R(11), |
+ B(JumpIfFalse), U8(12), |
+ B(LdaContextSlot), R(1), U8(8), |
+ B(Star), R(11), |
B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(11), U8(1), |
- B(LdrContextSlot), R(1), U8(8), R(11), |
+ B(LdaContextSlot), R(1), U8(8), |
+ B(Star), R(11), |
B(LdaNamedProperty), R(11), U8(5), U8(9), |
B(JumpIfToBooleanTrueConstant), U8(10), |
B(LdaSmi), U8(2), |
B(StaContextSlot), R(1), U8(9), |
- B(LdrContextSlot), R(1), U8(8), R(11), |
+ B(LdaContextSlot), R(1), U8(8), |
+ B(Star), R(11), |
B(LdaNamedProperty), R(11), U8(6), U8(11), |
B(StaContextSlot), R(1), U8(6), |
B(LdaContextSlot), R(1), U8(10), |
/* 16 E> */ B(StackCheck), |
B(LdaConstant), U8(7), |
B(Star), R(11), |
- B(Ldar), R(closure), |
- B(Star), R(12), |
+ B(Mov), R(closure), R(12), |
B(CallRuntime), U16(Runtime::kPushBlockContext), R(11), U8(2), |
B(PushContext), R(2), |
B(LdaTheHole), |
@@ -389,7 +401,8 @@ bytecodes: [ |
B(Star), R(12), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(11), U8(2), |
B(Star), R(13), |
- B(LdrContextSlot), R(1), U8(5), R(11), |
+ B(LdaContextSlot), R(1), U8(5), |
+ B(Star), R(11), |
B(LdaSmi), U8(1), |
B(SuspendGenerator), R(11), |
B(Ldar), R(13), |
@@ -407,9 +420,9 @@ bytecodes: [ |
B(TestEqualStrict), R(14), |
B(JumpIfTrue), U8(36), |
B(Jump), U8(2), |
- B(Mov), R(12), R(15), |
B(LdaTrue), |
B(Star), R(16), |
+ B(Mov), R(12), R(15), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(15), U8(2), |
B(PopContext), R(2), |
B(PopContext), R(2), |
@@ -421,30 +434,31 @@ bytecodes: [ |
B(Star), R(8), |
B(LdaZero), |
B(Star), R(7), |
- B(Jump), U8(76), |
+ B(Jump), U8(77), |
B(Ldar), R(12), |
B(Throw), |
B(Ldar), R(12), |
B(PopContext), R(2), |
B(LdaZero), |
B(StaContextSlot), R(1), U8(9), |
- B(Wide), B(Jump), U16(-224), |
- B(Jump), U8(47), |
+ B(Wide), B(Jump), U16(-229), |
+ B(Jump), U8(48), |
B(Star), R(12), |
B(LdaConstant), U8(11), |
B(Star), R(11), |
- B(Ldar), R(closure), |
- B(Star), R(13), |
+ B(Mov), R(closure), R(13), |
B(CallRuntime), U16(Runtime::kPushCatchContext), R(11), U8(3), |
B(Star), R(10), |
B(PushContext), R(2), |
- B(LdrContextSlot), R(1), U8(9), R(11), |
+ B(LdaContextSlot), R(1), U8(9), |
+ B(Star), R(11), |
B(LdaSmi), U8(2), |
B(TestEqualStrict), R(11), |
B(JumpIfFalse), U8(7), |
B(LdaSmi), U8(1), |
B(StaContextSlot), R(1), U8(9), |
- B(LdrContextSlot), R(context), U8(4), R(11), |
+ B(LdaContextSlot), R(context), U8(4), |
+ B(Star), R(11), |
B(CallRuntime), U16(Runtime::kReThrow), R(11), U8(1), |
B(PopContext), R(2), |
B(LdaSmi), U8(-1), |
@@ -455,27 +469,32 @@ bytecodes: [ |
B(Star), R(7), |
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), |
B(Star), R(9), |
- B(LdrContextSlot), R(1), U8(9), R(10), |
+ B(LdaContextSlot), R(1), U8(9), |
+ B(Star), R(10), |
B(LdaZero), |
B(TestEqualStrict), R(10), |
- B(JumpIfTrue), U8(9), |
- B(LdrContextSlot), R(1), U8(7), R(10), |
+ B(JumpIfTrue), U8(10), |
+ B(LdaContextSlot), R(1), U8(7), |
+ B(Star), R(10), |
B(LdaUndefined), |
B(TestEqualStrict), R(10), |
B(ToBooleanLogicalNot), |
B(JumpIfFalseConstant), U8(16), |
- B(LdrContextSlot), R(1), U8(7), R(10), |
+ B(LdaContextSlot), R(1), U8(7), |
+ B(Star), R(10), |
B(LdaNamedProperty), R(10), U8(12), U8(13), |
B(StaContextSlot), R(1), U8(11), |
- B(LdrContextSlot), R(1), U8(11), R(10), |
+ B(LdaContextSlot), R(1), U8(11), |
+ B(Star), R(10), |
B(LdaNull), |
B(TestEqual), R(10), |
B(JumpIfFalse), U8(4), |
B(JumpConstant), U8(15), |
- B(LdrContextSlot), R(1), U8(9), R(10), |
+ B(LdaContextSlot), R(1), U8(9), |
+ B(Star), R(10), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(10), |
- B(JumpIfFalse), U8(80), |
+ B(JumpIfFalse), U8(81), |
B(LdaContextSlot), R(1), U8(11), |
B(TypeOf), |
B(Star), R(10), |
@@ -490,31 +509,36 @@ bytecodes: [ |
B(CallRuntime), U16(Runtime::kNewTypeError), R(10), U8(2), |
B(Throw), |
B(Mov), R(context), R(10), |
- B(LdrContextSlot), R(1), U8(11), R(11), |
- B(LdrContextSlot), R(1), U8(7), R(12), |
+ B(LdaContextSlot), R(1), U8(11), |
+ B(Star), R(11), |
+ B(LdaContextSlot), R(1), U8(7), |
+ B(Star), R(12), |
B(CallRuntime), U16(Runtime::k_Call), R(11), U8(2), |
- B(Jump), U8(30), |
+ B(Jump), U8(29), |
B(Star), R(12), |
B(LdaConstant), U8(11), |
B(Star), R(11), |
- B(Ldar), R(closure), |
- B(Star), R(13), |
+ B(Mov), R(closure), R(13), |
B(CallRuntime), U16(Runtime::kPushCatchContext), R(11), U8(3), |
B(Star), R(10), |
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), |
B(Ldar), R(10), |
B(PushContext), R(2), |
B(PopContext), R(2), |
- B(Jump), U8(40), |
- B(LdrContextSlot), R(1), U8(11), R(10), |
- B(LdrContextSlot), R(1), U8(7), R(11), |
+ B(Jump), U8(44), |
+ B(LdaContextSlot), R(1), U8(11), |
+ B(Star), R(10), |
+ B(LdaContextSlot), R(1), U8(7), |
+ B(Star), R(11), |
B(CallRuntime), U16(Runtime::k_Call), R(10), U8(2), |
B(StaContextSlot), R(1), U8(12), |
- B(LdrContextSlot), R(1), U8(12), R(10), |
+ B(LdaContextSlot), R(1), U8(12), |
+ B(Star), R(10), |
B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(10), U8(1), |
B(JumpIfToBooleanFalse), U8(4), |
- B(Jump), U8(11), |
- B(LdrContextSlot), R(1), U8(12), R(10), |
+ B(Jump), U8(12), |
+ B(LdaContextSlot), R(1), U8(12), |
+ B(Star), R(10), |
B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(10), U8(1), |
B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(9), U8(1), |
B(LdaZero), |
@@ -522,24 +546,23 @@ bytecodes: [ |
B(JumpIfTrue), U8(10), |
B(LdaSmi), U8(1), |
B(TestEqualStrict), R(7), |
- B(JumpIfTrue), U8(18), |
- B(Jump), U8(30), |
- B(Ldar), R(8), |
+ B(JumpIfTrue), U8(17), |
+ B(Jump), U8(28), |
B(PopContext), R(1), |
B(PopContext), R(1), |
- B(Star), R(5), |
B(LdaSmi), U8(1), |
B(Star), R(4), |
+ B(Mov), R(8), R(5), |
B(Jump), U8(48), |
- B(Ldar), R(8), |
B(PopContext), R(1), |
B(PopContext), R(1), |
- B(Star), R(5), |
B(LdaSmi), U8(2), |
B(Star), R(4), |
- B(Jump), U8(34), |
+ B(Mov), R(8), R(5), |
+ B(Jump), U8(35), |
B(PopContext), R(1), |
- B(LdrUndefined), R(7), |
+ B(LdaUndefined), |
+ B(Star), R(7), |
B(LdaTrue), |
B(Star), R(8), |
B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(7), U8(2), |
@@ -555,7 +578,8 @@ bytecodes: [ |
B(Star), R(4), |
B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), |
B(Star), R(6), |
- B(LdrContextSlot), R(context), U8(5), R(7), |
+ B(LdaContextSlot), R(context), U8(5), |
+ B(Star), R(7), |
B(CallRuntime), U16(Runtime::k_GeneratorClose), R(7), U8(1), |
B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(6), U8(1), |
B(LdaZero), |
@@ -608,9 +632,9 @@ constant pool: [ |
kInstanceTypeDontCare, |
] |
handlers: [ |
- [44, 703, 709], |
- [154, 451, 457], |
- [157, 404, 406], |
- [554, 567, 569], |
+ [44, 719, 725], |
+ [154, 458, 464], |
+ [157, 410, 412], |
+ [566, 581, 583], |
] |