Tính năng mới trong WebGPU (Chrome'127)

François Beaufort
François Beaufort

Hỗ trợ thử nghiệm cho OpenGL ES trên Android

Giờ đây, bạn có thể truy cập vào GPUAdapter từ phần phụ trợ OpenGL ES khi yêu cầu chế độ tương thích WebGPU thử nghiệm trong Chrome dành cho Android. Điều này đặc biệt hữu ích đối với các thiết bị Android không hỗ trợ Vulkan 1.1 trở lên. Hãy xem ví dụ sau và vấn đề dawn:1545.

// Request a GPUAdapter in compatibility mode
const adapter = await navigator.gpu.requestAdapter({ compatibilityMode: true });
Trang báo cáo WebGPU cho thấy thông tin GPUAdapter từ phần phụ trợ OpenGL ES trên thiết bị Android.
Thông tin về bộ chuyển đổi OpenGL ES trong webgpureport.org

Vì tính năng này vẫn đang ở giai đoạn thử nghiệm, nên bạn cần thực hiện các bước sau:

  1. Bật các cờ Chrome sau: "Unsafe WebGPU Support", "WebGPU Developer Features" và "Enable command line on non-rooted devices".
  2. Bật tính năng Gỡ lỗi qua USB trên thiết bị Android.
  3. Kết nối thiết bị Android với máy trạm, chạy adb shell 'echo "_ --use-webgpu-adapter=opengles" > /data/local/tmp/chrome-command-line' để ưu tiên phần phụ trợ OpenGL ES hơn Vulkan và khởi động lại Chrome.

Thuộc tính thông tin GPUAdapter

Giờ đây, bạn có thể lấy thông tin nhận dạng về bộ chuyển đổi theo cách đồng bộ bằng thuộc tính info của GPUAdapter. Trước đây, cách duy nhất để lấy thông tin về bộ chuyển đổi là gọi phương thức requestAdapterInfo() không đồng bộ của GPUAdapter. Tuy nhiên, requestAdapterInfo() đã bị xoá khỏi thông số kỹ thuật WebGPU và sẽ bị xoá trong Chrome vào cuối năm nay để nhà phát triển web có đủ thời gian thực hiện quá trình chuyển đổi cần thiết. Hãy xem ví dụ sau, Trạng thái Chromevấn đề 335383516.

const adapter = await navigator.gpu.requestAdapter();
const info = adapter.info;

// During the transition period, you can use the following:
// const info = adapter.info || await adapter.requestAdapterInfo();

console.log(`Vendor: ${info.vendor}`); // "arm"
console.log(`Architecture: ${info.architecture}`); // "valhall"

Cải thiện khả năng tương tác của WebAssembly

Để phù hợp với việc các vùng nhớ WebAssembly được truyền trực tiếp đến WebGPU, kích thước của các đối số BufferSource sau đây không còn bị giới hạn ở mức 2 GB: dynamicOffsetsData trong setBindGroup(), nguồn data trong writeBuffer() và nguồn data Pin writeTexture(). Xem vấn đề 339049388.

Cải thiện lỗi bộ mã hoá lệnh

Một số lỗi xác thực phát sinh từ bộ mã hoá lệnh sẽ có thông tin theo ngữ cảnh được cải thiện. Ví dụ: việc cố gắng bắt đầu một lượt tính toán trong khi một lượt kết xuất vẫn đang mở sẽ dẫn đến lỗi sau.

Command cannot be recorded while [CommandEncoder (unlabeled)] is locked and [RenderPassEncoder (unlabeled)] is currently open.
    at CheckCurrentEncoder (..\..\third_party\dawn\src\dawn\native\EncodingContext.h:106)

Lỗi này có mô tả lý do gây ra lỗi, nhưng không cho biết lệnh gọi nào thực sự gây ra lỗi xác thực. Lỗi sau đây cho thấy thông báo được cải thiện, bao gồm cả lệnh gây ra lỗi. Xem thay đổi 192245.

Command cannot be recorded while [CommandEncoder (unlabeled)] is locked and [RenderPassEncoder (unlabeled)] is currently open.
 - While encoding [CommandEncoder (unlabeled)].BeginComputePass([ComputePassDescriptor]).

Thông tin cập nhật về Dawn

API C webgpu.h không còn hiển thị wgpuSurfaceGetPreferredFormat(), tương đương với C của wgpu::Surface::GetPreferredFormat() của Dawn. Thay vào đó, hãy sử dụng wgpu::Surface::GetCapabilities() để lấy danh sách các định dạng được hỗ trợ, sau đó sử dụng formats[0] để lấy định dạng hoạ tiết được ưu tiên cho nền tảng này. Trong khi đó, việc gọi wgpu::Surface::GetPreferredFormat() sẽ phát ra cảnh báo về việc ngừng sử dụng. Xem vấn đề 290.

Giờ đây, bạn có thể sử dụng các cách sử dụng kết cấu được hỗ trợ của một bề mặt thông qua wgpu::SurfaceCapabilities::usages khi gọi wgpu::Surface::GetCapabilities(). Chúng dự kiến sẽ luôn bao gồm wgpu::TextureUsage::RenderAttachment. Xem vấn đề 301.

Nội dung này chỉ đề cập đến một số điểm nổi bật chính. Hãy xem danh sách đầy đủ các cam kết.

Tính năng mới trong WebGPU

Danh sách mọi nội dung đã được đề cập trong loạt bài Tính năng mới trong WebGPU.

Chrome 149-150

Chrome 147-148

Chrome 146

Chrome 145

Chrome 144

Chrome 143

Chrome 142

Chrome 141

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