2016-02-25 12:07:07 +00:00
|
|
|
#
|
|
|
|
# Autogenerated by generate-bytecode-expectations.
|
|
|
|
#
|
|
|
|
|
|
|
|
---
|
|
|
|
wrap: yes
|
2016-09-16 13:26:44 +00:00
|
|
|
test function name: f
|
2016-02-25 12:07:07 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
snippet: "
|
|
|
|
eval('var x = 10;'); return x;
|
|
|
|
"
|
2017-04-11 14:20:30 +00:00
|
|
|
frame size: 9
|
2016-02-25 12:07:07 +00:00
|
|
|
parameter count: 1
|
2017-04-11 14:20:30 +00:00
|
|
|
bytecode array length: 62
|
2016-02-25 12:07:07 +00:00
|
|
|
bytecodes: [
|
2016-08-03 14:41:47 +00:00
|
|
|
B(CreateFunctionContext), U8(3),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(PushContext), R(0),
|
|
|
|
B(Ldar), R(this),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(4),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(CreateMappedArguments),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(6),
|
2016-09-07 06:54:36 +00:00
|
|
|
B(Ldar), R(new_target),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(5),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 10 E> */ B(StackCheck),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 14 S> */ B(LdaLookupGlobalSlot), U8(0), U8(5), U8(1),
|
2016-11-14 13:34:26 +00:00
|
|
|
B(Star), R(1),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaConstant), U8(1),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(2),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaZero),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(6),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(10),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(7),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(14),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(8),
|
|
|
|
B(Mov), R(1), R(3),
|
|
|
|
B(Mov), R(2), R(4),
|
|
|
|
B(Mov), R(closure), R(5),
|
|
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(3), U8(6),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(Star), R(1),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 14 E> */ B(CallUndefinedReceiver1), R(1), R(2), U8(3),
|
|
|
|
/* 35 S> */ B(LdaLookupGlobalSlot), U8(2), U8(7), U8(1),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 45 S> */ B(Return),
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
constant pool: [
|
2016-09-06 16:10:19 +00:00
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["eval"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["var x = 10;"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["x"],
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
handlers: [
|
|
|
|
]
|
|
|
|
|
|
|
|
---
|
|
|
|
snippet: "
|
|
|
|
eval('var x = 10;'); return typeof x;
|
|
|
|
"
|
2017-04-11 14:20:30 +00:00
|
|
|
frame size: 9
|
2016-02-25 12:07:07 +00:00
|
|
|
parameter count: 1
|
2017-04-11 14:20:30 +00:00
|
|
|
bytecode array length: 63
|
2016-02-25 12:07:07 +00:00
|
|
|
bytecodes: [
|
2016-08-03 14:41:47 +00:00
|
|
|
B(CreateFunctionContext), U8(3),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(PushContext), R(0),
|
|
|
|
B(Ldar), R(this),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(4),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(CreateMappedArguments),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(6),
|
2016-09-07 06:54:36 +00:00
|
|
|
B(Ldar), R(new_target),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(5),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 10 E> */ B(StackCheck),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 14 S> */ B(LdaLookupGlobalSlot), U8(0), U8(5), U8(1),
|
2016-11-14 13:34:26 +00:00
|
|
|
B(Star), R(1),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaConstant), U8(1),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(2),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaZero),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(6),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(10),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(7),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(14),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(8),
|
|
|
|
B(Mov), R(1), R(3),
|
|
|
|
B(Mov), R(2), R(4),
|
|
|
|
B(Mov), R(closure), R(5),
|
|
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(3), U8(6),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(Star), R(1),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 14 E> */ B(CallUndefinedReceiver1), R(1), R(2), U8(3),
|
|
|
|
/* 35 S> */ B(LdaLookupGlobalSlotInsideTypeof), U8(2), U8(7), U8(1),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(TypeOf),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 52 S> */ B(Return),
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
constant pool: [
|
2016-09-06 16:10:19 +00:00
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["eval"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["var x = 10;"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["x"],
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
handlers: [
|
|
|
|
]
|
|
|
|
|
|
|
|
---
|
|
|
|
snippet: "
|
|
|
|
x = 20; return eval('');
|
|
|
|
"
|
2017-04-11 14:20:30 +00:00
|
|
|
frame size: 9
|
2016-02-25 12:07:07 +00:00
|
|
|
parameter count: 1
|
2017-04-11 14:20:30 +00:00
|
|
|
bytecode array length: 62
|
2016-02-25 12:07:07 +00:00
|
|
|
bytecodes: [
|
2016-08-03 14:41:47 +00:00
|
|
|
B(CreateFunctionContext), U8(3),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(PushContext), R(0),
|
|
|
|
B(Ldar), R(this),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(4),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(CreateMappedArguments),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(6),
|
2016-09-07 06:54:36 +00:00
|
|
|
B(Ldar), R(new_target),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(5),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 10 E> */ B(StackCheck),
|
2017-01-25 17:39:24 +00:00
|
|
|
/* 14 S> */ B(LdaSmi), I8(20),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 16 E> */ B(StaLookupSlotSloppy), U8(0),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 22 S> */ B(LdaLookupGlobalSlot), U8(1), U8(5), U8(1),
|
2016-11-14 13:34:26 +00:00
|
|
|
B(Star), R(1),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaConstant), U8(2),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(2),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(LdaZero),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(6),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(10),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(7),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(29),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(8),
|
|
|
|
B(Mov), R(1), R(3),
|
|
|
|
B(Mov), R(2), R(4),
|
|
|
|
B(Mov), R(closure), R(5),
|
|
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(3), U8(6),
|
2016-05-11 12:21:56 +00:00
|
|
|
B(Star), R(1),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 29 E> */ B(CallUndefinedReceiver1), R(1), R(2), U8(3),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 39 S> */ B(Return),
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
constant pool: [
|
2016-09-06 16:10:19 +00:00
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["x"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["eval"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE [""],
|
2016-02-25 12:07:07 +00:00
|
|
|
]
|
|
|
|
handlers: [
|
|
|
|
]
|
|
|
|
|
2016-09-16 13:26:44 +00:00
|
|
|
---
|
|
|
|
snippet: "
|
|
|
|
var x = 20;
|
|
|
|
f = function(){
|
|
|
|
eval('var x = 10');
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
f();
|
|
|
|
"
|
2017-04-11 14:20:30 +00:00
|
|
|
frame size: 9
|
2016-09-16 13:26:44 +00:00
|
|
|
parameter count: 1
|
2017-04-11 14:20:30 +00:00
|
|
|
bytecode array length: 62
|
2016-09-16 13:26:44 +00:00
|
|
|
bytecodes: [
|
|
|
|
B(CreateFunctionContext), U8(3),
|
|
|
|
B(PushContext), R(0),
|
|
|
|
B(Ldar), R(this),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(4),
|
2016-09-16 13:26:44 +00:00
|
|
|
B(CreateMappedArguments),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(6),
|
2016-09-16 13:26:44 +00:00
|
|
|
B(Ldar), R(new_target),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(5),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 38 E> */ B(StackCheck),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 44 S> */ B(LdaLookupGlobalSlot), U8(0), U8(5), U8(1),
|
2016-11-14 13:34:26 +00:00
|
|
|
B(Star), R(1),
|
2016-09-16 13:26:44 +00:00
|
|
|
B(LdaConstant), U8(1),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(2),
|
2016-09-16 13:26:44 +00:00
|
|
|
B(LdaZero),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(6),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(38),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(7),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(44),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(8),
|
|
|
|
B(Mov), R(1), R(3),
|
|
|
|
B(Mov), R(2), R(4),
|
|
|
|
B(Mov), R(closure), R(5),
|
|
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(3), U8(6),
|
2016-09-16 13:26:44 +00:00
|
|
|
B(Star), R(1),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 44 E> */ B(CallUndefinedReceiver1), R(1), R(2), U8(3),
|
2016-09-16 13:26:44 +00:00
|
|
|
/* 66 S> */ B(LdaLookupContextSlot), U8(2), U8(6), U8(1),
|
|
|
|
/* 76 S> */ B(Return),
|
|
|
|
]
|
|
|
|
constant pool: [
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["eval"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["var x = 10"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["x"],
|
|
|
|
]
|
|
|
|
handlers: [
|
|
|
|
]
|
|
|
|
|
2016-09-20 10:31:24 +00:00
|
|
|
---
|
|
|
|
snippet: "
|
|
|
|
x = 20;
|
|
|
|
f = function(){
|
|
|
|
eval('var x = 10');
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
f();
|
|
|
|
"
|
2017-04-11 14:20:30 +00:00
|
|
|
frame size: 9
|
2016-09-20 10:31:24 +00:00
|
|
|
parameter count: 1
|
2017-04-11 14:20:30 +00:00
|
|
|
bytecode array length: 62
|
2016-09-20 10:31:24 +00:00
|
|
|
bytecodes: [
|
|
|
|
B(CreateFunctionContext), U8(3),
|
|
|
|
B(PushContext), R(0),
|
|
|
|
B(Ldar), R(this),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(4),
|
2016-09-20 10:31:24 +00:00
|
|
|
B(CreateMappedArguments),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(6),
|
2016-09-20 10:31:24 +00:00
|
|
|
B(Ldar), R(new_target),
|
2016-10-28 10:10:32 +00:00
|
|
|
B(StaCurrentContextSlot), U8(5),
|
2016-09-20 10:31:24 +00:00
|
|
|
/* 34 E> */ B(StackCheck),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 40 S> */ B(LdaLookupGlobalSlot), U8(0), U8(5), U8(1),
|
2016-11-14 13:34:26 +00:00
|
|
|
B(Star), R(1),
|
2016-09-20 10:31:24 +00:00
|
|
|
B(LdaConstant), U8(1),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(2),
|
2016-09-20 10:31:24 +00:00
|
|
|
B(LdaZero),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(6),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(34),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(7),
|
Revert "[ignition] Add call bytecodes for undefined receiver"
This reverts commit 751e89359123df4f6e5f0b28b89fcdf63ed16a77.
Reason for revert: Breaks layout tests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/14885
See:
https://github.com/v8/v8/wiki/Blink-layout-tests
Original change's description:
> [ignition] Add call bytecodes for undefined receiver
>
> Adds a collection of call bytecodes which have an implicit undefined
> receiver argument, for cases such as global calls where we know that the
> receiver has to be undefined. This way we can skip an LdaUndefined,
> decrease bytecode register pressure, and set a more accurate
> ConvertReceiverMode on the interpreter and TurboFan call.
>
> As a side effect, the "normal" Call bytecode now becomes a rare case
> (only with calls and super property calls), so we get rid of its 0-2
> argument special cases and modify CallProperty[N] to use the
> NotNullOrUndefined ConvertReceiverMode.
>
> Change-Id: I9374a32fefd66fc0251b5193bae7a6b7dc31eefc
> Reviewed-on: https://chromium-review.googlesource.com/463287
> Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#44530}
TBR=rmcilroy@chromium.org,mstarzinger@chromium.org,leszeks@chromium.org,v8-reviews@googlegroups.com,v8-mips-ports@googlegroups.com,v8-ppc-ports@googlegroups.com,v8-x87-ports@googlegroups.com,bmeurer@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Change-Id: I7629dec609d0ec938ce7105d6c1c74884e5f9272
Reviewed-on: https://chromium-review.googlesource.com/474744
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#44548}
2017-04-11 06:26:10 +00:00
|
|
|
B(LdaSmi), I8(40),
|
2017-04-11 14:20:30 +00:00
|
|
|
B(Star), R(8),
|
|
|
|
B(Mov), R(1), R(3),
|
|
|
|
B(Mov), R(2), R(4),
|
|
|
|
B(Mov), R(closure), R(5),
|
|
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(3), U8(6),
|
2016-09-20 10:31:24 +00:00
|
|
|
B(Star), R(1),
|
2017-05-09 21:45:33 +00:00
|
|
|
/* 40 E> */ B(CallUndefinedReceiver1), R(1), R(2), U8(3),
|
|
|
|
/* 62 S> */ B(LdaLookupGlobalSlot), U8(2), U8(7), U8(1),
|
2016-09-20 10:31:24 +00:00
|
|
|
/* 72 S> */ B(Return),
|
|
|
|
]
|
|
|
|
constant pool: [
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["eval"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["var x = 10"],
|
|
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["x"],
|
|
|
|
]
|
|
|
|
handlers: [
|
|
|
|
]
|
|
|
|
|