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. Saat 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 bind group. Sebelumnya, fitur 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() baru tersedia untuk menyinkronkan akses memori tekstur dalam workgroup.

Sebaiknya gunakan require-directive untuk memberi sinyal potensi non-portabilitas dengan requires readonly_and_readwrite_storage_textures; di bagian atas kode shader WGSL Anda. Lihat contoh dan issue dawn:1972 berikut.

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, 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 dalam 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 tanda "Fitur Developer WebGPU" di chrome://flags/#enable-webgpu-developer-features. Jika didukung:

Screenshot https://webgpureport.org yang menampilkan vkDriverVersion dalam 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 kini akan memunculkan GPUValidationError. Hal tersebut merupakan bug implementasi yang kini telah diperbaiki dengan pengujian yang tepat. Lihat masalah dawn:2402.

Update Fajar

Di Dawn API, callback error yang tidak direkam yang disetel dengan wgpuDeviceSetUncapturedErrorCallback kini tidak dipanggil setelah perangkat GPU hilang. Perbaikan ini menyelaraskan Dawn dengan spesifikasi JavaScript API dan implementasi Blink. Lihat masalah fawn:2459.

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

Yang Baru di WebGPU

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

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