| 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],
|
| ]
|
|
|
|
|