Commit 84c2c7cf authored by Milad Fa's avatar Milad Fa Committed by V8 LUCI CQ

PPC/s390: Reland: [wasm] WasmCompileLazyFrame scanning

Port 4e329f8c

Original Commit Message:

    The original CL did not handle the case where a GC gets triggered by
    the allocation of the error object when compilation fails.

    Orignal message:

    Feedback vector allocation can trigger a GC, and thereby make the
    WasmCompileLazyFrame visible for the GC. This CL add stack scanning
    for the WasmCompileLazyFrame.

    Design doc: http://doc/1peovM6N6C4nSEdC77l4uxU1L0njA0RTaOjy5F12r2CQ

R=ahaas@chromium.org, joransiu@ca.ibm.com, junyan@redhat.com, midawson@redhat.com
BUG=
LOG=N

Change-Id: I3cdd5b0cd72463a6b492fcafcabcf65e1da55eea
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3804694Reviewed-by: 's avatarAndreas Haas <ahaas@chromium.org>
Reviewed-by: 's avatarJoran Siu <joransiu@ca.ibm.com>
Commit-Queue: Milad Farazmand <mfarazma@redhat.com>
Cr-Commit-Position: refs/heads/main@{#82151}
parent 8abfe8f2
...@@ -2930,7 +2930,7 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2930,7 +2930,7 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
CHECK_EQ(gp_regs.Count(), arraysize(wasm::kGpParamRegisters)); CHECK_EQ(gp_regs.Count(), arraysize(wasm::kGpParamRegisters));
CHECK_EQ(fp_regs.Count(), arraysize(wasm::kFpParamRegisters)); CHECK_EQ(fp_regs.Count(), arraysize(wasm::kFpParamRegisters));
CHECK_EQ(simd_regs.Count(), arraysize(wasm::kFpParamRegisters)); CHECK_EQ(simd_regs.Count(), arraysize(wasm::kFpParamRegisters));
CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedGpParamRegs, CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedGpParamRegs + 1,
gp_regs.Count()); gp_regs.Count());
CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedFpParamRegs, CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedFpParamRegs,
fp_regs.Count()); fp_regs.Count());
...@@ -2944,10 +2944,13 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2944,10 +2944,13 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
__ Push(kWasmInstanceRegister); __ Push(kWasmInstanceRegister);
// Push the function index as second argument. // Push the function index as second argument.
__ Push(kWasmCompileLazyFuncIndexRegister); __ Push(kWasmCompileLazyFuncIndexRegister);
// Allocate a stack slot for the NativeModule, the pushed value does not
// matter.
__ push(r11);
// Initialize the JavaScript context with 0. CEntry will use it to // Initialize the JavaScript context with 0. CEntry will use it to
// set the current context on the isolate. // set the current context on the isolate.
__ LoadSmiLiteral(cp, Smi::zero()); __ LoadSmiLiteral(cp, Smi::zero());
__ CallRuntime(Runtime::kWasmCompileLazy, 2); __ CallRuntime(Runtime::kWasmCompileLazy, 3);
// The runtime function returns the jump table slot offset as a Smi. Use // The runtime function returns the jump table slot offset as a Smi. Use
// that to compute the jump target in r11. // that to compute the jump target in r11.
__ SmiUntag(kReturnRegister0); __ SmiUntag(kReturnRegister0);
......
...@@ -2930,7 +2930,7 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2930,7 +2930,7 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
CHECK_EQ(gp_regs.Count(), arraysize(wasm::kGpParamRegisters)); CHECK_EQ(gp_regs.Count(), arraysize(wasm::kGpParamRegisters));
CHECK_EQ(fp_regs.Count(), arraysize(wasm::kFpParamRegisters)); CHECK_EQ(fp_regs.Count(), arraysize(wasm::kFpParamRegisters));
CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedGpParamRegs, CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedGpParamRegs + 1,
gp_regs.Count()); gp_regs.Count());
CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedFpParamRegs, CHECK_EQ(WasmCompileLazyFrameConstants::kNumberOfSavedFpParamRegs,
fp_regs.Count()); fp_regs.Count());
...@@ -2942,10 +2942,13 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2942,10 +2942,13 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
__ Push(kWasmInstanceRegister); __ Push(kWasmInstanceRegister);
// Push the function index as second argument. // Push the function index as second argument.
__ Push(kWasmCompileLazyFuncIndexRegister); __ Push(kWasmCompileLazyFuncIndexRegister);
// Allocate a stack slot for the NativeModule, the pushed value does not
// matter.
__ push(ip);
// Initialize the JavaScript context with 0. CEntry will use it to // Initialize the JavaScript context with 0. CEntry will use it to
// set the current context on the isolate. // set the current context on the isolate.
__ LoadSmiLiteral(cp, Smi::zero()); __ LoadSmiLiteral(cp, Smi::zero());
__ CallRuntime(Runtime::kWasmCompileLazy, 2); __ CallRuntime(Runtime::kWasmCompileLazy, 3);
// The runtime function returns the jump table slot offset as a Smi. Use // The runtime function returns the jump table slot offset as a Smi. Use
// that to compute the jump target in ip. // that to compute the jump target in ip.
__ SmiUntag(kReturnRegister0); __ SmiUntag(kReturnRegister0);
......
...@@ -23,19 +23,22 @@ class EntryFrameConstants : public AllStatic { ...@@ -23,19 +23,22 @@ class EntryFrameConstants : public AllStatic {
class WasmCompileLazyFrameConstants : public TypedFrameConstants { class WasmCompileLazyFrameConstants : public TypedFrameConstants {
public: public:
static constexpr int kNumberOfSavedGpParamRegs = 7; // Number of gp parameters, without the instance.
static constexpr int kNumberOfSavedGpParamRegs = 6;
static constexpr int kNumberOfSavedFpParamRegs = 8; static constexpr int kNumberOfSavedFpParamRegs = 8;
// FP-relative. static constexpr int kInstanceSpillOffset =
// The instance is pushed as part of the saved registers. Being in {r10}, it TYPED_FRAME_PUSHED_VALUE_OFFSET(0);
// is the first register pushed (highest register code in
// {wasm::kGpParamRegisters}). static constexpr int kParameterSpillsOffset[] = {
static constexpr int kWasmInstanceOffset = TYPED_FRAME_PUSHED_VALUE_OFFSET(0); TYPED_FRAME_PUSHED_VALUE_OFFSET(1), TYPED_FRAME_PUSHED_VALUE_OFFSET(2),
static constexpr int kFixedFrameSizeFromFp = TYPED_FRAME_PUSHED_VALUE_OFFSET(3), TYPED_FRAME_PUSHED_VALUE_OFFSET(4),
TypedFrameConstants::kFixedFrameSizeFromFp + TYPED_FRAME_PUSHED_VALUE_OFFSET(5), TYPED_FRAME_PUSHED_VALUE_OFFSET(6)};
kNumberOfSavedGpParamRegs * kSystemPointerSize +
kNumberOfSavedFpParamRegs * kDoubleSize + // SP-relative.
kNumberOfSavedFpParamRegs * kSimd128Size; static constexpr int kWasmInstanceOffset = 2 * kSystemPointerSize;
static constexpr int kFunctionIndexOffset = 1 * kSystemPointerSize;
static constexpr int kNativeModuleOffset = 0;
}; };
// Frame constructed by the {WasmDebugBreak} builtin. // Frame constructed by the {WasmDebugBreak} builtin.
......
...@@ -23,22 +23,24 @@ class EntryFrameConstants : public AllStatic { ...@@ -23,22 +23,24 @@ class EntryFrameConstants : public AllStatic {
class WasmCompileLazyFrameConstants : public TypedFrameConstants { class WasmCompileLazyFrameConstants : public TypedFrameConstants {
public: public:
static constexpr int kNumberOfSavedGpParamRegs = 4; static constexpr int kNumberOfSavedGpParamRegs = 3;
#ifdef V8_TARGET_ARCH_S390X #ifdef V8_TARGET_ARCH_S390X
static constexpr int kNumberOfSavedFpParamRegs = 4; static constexpr int kNumberOfSavedFpParamRegs = 4;
#else #else
static constexpr int kNumberOfSavedFpParamRegs = 2; static constexpr int kNumberOfSavedFpParamRegs = 2;
#endif #endif
// FP-relative. static constexpr int kInstanceSpillOffset =
// The instance is pushed as part of the saved registers. Being in {r6}, it is TYPED_FRAME_PUSHED_VALUE_OFFSET(0);
// the first register pushed (highest register code in
// {wasm::kGpParamRegisters}). static constexpr int kParameterSpillsOffset[] = {
static constexpr int kWasmInstanceOffset = TYPED_FRAME_PUSHED_VALUE_OFFSET(0); TYPED_FRAME_PUSHED_VALUE_OFFSET(1), TYPED_FRAME_PUSHED_VALUE_OFFSET(2),
static constexpr int kFixedFrameSizeFromFp = TYPED_FRAME_PUSHED_VALUE_OFFSET(3)};
TypedFrameConstants::kFixedFrameSizeFromFp +
kNumberOfSavedGpParamRegs * kSystemPointerSize + // SP-relative.
kNumberOfSavedFpParamRegs * kSimd128Size; static constexpr int kWasmInstanceOffset = 2 * kSystemPointerSize;
static constexpr int kFunctionIndexOffset = 1 * kSystemPointerSize;
static constexpr int kNativeModuleOffset = 0;
}; };
// Frame constructed by the {WasmDebugBreak} builtin. // Frame constructed by the {WasmDebugBreak} builtin.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment