Yang Baru di WebGPU (Chrome\r124)

François Beaufort
François Beaufort

Tekstur penyimpanan hanya baca dan baca-tulis

Jenis pengikatan tekstur penyimpanan memungkinkan shader membaca dari tekstur penyimpanan tanpa menambahkan penggunaan TEXTURE_BINDING, dan melakukan pembacaan dan penulisan campuran pada format tertentu. Jika ekstensi bahasa "readonly_and_readwrite_storage_textures" WGSL ada di navigator.gpu.wgslLanguageFeatures, Anda kini dapat menyetel akses GPUStorageTexture ke "read-write" atau "read-only" saat membuat tata letak grup pengikatan. Sebelumnya, fitur ini dibatasi untuk "write-only".

Kemudian, kode shader WGSL Anda dapat menggunakan kualifikasi akses read_write dan read untuk tekstur penyimpanan, fungsi bawaan textureLoad() dan textureStore() berperilaku sesuai, dan fungsi bawaan textureBarrier() baru tersedia untuk menyinkronkan akses memori tekstur dalam grup kerja.

Sebaiknya gunakan requires-directive untuk menandakan potensi tidak portabel dengan requires readonly_and_readwrite_storage_textures; di bagian atas kode shader WGSL Anda. Lihat contoh berikut dan issue 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.

Dukungan pekerja layanan dan pekerja bersama

WebGPU di Chrome meningkatkan dukungan pekerja web ke level berikutnya, kini menawarkan dukungan untuk service worker dan shared worker. Anda dapat menggunakan service worker untuk meningkatkan tugas latar belakang dan kemampuan offline, serta shared worker untuk berbagi resource secara efisien di seluruh skrip. Lihat masalah chromium:41494731.

Lihat contoh ekstensi Chrome dan ekstensi Chrome WebLLM untuk melihat cara menggunakan WebGPU di pekerja layanan ekstensi.

Screenshot ekstensi Chrome WebLLM.
Ekstensi Chrome WebLLM.

Atribut informasi adaptor baru

Atribut info adaptor d3dShaderModel dan vkDriverVersion non-standar kini tersedia saat memanggil requestAdapterInfo() jika pengguna telah mengaktifkan flag "Fitur Developer WebGPU" di chrome://flags/#enable-webgpu-developer-features. Jika didukung:

Screenshot https://webgpureport.org yang menampilkan vkDriverVersion di info adaptor.
Info Adapter vkDriverVersion ditampilkan di https://webgpureport.org.

Perbaikan bug

Membuat dua pipeline dengan bindgroup yang cocok menggunakan layout: "auto", lalu membuat bindgroup dengan pipeline pertama, dan menggunakannya di pipeline kedua kini memunculkan GPUValidationError. Mengizinkannya adalah bug implementasi yang kini diperbaiki dengan pengujian yang tepat. Lihat masalah dawn:2402.

Update Dawn

Di Dawn API, callback error yang tidak tertangkap yang ditetapkan dengan wgpuDeviceSetUncapturedErrorCallback kini tidak dipanggil setelah perangkat GPU hilang. Perbaikan ini menyelaraskan Dawn dengan spesifikasi JavaScript API dan penerapan Blink. Lihat masalah dawn:2459.

Hal ini hanya mencakup beberapa sorotan utama. Lihat daftar commit yang lengkap.

Yang Baru di WebGPU

Daftar semua hal yang telah dibahas dalam seri Yang Baru di 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