732f394c5d
StaGlobal didn't write the accumulator, but the baseline implementation assumed that it could preserve the accumulator by taking the return value of the StoreGlobalIC. This almost always worked, except for setters on the global object. Fix this by marking StaGlobal as clobbering the accumulator, same as StaNamedProperty (StaNamedProperty needs to do this anyway to avoid inlined setters from needing to create accumulator-preserving frames; StaGlobal would have needed the same thing if we'd ever inlined setters for it). Also, add a new debug scope, EnsureAccumulatorPreservedScope, to the baseline compiler, which checks if the accumulator value is preserved across non-accumulator-writing bytecodes. This found a (benign) bug with ForInPrepare, so fix that too. Fixed: chromium:1242306 Change-Id: I220b5b1c41010c16ac9f944cbd55d2705c299434 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3122325 Commit-Queue: Leszek Swirski <leszeks@chromium.org> Auto-Submit: Leszek Swirski <leszeks@chromium.org> Reviewed-by: Toon Verwaest <verwaest@chromium.org> Cr-Commit-Position: refs/heads/main@{#76525}
109 lines
2.2 KiB
Plaintext
109 lines
2.2 KiB
Plaintext
#
|
|
# Autogenerated by generate-bytecode-expectations.
|
|
#
|
|
|
|
---
|
|
wrap: no
|
|
top level: yes
|
|
|
|
---
|
|
snippet: "
|
|
var a = 1;
|
|
"
|
|
frame size: 3
|
|
parameter count: 1
|
|
bytecode array length: 18
|
|
bytecodes: [
|
|
B(LdaConstant), U8(0),
|
|
B(Star1),
|
|
B(Mov), R(closure), R(2),
|
|
/* 0 E> */ B(CallRuntime), U16(Runtime::kDeclareGlobals), R(1), U8(2),
|
|
/* 8 S> */ B(LdaSmi), I8(1),
|
|
/* 8 E> */ B(StaGlobal), U8(1), U8(0),
|
|
B(LdaUndefined),
|
|
/* 11 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
FIXED_ARRAY_TYPE,
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["a"],
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
function f() {}
|
|
"
|
|
frame size: 2
|
|
parameter count: 1
|
|
bytecode array length: 13
|
|
bytecodes: [
|
|
B(LdaConstant), U8(0),
|
|
B(Star0),
|
|
B(Mov), R(closure), R(1),
|
|
/* 0 E> */ B(CallRuntime), U16(Runtime::kDeclareGlobals), R(0), U8(2),
|
|
B(LdaUndefined),
|
|
/* 16 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
FIXED_ARRAY_TYPE,
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
var a = 1;
|
|
a=2;
|
|
"
|
|
frame size: 3
|
|
parameter count: 1
|
|
bytecode array length: 28
|
|
bytecodes: [
|
|
B(LdaConstant), U8(0),
|
|
B(Star1),
|
|
B(Mov), R(closure), R(2),
|
|
/* 0 E> */ B(CallRuntime), U16(Runtime::kDeclareGlobals), R(1), U8(2),
|
|
/* 8 S> */ B(LdaSmi), I8(1),
|
|
/* 8 E> */ B(StaGlobal), U8(1), U8(0),
|
|
/* 11 S> */ B(LdaSmi), I8(2),
|
|
B(Star1),
|
|
/* 12 E> */ B(StaGlobal), U8(1), U8(0),
|
|
B(Mov), R(1), R(0),
|
|
B(Ldar), R(0),
|
|
/* 16 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
FIXED_ARRAY_TYPE,
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["a"],
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
function f() {}
|
|
f();
|
|
"
|
|
frame size: 3
|
|
parameter count: 1
|
|
bytecode array length: 20
|
|
bytecodes: [
|
|
B(LdaConstant), U8(0),
|
|
B(Star1),
|
|
B(Mov), R(closure), R(2),
|
|
/* 0 E> */ B(CallRuntime), U16(Runtime::kDeclareGlobals), R(1), U8(2),
|
|
/* 16 S> */ B(LdaGlobal), U8(1), U8(0),
|
|
B(Star1),
|
|
/* 16 E> */ B(CallUndefinedReceiver0), R(1), U8(2),
|
|
B(Star0),
|
|
/* 21 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
FIXED_ARRAY_TYPE,
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["f"],
|
|
]
|
|
handlers: [
|
|
]
|
|
|