| 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 aa13e49444696407f0467c859699ff599160809a..bd94b9eb2d074ab38a0d42006cd08733ec2bf7f7 100644 | 
| --- a/test/cctest/interpreter/bytecode_expectations/Generators.golden | 
| +++ b/test/cctest/interpreter/bytecode_expectations/Generators.golden | 
| @@ -15,7 +15,7 @@ snippet: " | 
| " | 
| frame size: 11 | 
| parameter count: 1 | 
| -bytecode array length: 203 | 
| +bytecode array length: 199 | 
| bytecodes: [ | 
| B(Ldar), R(new_target), | 
| B(JumpIfUndefined), U8(20), | 
| @@ -23,7 +23,7 @@ bytecodes: [ | 
| B(Star), R(1), | 
| B(LdaZero), | 
| B(TestEqualStrict), R(1), | 
| -                B(JumpIfTrue), U8(57), | 
| +                B(JumpIfTrue), U8(55), | 
| B(LdaSmi), U8(76), | 
| B(Star), R(2), | 
| B(CallRuntime), U16(Runtime::kAbort), R(2), U8(1), | 
| @@ -35,13 +35,11 @@ bytecodes: [ | 
| B(Mov), R(context), R(4), | 
| B(Ldar), R(closure), | 
| B(Star), R(5), | 
| -                B(LdaContextSlot), R(context), U8(4), | 
| -                B(Star), R(6), | 
| +                B(LdrContextSlot), R(context), U8(4), R(6), | 
| B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2), | 
| B(StaContextSlot), R(context), U8(5), | 
| B(Star), R(5), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(6), | 
| +                B(LdrContextSlot), R(context), U8(5), R(6), | 
| B(LdaZero), | 
| B(SuspendGenerator), R(6), | 
| B(Ldar), R(5), | 
| @@ -66,11 +64,10 @@ bytecodes: [ | 
| B(Star), R(3), | 
| B(LdaZero), | 
| B(Star), R(2), | 
| -                B(Jump), U8(36), | 
| +                B(Jump), U8(35), | 
| B(Ldar), R(7), | 
| B(Throw), | 
| -                B(LdaUndefined), | 
| -                B(Star), R(5), | 
| +                B(LdrUndefined), R(5), | 
| B(LdaTrue), | 
| B(Star), R(6), | 
| B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), | 
| @@ -86,8 +83,7 @@ bytecodes: [ | 
| B(Star), R(2), | 
| B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), | 
| B(Star), R(4), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(5), | 
| +                B(LdrContextSlot), R(context), U8(5), R(5), | 
| B(CallRuntime), U16(Runtime::k_GeneratorClose), R(5), U8(1), | 
| B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1), | 
| B(LdaZero), | 
| @@ -112,7 +108,7 @@ bytecodes: [ | 
| constant pool: [ | 
| ] | 
| handlers: [ | 
| -  [38, 139, 145], | 
| +  [38, 136, 142], | 
| ] | 
|  | 
| --- | 
| @@ -121,7 +117,7 @@ snippet: " | 
| " | 
| frame size: 11 | 
| parameter count: 1 | 
| -bytecode array length: 297 | 
| +bytecode array length: 292 | 
| bytecodes: [ | 
| B(Ldar), R(new_target), | 
| B(JumpIfUndefined), U8(26), | 
| @@ -129,7 +125,7 @@ bytecodes: [ | 
| B(Star), R(1), | 
| B(LdaZero), | 
| B(TestEqualStrict), R(1), | 
| -                B(JumpIfTrue), U8(63), | 
| +                B(JumpIfTrue), U8(61), | 
| B(LdaSmi), U8(1), | 
| B(TestEqualStrict), R(1), | 
| B(JumpIfTrueConstant), U8(0), | 
| @@ -144,13 +140,11 @@ bytecodes: [ | 
| B(Mov), R(context), R(4), | 
| B(Ldar), R(closure), | 
| B(Star), R(5), | 
| -                B(LdaContextSlot), R(context), U8(4), | 
| -                B(Star), R(6), | 
| +                B(LdrContextSlot), R(context), U8(4), R(6), | 
| B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(5), U8(2), | 
| B(StaContextSlot), R(context), U8(5), | 
| B(Star), R(5), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(6), | 
| +                B(LdrContextSlot), R(context), U8(5), R(6), | 
| B(LdaZero), | 
| B(SuspendGenerator), R(6), | 
| B(Ldar), R(5), | 
| @@ -175,7 +169,7 @@ bytecodes: [ | 
| B(Star), R(3), | 
| B(LdaZero), | 
| B(Star), R(2), | 
| -                B(Jump), U8(115), | 
| +                B(Jump), U8(113), | 
| B(Ldar), R(7), | 
| B(Throw), | 
| /*   16 S> */ B(LdaSmi), U8(42), | 
| @@ -184,8 +178,7 @@ bytecodes: [ | 
| B(Star), R(6), | 
| B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), | 
| B(Star), R(7), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(5), | 
| +                B(LdrContextSlot), R(context), U8(5), R(5), | 
| B(LdaSmi), U8(1), | 
| B(SuspendGenerator), R(5), | 
| B(Ldar), R(7), | 
| @@ -210,11 +203,10 @@ bytecodes: [ | 
| B(Star), R(3), | 
| B(LdaSmi), U8(1), | 
| B(Star), R(2), | 
| -                B(Jump), U8(36), | 
| +                B(Jump), U8(35), | 
| B(Ldar), R(6), | 
| B(Throw), | 
| -                B(LdaUndefined), | 
| -                B(Star), R(5), | 
| +                B(LdrUndefined), R(5), | 
| B(LdaTrue), | 
| B(Star), R(6), | 
| B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(5), U8(2), | 
| @@ -230,8 +222,7 @@ bytecodes: [ | 
| B(Star), R(2), | 
| B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), | 
| B(Star), R(4), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(5), | 
| +                B(LdrContextSlot), R(context), U8(5), R(5), | 
| B(CallRuntime), U16(Runtime::k_GeneratorClose), R(5), U8(1), | 
| B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(4), U8(1), | 
| B(LdaZero), | 
| @@ -262,7 +253,7 @@ constant pool: [ | 
| kInstanceTypeDontCare, | 
| ] | 
| handlers: [ | 
| -  [44, 224, 230], | 
| +  [44, 220, 226], | 
| ] | 
|  | 
| --- | 
| @@ -271,7 +262,7 @@ snippet: " | 
| " | 
| frame size: 17 | 
| parameter count: 1 | 
| -bytecode array length: 808 | 
| +bytecode array length: 784 | 
| bytecodes: [ | 
| B(Ldar), R(new_target), | 
| B(JumpIfUndefined), U8(26), | 
| @@ -279,7 +270,7 @@ bytecodes: [ | 
| B(Star), R(3), | 
| B(LdaZero), | 
| B(TestEqualStrict), R(3), | 
| -                B(JumpIfTrue), U8(63), | 
| +                B(JumpIfTrue), U8(61), | 
| B(LdaSmi), U8(1), | 
| B(TestEqualStrict), R(3), | 
| B(JumpIfTrueConstant), U8(3), | 
| @@ -294,13 +285,11 @@ bytecodes: [ | 
| B(Mov), R(context), R(6), | 
| B(Ldar), R(closure), | 
| B(Star), R(7), | 
| -                B(LdaContextSlot), R(context), U8(4), | 
| -                B(Star), R(8), | 
| +                B(LdrContextSlot), R(context), U8(4), R(8), | 
| B(CallRuntime), U16(Runtime::kCreateJSGeneratorObject), R(7), U8(2), | 
| B(StaContextSlot), R(context), U8(5), | 
| B(Star), R(7), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(8), | 
| +                B(LdrContextSlot), R(context), U8(5), R(8), | 
| B(LdaZero), | 
| B(SuspendGenerator), R(8), | 
| B(Ldar), R(7), | 
| @@ -345,8 +334,7 @@ bytecodes: [ | 
| /*   30 S> */ B(CreateArrayLiteral), U8(1), U8(0), U8(3), | 
| B(Star), R(12), | 
| /*   30 E> */ B(LdaConstant), U8(2), | 
| -                B(KeyedLoadIC), R(12), U8(3), | 
| -                B(Star), R(11), | 
| +                B(LdrKeyedProperty), R(12), U8(3), 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), | 
| @@ -358,27 +346,22 @@ bytecodes: [ | 
| B(LdaSmi), U8(76), | 
| B(Star), R(11), | 
| B(CallRuntime), U16(Runtime::kAbort), R(11), U8(1), | 
| -  /*   27 S> */ B(LdaContextSlot), R(1), U8(7), | 
| -                B(Star), R(13), | 
| -                B(LoadIC), R(13), U8(4), U8(7), | 
| -                B(Star), R(12), | 
| +  /*   27 S> */ B(LdrContextSlot), R(1), U8(7), R(13), | 
| +                B(LdrNamedProperty), R(13), U8(4), U8(7), 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(12), | 
| -                B(LdaContextSlot), R(1), U8(8), | 
| -                B(Star), R(11), | 
| +                B(JumpIfFalse), U8(11), | 
| +                B(LdrContextSlot), R(1), U8(8), R(11), | 
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(11), U8(1), | 
| -                B(LdaContextSlot), R(1), U8(8), | 
| -                B(Star), R(11), | 
| +                B(LdrContextSlot), R(1), U8(8), R(11), | 
| B(LoadIC), R(11), U8(5), U8(9), | 
| B(JumpIfToBooleanTrueConstant), U8(10), | 
| B(LdaSmi), U8(2), | 
| B(StaContextSlot), R(1), U8(9), | 
| -                B(LdaContextSlot), R(1), U8(8), | 
| -                B(Star), R(11), | 
| +                B(LdrContextSlot), R(1), U8(8), R(11), | 
| B(LoadIC), R(11), U8(6), U8(11), | 
| B(StaContextSlot), R(1), U8(6), | 
| B(LdaContextSlot), R(1), U8(10), | 
| @@ -403,8 +386,7 @@ bytecodes: [ | 
| B(Star), R(12), | 
| B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(11), U8(2), | 
| B(Star), R(13), | 
| -                B(LdaContextSlot), R(1), U8(5), | 
| -                B(Star), R(11), | 
| +                B(LdrContextSlot), R(1), U8(5), R(11), | 
| B(LdaSmi), U8(1), | 
| B(SuspendGenerator), R(11), | 
| B(Ldar), R(13), | 
| @@ -436,15 +418,15 @@ bytecodes: [ | 
| B(Star), R(8), | 
| B(LdaZero), | 
| B(Star), R(7), | 
| -                B(Jump), U8(78), | 
| +                B(Jump), U8(76), | 
| 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(-230), | 
| -                B(Jump), U8(49), | 
| +                B(Wide), B(Jump), U16(-224), | 
| +                B(Jump), U8(47), | 
| B(Star), R(12), | 
| B(LdaConstant), U8(11), | 
| B(Star), R(11), | 
| @@ -453,15 +435,13 @@ bytecodes: [ | 
| B(CallRuntime), U16(Runtime::kPushCatchContext), R(11), U8(3), | 
| B(Star), R(10), | 
| B(PushContext), R(2), | 
| -                B(LdaContextSlot), R(1), U8(9), | 
| -                B(Star), R(11), | 
| +                B(LdrContextSlot), R(1), U8(9), 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(LdaContextSlot), R(context), U8(4), | 
| -                B(Star), R(11), | 
| +                B(LdrContextSlot), R(context), U8(4), R(11), | 
| B(CallRuntime), U16(Runtime::kReThrow), R(11), U8(1), | 
| B(PopContext), R(2), | 
| B(LdaSmi), U8(-1), | 
| @@ -472,32 +452,27 @@ bytecodes: [ | 
| B(Star), R(7), | 
| B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), | 
| B(Star), R(9), | 
| -                B(LdaContextSlot), R(1), U8(9), | 
| -                B(Star), R(10), | 
| +                B(LdrContextSlot), R(1), U8(9), R(10), | 
| B(LdaZero), | 
| B(TestEqualStrict), R(10), | 
| -                B(JumpIfTrue), U8(10), | 
| -                B(LdaContextSlot), R(1), U8(7), | 
| -                B(Star), R(10), | 
| +                B(JumpIfTrue), U8(9), | 
| +                B(LdrContextSlot), R(1), U8(7), R(10), | 
| B(LdaUndefined), | 
| B(TestEqualStrict), R(10), | 
| B(ToBooleanLogicalNot), | 
| B(JumpIfFalseConstant), U8(16), | 
| -                B(LdaContextSlot), R(1), U8(7), | 
| -                B(Star), R(10), | 
| +                B(LdrContextSlot), R(1), U8(7), R(10), | 
| B(LoadIC), R(10), U8(12), U8(13), | 
| B(StaContextSlot), R(1), U8(11), | 
| -                B(LdaContextSlot), R(1), U8(11), | 
| -                B(Star), R(10), | 
| +                B(LdrContextSlot), R(1), U8(11), R(10), | 
| B(LdaNull), | 
| B(TestEqual), R(10), | 
| B(JumpIfFalse), U8(4), | 
| B(JumpConstant), U8(15), | 
| -                B(LdaContextSlot), R(1), U8(9), | 
| -                B(Star), R(10), | 
| +                B(LdrContextSlot), R(1), U8(9), R(10), | 
| B(LdaSmi), U8(1), | 
| B(TestEqualStrict), R(10), | 
| -                B(JumpIfFalse), U8(82), | 
| +                B(JumpIfFalse), U8(80), | 
| B(LdaContextSlot), R(1), U8(11), | 
| B(TypeOf), | 
| B(Star), R(10), | 
| @@ -512,10 +487,8 @@ bytecodes: [ | 
| B(CallRuntime), U16(Runtime::kNewTypeError), R(10), U8(2), | 
| B(Throw), | 
| B(Mov), R(context), R(10), | 
| -                B(LdaContextSlot), R(1), U8(11), | 
| -                B(Star), R(11), | 
| -                B(LdaContextSlot), R(1), U8(7), | 
| -                B(Star), R(12), | 
| +                B(LdrContextSlot), R(1), U8(11), R(11), | 
| +                B(LdrContextSlot), R(1), U8(7), R(12), | 
| B(CallRuntime), U16(Runtime::k_Call), R(11), U8(2), | 
| B(Jump), U8(30), | 
| B(Star), R(12), | 
| @@ -529,20 +502,16 @@ bytecodes: [ | 
| B(Ldar), R(10), | 
| B(PushContext), R(2), | 
| B(PopContext), R(2), | 
| -                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(Jump), U8(40), | 
| +                B(LdrContextSlot), R(1), U8(11), R(10), | 
| +                B(LdrContextSlot), R(1), U8(7), R(11), | 
| B(CallRuntime), U16(Runtime::k_Call), R(10), U8(2), | 
| B(StaContextSlot), R(1), U8(12), | 
| -                B(LdaContextSlot), R(1), U8(12), | 
| -                B(Star), R(10), | 
| +                B(LdrContextSlot), R(1), U8(12), R(10), | 
| B(InvokeIntrinsic), U16(Runtime::k_IsJSReceiver), R(10), U8(1), | 
| B(JumpIfToBooleanFalse), U8(4), | 
| -                B(Jump), U8(12), | 
| -                B(LdaContextSlot), R(1), U8(12), | 
| -                B(Star), R(10), | 
| +                B(Jump), U8(11), | 
| +                B(LdrContextSlot), R(1), U8(12), R(10), | 
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(10), U8(1), | 
| B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(9), U8(1), | 
| B(LdaZero), | 
| @@ -558,17 +527,16 @@ bytecodes: [ | 
| B(Star), R(5), | 
| B(LdaSmi), U8(1), | 
| B(Star), R(4), | 
| -                B(Jump), U8(49), | 
| +                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(35), | 
| +                B(Jump), U8(34), | 
| B(PopContext), R(1), | 
| -                B(LdaUndefined), | 
| -                B(Star), R(7), | 
| +                B(LdrUndefined), R(7), | 
| B(LdaTrue), | 
| B(Star), R(8), | 
| B(CallRuntime), U16(Runtime::k_CreateIterResultObject), R(7), U8(2), | 
| @@ -584,8 +552,7 @@ bytecodes: [ | 
| B(Star), R(4), | 
| B(CallRuntime), U16(Runtime::kInterpreterClearPendingMessage), R(0), U8(0), | 
| B(Star), R(6), | 
| -                B(LdaContextSlot), R(context), U8(5), | 
| -                B(Star), R(7), | 
| +                B(LdrContextSlot), R(context), U8(5), R(7), | 
| B(CallRuntime), U16(Runtime::k_GeneratorClose), R(7), U8(1), | 
| B(CallRuntime), U16(Runtime::kInterpreterSetPendingMessage), R(6), U8(1), | 
| B(LdaZero), | 
| @@ -638,9 +605,9 @@ constant pool: [ | 
| kInstanceTypeDontCare, | 
| ] | 
| handlers: [ | 
| -  [44, 726, 732], | 
| -  [156, 462, 468], | 
| -  [159, 413, 415], | 
| -  [570, 585, 587], | 
| +  [44, 703, 709], | 
| +  [154, 451, 457], | 
| +  [157, 404, 406], | 
| +  [554, 567, 569], | 
| ] | 
|  | 
|  |