מה חדש ב-WebGPU (Chrome {/7}127)

François Beaufort
François Beaufort

תמיכה ניסיונית ב-OpenGL ES ב-Android

עכשיו אפשר לגשת ל-GPUAdapter מקצהה העורפי של OpenGL ES כשמבקשים את מצב התאימות הניסיוני של WebGPU ב-Chrome ל-Android. האפשרות הזו שימושית במיוחד במכשירי Android שאין בהם תמיכה ב-Vulkan 1.1 ואילך. אפשר לראות את הדוגמה הבאה ואת הבעיה dawn:1545.

// Request a GPUAdapter in compatibility mode
const adapter = await navigator.gpu.requestAdapter({ compatibilityMode: true });
בדף הדוח של WebGPU מוצג מידע על GPUAdapter מהקצה העורפי של OpenGL ES במכשיר Android.
מידע על מתאם OpenGL ES ב-webgpureport.org

התכונה הזו עדיין נמצאת בשלב ניסיוני, ולכן תצטרכו לבצע את השלבים הבאים:

  1. מפעילים את הדגלים הבאים ב-Chrome: 'תמיכה לא בטוחה ב-WebGPU', 'תכונות למפתחים של WebGPU' ו'הפעלת שורת הפקודה במכשירים ללא הרשאת root'.
  2. מפעילים את ניפוי הבאגים ב-USB במכשיר Android.
  3. מחברים את מכשיר Android לתחנת העבודה, מריצים את הפקודה adb shell 'echo "_ --use-webgpu-adapter=opengles" > /data/local/tmp/chrome-command-line' כדי להעדיף את הקצה העורפי של OpenGL ES על פני Vulkan ומפעילים מחדש את Chrome.

מאפיין המידע של GPUAdapter

עכשיו אפשר לקבל פרטים מזהים על מתאם באופן סינכרוני באמצעות המאפיין info של GPUAdapter. בעבר, הפעלת השיטה האסינכרונית של GPUAdapter requestAdapterInfo() הייתה הדרך היחידה לקבל פרטי מתאם. עם זאת, requestAdapterInfo() הוסר מהמפרט של WebGPU ויוסר מ-Chrome בהמשך השנה כדי לתת למפתחי אתרים מספיק זמן לבצע את המעבר הדרוש. אפשר לעיין בדוגמה הבאה, בסטטוס Chrome ובבעיה 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"

שיפורים בפעולה ההדדית של WebAssembly

כדי לאפשר העברת ערימות של WebAssembly ישירות אל WebGPU, הגדלים של הארגומנטים הבאים של BufferSource כבר לא מוגבלים ל-2GB: dynamicOffsetsData ב-setBindGroup(), המקור data ב-writeBuffer() וקוד המקור data writeTexture(). בעיה מס' 339049388

שיפור של שגיאות במקודד הפקודות

חלק משגיאות האימות שהתקבלו ממקודדי הפקודות יכללו עכשיו מידע נסיבתי משופר. לדוגמה, ניסיון להתחיל שלב מחשוב בזמן ששלב רינדור עדיין היה פתוח הוביל לשגיאה הבאה.

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)

התיאור הזה מתאר את הסיבה לשגיאה, אבל הוא לא מציין איזו קריאה גרמה בפועל לשגיאת האימות. בשגיאה הבאה מוצגת ההודעה המשופרת, שכוללת את הפקודה שהפעילה את השגיאה. ראו שינוי 192245.

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

עדכונים לגבי זריחה

ממשק ה-API ל-C‏ webgpu.h לא חושף יותר את wgpuSurfaceGetPreferredFormat(), המקבילה ל-C של wgpu::Surface::GetPreferredFormat() ב-Dawn. במקום זאת, אפשר להשתמש ב-wgpu::Surface::GetCapabilities() כדי לקבל את רשימת הפורמטים הנתמכים, ואז להשתמש ב-formats[0] כדי לקבל את פורמט הטקסטורה המועדף למשטח הזה. בינתיים, אם תבוצע קריאה אל wgpu::Surface::GetPreferredFormat(), תוצג אזהרה על הוצאה משימוש. בעיה 290

השימושים הנתמכים במרקמים של משטח זמינים עכשיו דרך wgpu::SurfaceCapabilities::usages בקריאה ל-wgpu::Surface::GetCapabilities(). הם אמורים תמיד לכלול את wgpu::TextureUsage::RenderAttachment. בעיה 301

הסקירה הזו כוללת רק חלק מהנקודות העיקריות. רשימת ההצהרות המלאה

מה חדש ב-WebGPU

רשימה של כל מה שנדון בסדרה מה חדש ב-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