มีอะไรใหม่ใน WebGPU (Chrome 124)

François Beaufort
François Beaufort

เท็กซ์เจอร์พื้นที่เก็บข้อมูลแบบอ่านอย่างเดียวและอ่าน-เขียน

ประเภทการเชื่อมโยงเท็กซ์เจอร์พื้นที่เก็บข้อมูลช่วยให้ Shader อ่านจากเท็กซ์เจอร์พื้นที่เก็บข้อมูลได้โดยไม่ต้องเพิ่ม TEXTURE_BINDING usage และดำเนินการอ่านและเขียนแบบผสมในบางรูปแบบ เมื่อมี"readonly_and_readwrite_storage_textures"ส่วนขยายภาษา WGSL ใน navigator.gpu.wgslLanguageFeatures ตอนนี้คุณสามารถตั้งค่าสิทธิ์เข้าถึง GPUStorageTexture เป็น "read-write" หรือ "read-only" เมื่อสร้างเลย์เอาต์กลุ่มการเชื่อมโยงได้แล้ว ก่อนหน้านี้ฟีเจอร์นี้จำกัดไว้สำหรับ "write-only"

จากนั้นโค้ดเชดเดอร์ WGSL จะใช้ตัวระบุการเข้าถึง read_write และ read สำหรับเท็กซ์เจอร์พื้นที่เก็บข้อมูลได้ ฟังก์ชันในตัว textureLoad() และ textureStore() จะทำงานตามนั้น และฟังก์ชันในตัว textureBarrier() ใหม่จะพร้อมใช้งานเพื่อซิงค์การเข้าถึงหน่วยความจำของเท็กซ์เจอร์ในเวิร์กกรุ๊ป

เราขอแนะนำให้ใช้ requires-directive เพื่อส่งสัญญาณถึงความเป็นไปได้ที่จะไม่สามารถพกพาได้ด้วย requires readonly_and_readwrite_storage_textures; ที่ด้านบนของโค้ดเชดเดอร์ WGSL ดูตัวอย่างต่อไปนี้และออกปัญหา:1972

if (!navigator.gpu.wgslLanguageFeatures.has("readonly_and_readwrite_storage_textures")) {
  throw new Error("Read-only and read-write storage textures are not available");
}

const adapter = await navigator.gpu.requestAdapter();
const device = await adapter.requestDevice();

const bindGroupLayout = device.createBindGroupLayout({
  entries: [{
    binding: 0,
    visibility: GPUShaderStage.COMPUTE,
    storageTexture: {
      access: "read-write", // <-- New!
      format: "r32uint",
    },
  }],
});

const shaderModule = device.createShaderModule({ code: `
  requires readonly_and_readwrite_storage_textures;

  @group(0) @binding(0) var tex : texture_storage_2d<r32uint, read_write>;

  @compute @workgroup_size(1, 1)
  fn main(@builtin(local_invocation_id) local_id: vec3u) {
    var data = textureLoad(tex, vec2i(local_id.xy));
    data.x *= 2;
    textureStore(tex, vec2i(local_id.xy), data);
  }`
});

// You can now create a compute pipeline with this shader module and
// send the appropriate commands to the GPU.

การรองรับ Service Worker และ Shared Worker

WebGPU ใน Chrome จะยกระดับการรองรับ Web Worker ไปอีกขั้น โดยตอนนี้รองรับทั้ง Service Worker และ Shared Worker คุณสามารถใช้ Service Worker เพื่อปรับปรุงงานที่ทำงานเบื้องหลังและความสามารถแบบออฟไลน์ และใช้ Shared Worker เพื่อแชร์ทรัพยากรอย่างมีประสิทธิภาพในสคริปต์ต่างๆ ดูissue chromium:41494731

ดูตัวอย่างส่วนขยาย Chrome และส่วนขยาย Chrome ของ WebLLM เพื่อดูวิธีใช้ WebGPU ใน Service Worker ของส่วนขยาย

ภาพหน้าจอของส่วนขยาย WebLLM ใน Chrome
ส่วนขยาย WebLLM สำหรับ Chrome

แอตทริบิวต์ข้อมูลอะแดปเตอร์ใหม่

ตอนนี้แอตทริบิวต์ข้อมูลอะแดปเตอร์ d3dShaderModel และ vkDriverVersion ที่ไม่ใช่มาตรฐานพร้อมใช้งานแล้วเมื่อเรียกใช้ requestAdapterInfo() หากผู้ใช้เปิดใช้ฟีเจอร์สำหรับนักพัฒนาซอฟต์แวร์ WebGPU ที่chrome://flags/#enable-webgpu-developer-features เมื่อรองรับ

ภาพหน้าจอของ https://webgpureport.org ที่มี vkDriverVersion ในข้อมูลอะแดปเตอร์
ข้อมูลอะแดปเตอร์ vkDriverVersion แสดงที่ https://webgpureport.org

การแก้ไขบั๊ก

การสร้าง 2 ไปป์ไลน์ที่มีกลุ่มการเชื่อมโยงที่ตรงกันโดยใช้ layout: "auto" จากนั้นสร้างกลุ่มการเชื่อมโยงด้วยไปป์ไลน์แรก และใช้ในไปป์ไลน์ที่ 2 จะทำให้เกิด GPUValidationError การอนุญาตดังกล่าวเป็นข้อบกพร่องในการใช้งานซึ่งได้รับการแก้ไขแล้วด้วยการทดสอบที่เหมาะสม ดูปัญหา dawn:2402

ข้อมูลอัปเดตเกี่ยวกับ Dawn

ใน Dawn API ตอนนี้ระบบจะไม่เรียกใช้การเรียกกลับข้อผิดพลาดที่ไม่ได้บันทึกซึ่งตั้งค่าด้วย wgpuDeviceSetUncapturedErrorCallback หลังจากที่อุปกรณ์ GPU หายไป การแก้ไขนี้จะปรับ Dawn ให้สอดคล้องกับข้อกำหนดของ JavaScript API และการใช้งานของ Blink ดูปัญหา dawn:2459

นี่เป็นเพียงไฮไลต์สำคัญบางส่วนเท่านั้น ดูรายการคอมมิตทั้งหมด

มีอะไรใหม่ใน WebGPU

รายการทุกอย่างที่ครอบคลุมในซีรีส์มีอะไรใหม่ใน WebGPU

Chrome 149-150

Chrome 147-148

Chrome 146

Chrome 145

Chrome 144

Chrome 143

Chrome 142

Chrome 141

Chrome 140

Chrome 139

Chrome 138

Chrome 137

Chrome 136

Chrome 135

Chrome 134

Chrome 133

Chrome 132

Chrome 131

Chrome 130

Chrome 129

Chrome 128

Chrome 127

Chrome 126

Chrome 125

Chrome 124

Chrome 123

Chrome 122

Chrome 121

Chrome 120

Chrome 119

Chrome 118

Chrome 117

Chrome 116

Chrome 115

Chrome 114

Chrome 113