Commit d7be571c authored by Liu Yu's avatar Liu Yu Committed by Commit Bot

[mips64][wasm-simd] Retrieve the value of SupportsWasmSimd128()

in builtin

Port: 68105996

Bug: v8:11377
Change-Id: Ib60f0b0c0c994791e02ebde6ee8519134a3dd9f1
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2719806
Auto-Submit: Liu yu <liuyu@loongson.cn>
Reviewed-by: 's avatarZhao Jiazhong <zhaojiazhong-hf@loongson.cn>
Commit-Queue: Zhao Jiazhong <zhaojiazhong-hf@loongson.cn>
Cr-Commit-Position: refs/heads/master@{#73046}
parent 0e75ba17
...@@ -2374,13 +2374,23 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2374,13 +2374,23 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
STATIC_ASSERT(num_to_push == STATIC_ASSERT(num_to_push ==
WasmCompileLazyFrameConstants::kNumberOfSavedAllParamRegs); WasmCompileLazyFrameConstants::kNumberOfSavedAllParamRegs);
__ MultiPush(gp_regs); __ MultiPush(gp_regs);
if (CpuFeatures::IsSupported(MIPS_SIMD)) { // Check if machine has simd enabled, if so push vector registers. If not
__ MultiPushMSA(fp_regs); // then only push double registers.
} else { Label push_doubles, simd_pushed;
__ MultiPushFPU(fp_regs); __ li(a1, ExternalReference::supports_wasm_simd_128_address());
__ Dsubu(sp, sp, base::bits::CountPopulation(fp_regs) * kDoubleSize); // If > 0 then simd is available.
} __ Lbu(a1, MemOperand(a1));
__ Branch(&push_doubles, le, a1, Operand(zero_reg));
// Save vector registers.
__ MultiPushMSA(fp_regs);
__ Branch(&simd_pushed);
__ bind(&push_doubles);
__ MultiPushFPU(fp_regs);
// kFixedFrameSizeFromFp is hard coded to include space for Simd
// registers, so we still need to allocate extra (unused) space on the stack
// as if they were saved.
__ Dsubu(sp, sp, base::bits::CountPopulation(fp_regs) * kDoubleSize);
__ bind(&simd_pushed);
// Pass instance and function index as an explicit arguments to the runtime // Pass instance and function index as an explicit arguments to the runtime
// function. // function.
__ Push(kWasmInstanceRegister, kWasmCompileLazyFuncIndexRegister); __ Push(kWasmInstanceRegister, kWasmCompileLazyFuncIndexRegister);
...@@ -2390,12 +2400,18 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) { ...@@ -2390,12 +2400,18 @@ void Builtins::Generate_WasmCompileLazy(MacroAssembler* masm) {
__ CallRuntime(Runtime::kWasmCompileLazy, 2); __ CallRuntime(Runtime::kWasmCompileLazy, 2);
// Restore registers. // Restore registers.
if (CpuFeatures::IsSupported(MIPS_SIMD)) { Label pop_doubles, simd_popped;
__ MultiPopMSA(fp_regs); __ li(a1, ExternalReference::supports_wasm_simd_128_address());
} else { // If > 0 then simd is available.
__ Daddu(sp, sp, base::bits::CountPopulation(fp_regs) * kDoubleSize); __ Lbu(a1, MemOperand(a1));
__ MultiPopFPU(fp_regs); __ Branch(&pop_doubles, le, a1, Operand(zero_reg));
} // Pop vector registers.
__ MultiPopMSA(fp_regs);
__ Branch(&simd_popped);
__ bind(&pop_doubles);
__ Daddu(sp, sp, base::bits::CountPopulation(fp_regs) * kDoubleSize);
__ MultiPopFPU(fp_regs);
__ bind(&simd_popped);
__ MultiPop(gp_regs); __ MultiPop(gp_regs);
} }
// Finally, jump to the entrypoint. // Finally, jump to the entrypoint.
......
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