Bug 267381

Summary: [Wasm-GC] Fix write barrier bug in BBQ array.set
Product: WebKit Reporter: Asumu Takikawa <asumu>
Component: WebAssemblyAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: bashorov, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 247394    

Asumu Takikawa
Reported 2024-01-10 16:15:02 PST
A recent PR added JIT inlining for array ops, and also has write barriers for these situations. Unfortunately while the write barrier is in the right place, the condition to add them is slightly wrong. Test case: ``` //@ runWebAssemblySuite("--useWebAssemblyTypedFunctionReferences=true", "--useWebAssemblyGC=true", "--useWebAssemblyExtendedConstantExpressions=true") import * as assert from "../assert.js"; import { instantiate } from "./wast-wrapper.js"; { const m1 = instantiate(` (module (type (struct (field i32))) (type (array (mut (ref null 0)))) (func (export "maker") (result (ref 1)) (array.new_default 1 (i32.const 5)))) `); const arr = m1.exports.maker(); assert.isObject(arr); // Do a GC to ensure the array is an old object. gc(); const m2 = instantiate(` (module (type (struct (field i32))) (type (array (mut (ref null 0)))) (func (export "set") (param (ref 1) i32) (array.set 1 (local.get 0) (local.get 1) (struct.new 0 (i32.const 42)))) (func (export "get") (param (ref 1) i32) (result i32) (struct.get 0 0 (array.get 1 (local.get 0) (local.get 1))))) `); for (var i = 0; i < 5; i++) m2.exports.set(arr, i); // Do an eden GC to test write barriers. edenGC(); for (var i = 0; i < 5; i++) assert.eq(m2.exports.get(arr, i), 42); } ``` The fix is straightforward (just fix the condition to check the right type).
Attachments
Asumu Takikawa
Comment 1 2024-01-10 16:27:12 PST
EWS
Comment 2 2024-01-11 10:09:39 PST
Committed 272923@main (6decd847ff17): <https://commits.webkit.org/272923@main> Reviewed commits have been landed. Closing PR #22630 and removing active labels.
Radar WebKit Bug Importer
Comment 3 2024-01-11 10:10:14 PST
Note You need to log in before you can comment on or make changes to this bug.