a2fcdc7cc8
Instead of counting profiler ticks on the shared function info (which is shared between native contexts), count them on the feedback vector (which is not). This allows us to continue pushing optimization decisions off the SFI, onto the feedback vector. Note that a side-effect of this is that ICs don't have to walk the stack to reset profiler ticks, as they can access the feedback vector directly from their feedback nexus. Change-Id: I232ae9e759fca75cd89d393148a4ff42caa2646f Reviewed-on: https://chromium-review.googlesource.com/544888 Reviewed-by: Igor Sheludko <ishell@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Commit-Queue: Leszek Swirski <leszeks@chromium.org> Cr-Commit-Position: refs/heads/master@{#46411}
97 lines
1.8 KiB
Plaintext
97 lines
1.8 KiB
Plaintext
#
|
|
# Autogenerated by generate-bytecode-expectations.
|
|
#
|
|
|
|
---
|
|
wrap: yes
|
|
|
|
---
|
|
snippet: "
|
|
var ld_a = 1;
|
|
while(true) {
|
|
ld_a = ld_a + ld_a;
|
|
if (ld_a > 10) break;
|
|
}
|
|
return ld_a;
|
|
"
|
|
frame size: 1
|
|
parameter count: 1
|
|
bytecode array length: 28
|
|
bytecodes: [
|
|
/* 30 E> */ B(StackCheck),
|
|
/* 45 S> */ B(LdaSmi), I8(1),
|
|
B(Star), R(0),
|
|
/* 48 E> */ B(StackCheck),
|
|
/* 64 S> */ B(Ldar), R(0),
|
|
/* 76 E> */ B(Add), R(0), U8(4),
|
|
B(Star), R(0),
|
|
/* 86 S> */ B(LdaSmi), I8(10),
|
|
/* 95 E> */ B(TestGreaterThan), R(0), U8(5),
|
|
B(JumpIfFalse), U8(4),
|
|
/* 101 S> */ B(Jump), U8(5),
|
|
B(JumpLoop), U8(17), I8(0),
|
|
/* 110 S> */ B(Ldar), R(0),
|
|
/* 123 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
var ld_a = 1;
|
|
do {
|
|
ld_a = ld_a + ld_a;
|
|
if (ld_a > 10) continue;
|
|
} while(false);
|
|
return ld_a;
|
|
"
|
|
frame size: 1
|
|
parameter count: 1
|
|
bytecode array length: 24
|
|
bytecodes: [
|
|
/* 30 E> */ B(StackCheck),
|
|
/* 45 S> */ B(LdaSmi), I8(1),
|
|
B(Star), R(0),
|
|
/* 48 E> */ B(StackCheck),
|
|
/* 55 S> */ B(Nop),
|
|
/* 67 E> */ B(Add), R(0), U8(4),
|
|
B(Star), R(0),
|
|
/* 77 S> */ B(LdaSmi), I8(10),
|
|
/* 86 E> */ B(TestGreaterThan), R(0), U8(5),
|
|
B(JumpIfFalse), U8(4),
|
|
/* 92 S> */ B(Jump), U8(2),
|
|
/* 118 S> */ B(Ldar), R(0),
|
|
/* 131 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
var ld_a = 1;
|
|
ld_a = ld_a + ld_a;
|
|
return ld_a;
|
|
"
|
|
frame size: 1
|
|
parameter count: 1
|
|
bytecode array length: 13
|
|
bytecodes: [
|
|
/* 30 E> */ B(StackCheck),
|
|
/* 45 S> */ B(LdaSmi), I8(1),
|
|
B(Star), R(0),
|
|
/* 50 S> */ B(Nop),
|
|
/* 62 E> */ B(Add), R(0), U8(4),
|
|
B(Star), R(0),
|
|
/* 72 S> */ B(Nop),
|
|
/* 85 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
]
|
|
handlers: [
|
|
]
|
|
|