Yang Baru di WebGPU (Chrome\r124)

François Beaufort
François Beaufort

Tekstur penyimpanan hanya baca dan baca-tulis

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

Kemudian, kode shader WGSL Anda dapat menggunakan penentu 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 non-portabilitas 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 tingkat berikutnya, yang kini menawarkan dukungan untuk pekerja layanan dan pekerja bersama. Anda dapat menggunakan pekerja layanan untuk meningkatkan tugas latar belakang dan kemampuan offline, serta pekerja bersama 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 service worker ekstensi.

Screenshot ekstensi Chrome WebLLM.
Ekstensi Chrome WebLLM.

Atribut informasi adaptor baru

Atribut info adaptor d3dShaderModel dan vkDriverVersion non-standar kini tersedia setelah 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 adaptor 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 akan memunculkan GPUValidationError. Mengizinkannya adalah bug implementasi yang kini diperbaiki dengan pengujian yang tepat. Lihat masalah dawn:2402.

Update fajar

Di Dawn API, callback error yang tidak direkam 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.

Bagian ini hanya membahas beberapa sorotan utama. Lihat daftar commit yang lengkap.

Yang Baru di WebGPU

Daftar semua yang telah dibahas dalam seri Yang Baru di WebGPU.

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