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, serta melakukan pembacaan dan penulisan campuran pada format tertentu. Jika ekstensi bahasa WGSL "readonly_and_readwrite_storage_textures" ada di navigator.gpu.wgslLanguageFeatures, Anda kini dapat menyetel akses GPUStorageTexture ke "read-write" atau "read-only" saat membuat tata letak bind group. Sebelumnya, setelan ini dibatasi untuk "write-only".

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

Sebaiknya gunakan required-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 membawa dukungan pekerja web ke tingkat yang lebih tinggi, 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 yang efisien di seluruh skrip. Lihat masalah chromium:41494731.

Lihat contoh ekstensi Chrome dan ekstensi Chrome WebLLM untuk mengetahui 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 setelah memanggil requestAdapterInfo() jika pengguna telah mengaktifkan "Fitur Developer WebGPU" bendera pada 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 pada pipeline kedua sekarang memunculkan GPUValidationError. Mengizinkan hal tersebut adalah bug implementasi yang kini telah diperbaiki dengan pengujian yang tepat. Lihat issue dawn:2402.

Update fajar

Di Dawn API, callback error yang tidak direkam yang disetel dengan wgpuDeviceSetUncapturedErrorCallback sekarang tidak dipanggil setelah perangkat GPU hilang. Perbaikan ini menyelaraskan Dawn dengan spesifikasi JavaScript API dan penerapan Blink. Lihat issue dawn:2459.

Artikel ini hanya mencakup beberapa sorotan utama. Lihat daftar commit selengkapnya.

Yang Baru di WebGPU

Daftar semua hal yang telah dibahas dalam seri What's New in WebGPU.

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