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

François Beaufort
François Beaufort

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

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

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

เราขอแนะนำให้ใช้ requires-directive เพื่อส่งสัญญาณถึงความเป็นไปได้ที่จะไม่สามารถพกพาได้ด้วย requires readonly_and_readwrite_storage_textures; ที่ด้านบนของโค้ด Shader WGSL ดูตัวอย่างต่อไปนี้และออกคำสั่ง dawn: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() หากผู้ใช้เปิดใช้Flag "ฟีเจอร์สำหรับนักพัฒนาซอฟต์แวร์ WebGPU" ที่ chrome://flags/#enable-webgpu-developer-features เมื่อรองรับ

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

การแก้ไขข้อบกพร่อง

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

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

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

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

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

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

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