v8/test/cctest/interpreter/bytecode_expectations/Switch.golden
oth 40511877eb [interpreter] Introduce binary op bytecodes for Smi operand.
Introduces fused bytecodes for fusing LdaSmi followed by a binary op bytecode.
The chosen bytecodes are used frequently in Octane: AddSmi, SubSmi,
BitwiseOrSmi, BitwiseAndSmi, ShiftLeftSmi, ShiftRightSmi.

There are additional code stubs for these operations that are biased towards
both the left hand and right hand operands being Smis.

BUG=v8:4280
LOG=N

Review-Url: https://codereview.chromium.org/2111923002
Cr-Commit-Position: refs/heads/master@{#37531}
2016-07-05 13:46:11 +00:00

521 lines
12 KiB
Plaintext

#
# Autogenerated by generate-bytecode-expectations.
#
---
pool type: number
execute: yes
wrap: yes
---
snippet: "
var a = 1;
switch(a) {
case 1: return 2;
case 2: return 3;
}
"
frame size: 3
parameter count: 1
bytecode array length: 32
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(1),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(2),
B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(7),
B(Jump), U8(8),
/* 66 S> */ B(LdaSmi), U8(2),
/* 97 S> */ B(Return),
/* 85 S> */ B(LdaSmi), U8(3),
/* 97 S> */ B(Return),
B(LdaUndefined),
/* 97 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case 1: a = 2; break;
case 2: a = 3; break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 38
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(1),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(2),
B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(10),
B(Jump), U8(14),
/* 66 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 73 S> */ B(Jump), U8(8),
/* 89 S> */ B(LdaSmi), U8(3),
B(Star), R(1),
/* 96 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 105 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case 1: a = 2; // fall-through
case 2: a = 3; break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 36
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(1),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(2),
B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(8),
B(Jump), U8(12),
/* 66 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 98 S> */ B(LdaSmi), U8(3),
B(Star), R(1),
/* 105 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 114 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case 2: break;
case 3: break;
default: a = 1; break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 36
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(2),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(3),
B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(6),
B(Jump), U8(6),
/* 66 S> */ B(Jump), U8(10),
/* 82 S> */ B(Jump), U8(8),
/* 99 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
/* 106 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 115 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(typeof(a)) {
case 2: a = 1; break;
case 3: a = 2; break;
default: a = 3; break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 45
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
/* 42 E> */ B(TypeOf),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(2),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(3),
B(TestEqualStrict), R(2),
B(JumpIfTrue), U8(10),
B(Jump), U8(14),
/* 74 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
/* 81 S> */ B(Jump), U8(14),
/* 97 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 104 S> */ B(Jump), U8(8),
/* 121 S> */ B(LdaSmi), U8(3),
B(Star), R(1),
/* 128 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 137 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case typeof(a): a = 1; break;
default: a = 2; break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 31
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(TypeOf),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(4),
B(Jump), U8(8),
/* 74 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
/* 81 S> */ B(Jump), U8(8),
/* 98 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 105 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 114 S> */ B(Return),
]
constant pool: [
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case 1:
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
a = 2;
break;
case 2:
a = 3;
break;
}
"
frame size: 3
parameter count: 1
bytecode array length: 290
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(1),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(1),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(2),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(2),
B(TestEqualStrict), R(2),
B(JumpIfTrueConstant), U8(0),
B(JumpConstant), U8(1),
/* 68 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 77 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 86 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 95 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 104 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 113 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 122 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 131 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 140 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 149 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 158 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 167 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 176 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 185 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 194 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 203 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 212 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 221 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 230 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 239 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 248 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 257 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 266 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 275 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 284 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 293 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 302 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 311 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 320 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 329 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 338 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 347 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 356 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 365 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 374 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 383 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 392 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 401 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 410 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 419 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 428 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 437 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 446 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 455 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 464 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 473 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 482 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 491 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 500 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 509 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 518 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 527 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 536 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 545 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 554 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 563 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 572 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 581 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 590 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 599 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 608 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 617 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 626 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 635 S> */ B(LdaSmi), U8(2),
B(Star), R(1),
/* 644 S> */ B(Jump), U8(8),
/* 662 S> */ B(LdaSmi), U8(3),
B(Star), R(1),
/* 671 S> */ B(Jump), U8(2),
B(LdaUndefined),
/* 680 S> */ B(Return),
]
constant pool: [
262,
266,
]
handlers: [
]
---
snippet: "
var a = 1;
switch(a) {
case 1:
switch(a + 1) {
case 2 : a = 1; break;
default : a = 2; break;
} // fall-through
case 2: a = 3;
}
"
frame size: 5
parameter count: 1
bytecode array length: 58
bytecodes: [
/* 30 E> */ B(StackCheck),
/* 42 S> */ B(LdaSmi), U8(1),
B(Star), R(2),
B(Star), R(0),
/* 45 S> */ B(LdaSmi), U8(1),
B(TestEqualStrict), R(0),
B(Mov), R(0), R(3),
B(JumpIfToBooleanTrue), U8(10),
B(LdaSmi), U8(2),
B(TestEqualStrict), R(3),
B(JumpIfTrue), U8(32),
B(Jump), U8(34),
/* 77 E> */ B(AddSmi), U8(1), R(2),
B(Star), R(1),
/* 70 S> */ B(LdaSmi), U8(2),
B(TestEqualStrict), R(1),
B(Mov), R(1), R(4),
B(JumpIfToBooleanTrue), U8(4),
B(Jump), U8(8),
/* 101 S> */ B(LdaSmi), U8(1),
B(Star), R(2),
/* 108 S> */ B(Jump), U8(8),
/* 131 S> */ B(LdaSmi), U8(2),
B(Star), R(2),
/* 138 S> */ B(Jump), U8(2),
/* 176 S> */ B(LdaSmi), U8(3),
B(Star), R(2),
B(LdaUndefined),
/* 185 S> */ B(Return),
]
constant pool: [
]
handlers: [
]