תמיכה ב-WebGPU ב-Android
צוות Chrome שמח להודיע ש-WebGPU מופעל עכשיו כברירת מחדל ב-Chrome 121 במכשירים עם Android 12 ומעלה שמבוססים על מעבדי Qualcomm ו-ARM.
התמיכה תורחב בהדרגה למגוון רחב יותר של מכשירי Android, כולל מכשירים עם Android 11 בעתיד הקרוב. ההרחבה הזו תהיה תלויה בבדיקות ובאופטימיזציה נוספות כדי להבטיח חוויה חלקה במגוון רחב יותר של תצורות חומרה. מידע נוסף
שימוש ב-DXC במקום ב-FXC לקימפול של shader ב-Windows
Chrome משתמש עכשיו ביכולות של DXC (DirectX Compiler) כדי לקמפל shaders במחשבי Windows D3D12 שמצוידים בחומרה גרפית SM6+. בעבר, WebGPU הסתמך על FXC (FX Compiler) לקימפול של shader ב-Windows. למרות ש-FXC פועל, חסרים בו התכונות והאופטימיזציות של הביצועים שקיימים ב-DXC.
בבדיקות ראשוניות שערכנו, המהירות של קימפול shader לחישוב הייתה גבוהה ב-20% בממוצע כשנעשה שימוש ב-DXC לעומת FXC.
שאילתות של חותמות זמן במעברי חישוב ועיבוד
שאילתות של חותמות זמן מאפשרות לאפליקציות WebGPU למדוד במדויק (עד לרמת הננו-שנייה) כמה זמן לוקח לפקודות ה-GPU שלהן לבצע חישובים ולהעביר עיבודים. הם משמשים בעיקר כדי לקבל תובנות לגבי הביצועים וההתנהגות של עומסי עבודה של מעבד גרפי.
אם התכונה "timestamp-query" זמינה ב-GPUAdapter, תוכלו לבצע את הפעולות הבאות:
- שליחת בקשה ל
GPUDeviceבאמצעות התכונה"timestamp-query". - יצירת
GPUQuerySetמסוג"timestamp". - משתמשים ב-
GPUComputePassDescriptor.timestampWritesוב-GPURenderPassDescriptor.timestampWritesכדי להגדיר איפה לכתוב ערכי חותמת זמן ב-GPUQuerySet. - המרת ערכים של חותמות זמן לערך
GPUBufferבאמצעותresolveQuerySet(). - כדי לקרוא את ערכי חותמת הזמן, מעתיקים את התוצאות מ-
GPUBufferאל המעבד. - פענוח של ערכי חותמת זמן כ-
BigInt64Array.
לדוגמה, הבעיה dawn:1800.
const adapter = await navigator.gpu.requestAdapter();
if (!adapter.features.has("timestamp-query")) {
throw new Error("Timestamp query feature is not available");
}
// Explicitly request timestamp query feature.
const device = await adapter.requestDevice({
requiredFeatures: ["timestamp-query"],
});
const commandEncoder = device.createCommandEncoder();
// Create a GPUQuerySet which holds 2 timestamp query results: one for the
// beginning and one for the end of compute pass execution.
const querySet = device.createQuerySet({ type: "timestamp", count: 2 });
const timestampWrites = {
querySet,
beginningOfPassWriteIndex: 0, // Write timestamp in index 0 when pass begins.
endOfPassWriteIndex: 1, // Write timestamp in index 1 when pass ends.
};
const passEncoder = commandEncoder.beginComputePass({ timestampWrites });
// TODO: Set pipeline, bind group, and dispatch work to be performed.
passEncoder.end();
// Resolve timestamps in nanoseconds as a 64-bit unsigned integer into a GPUBuffer.
const size = 2 * BigInt64Array.BYTES_PER_ELEMENT;
const resolveBuffer = device.createBuffer({
size,
usage: GPUBufferUsage.QUERY_RESOLVE | GPUBufferUsage.COPY_SRC,
});
commandEncoder.resolveQuerySet(querySet, 0, 2, resolveBuffer, 0);
// Read GPUBuffer memory.
const resultBuffer = device.createBuffer({
size,
usage: GPUBufferUsage.COPY_DST | GPUBufferUsage.MAP_READ,
});
commandEncoder.copyBufferToBuffer(resolveBuffer, 0, resultBuffer, 0, size);
// Submit commands to the GPU.
device.queue.submit([commandEncoder.finish()]);
// Log compute pass duration in nanoseconds.
await resultBuffer.mapAsync(GPUMapMode.READ);
const times = new BigInt64Array(resultBuffer.getMappedRange());
console.log(`Compute pass duration: ${Number(times[1] - times[0])}ns`);
resultBuffer.unmap();
בגלל חששות לגבי מתקפת תזמון, שאילתות של חותמות זמן עוברות קוונטיזציה ברזולוציה של 100 מיקרו-שניות, שמספקת פשרה טובה בין דיוק לאבטחה. בדפדפן Chrome, אפשר להשבית את הכימות של חותמות הזמן על ידי הפעלת הדגל WebGPU Developer Features (תכונות למפתחים של WebGPU) בכתובת chrome://flags/#enable-webgpu-developer-features במהלך פיתוח האפליקציה. מידע נוסף זמין במאמר כימות של שאילתות חותמות זמן.
יכול להיות שמאיצי GPU יאפסו מדי פעם את מונה חותמות הזמן, מה שיכול לגרום לערכים לא צפויים כמו דלתאות שליליות בין חותמות זמן. לכן מומלץ לבדוק את השינויים ב-git diff שמוסיפים תמיכה בשאילתות של חותמות זמן לדוגמה הבאה של Compute Boids.
נקודות כניסה שמוגדרות כברירת מחדל למודולים של תוכנת הצללה (shader)
כדי לשפר את חוויית המפתחים, עכשיו אפשר להשמיט את entryPoint של מודול ההצללה כשיוצרים צינור עיבוד או צינור רנדור. אם לא נמצאה נקודת כניסה ייחודית לשלב ההצללה בקוד ההצללה, תופעל GPUValidationError. דוגמה: issue dawn:2254.
const code = `
@vertex fn vertexMain(@builtin(vertex_index) i : u32) ->
@builtin(position) vec4f {
const pos = array(vec2f(0, 1), vec2f(-1, -1), vec2f(1, -1));
return vec4f(pos[i], 0, 1);
}
@fragment fn fragmentMain() -> @location(0) vec4f {
return vec4f(1, 0, 0, 1);
}`;
const module = myDevice.createShaderModule({ code });
const format = navigator.gpu.getPreferredCanvasFormat();
const pipeline = await myDevice.createRenderPipelineAsync({
layout: "auto",
vertex: { module, entryPoint: "vertexMain" },
fragment: { module, entryPoint: "fragmentMain", targets: [{ format }] },
vertex: { module },
fragment: { module, targets: [{ format }] },
});
תמיכה ב-display-p3 כמרחב צבעים של GPUExternalTexture
עכשיו אפשר להגדיר "display-p3" מרחב צבעים ליעד כשמייבאים GPUExternalTexture מסרטוני HDR עם importExternalTexture(). איך WebGPU מטפל במרחבי צבע לדוגמה, ראו את הבעיה chromium:1330250.
// Create texture from HDR video.
const video = document.querySelector("video");
const texture = myDevice.importExternalTexture({
source: video,
colorSpace: "display-p3",
});
פרטים על ערימות הזיכרון
כדי לעזור לכם לצפות מראש במגבלות הזיכרון כשאתם מקצים כמויות גדולות במהלך הפיתוח של האפליקציה, requestAdapterInfo() חושף עכשיו מידע על memoryHeaps, כמו הגודל והסוג של ערימות הזיכרון שזמינות במתאם. אפשר לגשת לתכונה הניסיונית הזו רק כשהדגל 'WebGPU Developer Features' ב-chrome://flags/#enable-webgpu-developer-features מופעל. דוגמה: issue dawn:2249.
const adapter = await navigator.gpu.requestAdapter();
const adapterInfo = await adapter.requestAdapterInfo();
for (const { size, properties } of adapterInfo.memoryHeaps) {
console.log(size); // memory heap size in bytes
if (properties & GPUHeapProperty.DEVICE_LOCAL) { /* ... */ }
if (properties & GPUHeapProperty.HOST_VISIBLE) { /* ... */ }
if (properties & GPUHeapProperty.HOST_COHERENT) { /* ... */ }
if (properties & GPUHeapProperty.HOST_UNCACHED) { /* ... */ }
if (properties & GPUHeapProperty.HOST_CACHED) { /* ... */ }
}
עדכונים של Dawn
השיטות HasWGSLLanguageFeature ו-EnumerateWGSLLanguageFeatures ב-wgpu::Instance נוספו כדי לטפל בתכונות של שפת WGSL. מידע נוסף
התכונה הלא סטנדרטית wgpu::Feature::BufferMapExtendedUsages מאפשרת ליצור מאגר GPU עם wgpu::BufferUsage::MapRead או wgpu::BufferUsage::MapWrite וכל wgpu::BufferUsage אחר. דוגמה ובעיה dawn:2204.
wgpu::BufferDescriptor descriptor = {
.size = 128,
.usage = wgpu::BufferUsage::MapWrite | wgpu::BufferUsage::Uniform
};
wgpu::Buffer uniformBuffer = device.CreateBuffer(&descriptor);
uniformBuffer.MapAsync(wgpu::MapMode::Write, 0, 128,
[](WGPUBufferMapAsyncStatus status, void* userdata)
{
wgpu::Buffer* buffer = static_cast<wgpu::Buffer*>(userdata);
memcpy(buffer->GetMappedRange(), data, sizeof(data));
},
&uniformBuffer);
התכונות הבאות מתועדות: ANGLE Texture Sharing, D3D11 multithread protected, Implicit Device Synchronization, Norm16 texture formats, Timestamp Query Inside Passes, Pixel Local Storage, Shader Features ו-Multi Planar Formats.
צוות Chrome יצר מאגר רשמי של Dawn ב-GitHub.
המידע הזה כולל רק נקודות עיקריות. רשימה מלאה של קומיטים
מה חדש ב-WebGPU
רשימה של כל הנושאים שמופיעים בסדרת המאמרים מה חדש ב-WebGPU.
Chrome 143
Chrome 142
Chrome 141
- התאמת גוון IR הושלמה
- ניתוח טווח מספרים שלמים בקומפיילר WGSL
- עדכון SPIR-V 1.4 לבק-אנד ב-Vulkan
- עדכונים של Dawn
Chrome 140
- בקשות ממכשירים צורכות מתאם
- קיצור דרך לשימוש בטקסטורה במקום שבו נעשה שימוש בתצוגת טקסטורה
- הפונקציה textureSampleLevel ב-WGSL תומכת בטקסטורות חד-ממדיות
- הוצאה משימוש של השימוש בטקסטורות של אחסון לקריאה בלבד בפורמט bgra8unorm
- הסרת המאפיין isFallbackAdapter של GPUAdapter
- עדכונים של Dawn
Chrome 139
- תמיכה בטקסטורות תלת-ממדיות בפורמטים דחוסים של BC ו-ASTC
- תכונה חדשה: core-features-and-limits
- גרסת מקור לניסיון של מצב תאימות של WebGPU
- עדכונים של Dawn
Chrome 138
- קיצור דרך לשימוש ב-buffer כמשאב מחייב
- שינויים בדרישות הגודל של מאגרי נתונים זמניים שמנופים בזמן היצירה
- דוח ארכיטקטורה של יחידות GPU מהזמן האחרון
- הוצאה משימוש של המאפיין isFallbackAdapter של GPUAdapter
- עדכונים של Dawn
Chrome 137
- שימוש בתצוגת טקסטורה לקישור externalTexture
- העתקת מאגרי נתונים זמניים בלי לציין היסטים וגודל
- WGSL workgroupUniformLoad משתמשת במצביע לפעולה אטומית
- המאפיין powerPreference של GPUAdapterInfo
- הסרת המאפיין compatibilityMode של GPURequestAdapterOptions
- עדכונים של Dawn
Chrome 136
- המאפיין isFallbackAdapter של GPUAdapterInfo
- שיפורים במשך הזמן לקימפול של Shader ב-D3D12
- שמירה והעתקה של תמונות בלוח הציור
- הסרת ההגבלות של מצב תאימות
- עדכונים של Dawn
Chrome 135
- אפשר לתת ליצור פריסת צינור עיבוד נתונים עם פריסת קבוצת כבילה null
- אפשר לתת לאזורי תצוגה לחרוג מגבולות יעדי הרינדור
- גישה קלה יותר למצב התאימות הניסיוני ב-Android
- הסרת המגבלה של maxInterStageShaderComponents
- עדכונים של Dawn
Chrome 134
- שיפור עומסי עבודה של למידת מכונה באמצעות תת קבוצות
- סוגים ניתנים לסינון של מרקם של מספרים ממשיים כבר לא ייתמכו בתור מרקמים שניתנים למיזוג
- עדכונים של Dawn
Chrome 133
- עוד פורמטים של unorm8x4-bgra ושל רכיב אחד לוורטקסים
- מתן אפשרות לבקש מגבלות לא ידועות עם ערך לא מוגדר
- שינויים בכללי התאמת משתנים של WGSL
- שיפורים בביצועים של WGSL עם discard
- שימוש ב-displaySize של VideoFrame לטקסטורות חיצוניות
- טיפול בתמונות עם כיוונים שאינם ברירת המחדל באמצעות copyExternalImageToTexture
- שיפור חוויית המפתחים
- הפעלת מצב תאימות באמצעות featureLevel
- ניקוי של תכונות ניסיוניות של תת-קבוצות
- הוצאה משימוש של המגבלה maxInterStageShaderComponents
- עדכונים של Dawn
Chrome 132
- שימוש בתצוגת הטקסטורה
- מיזוג של מרקמים מסוג מספר ממשי (float) ב-32 ביט
- המאפיין adapterInfo של GPUDevice
- הגדרת הקשר של לוח הציור בפורמט לא תקין גורמת לשגיאת JavaScript
- הגבלות על דוגמי טקסטורה מסננים
- ניסויים מורחבים בתתי-קבוצות
- שיפור חוויית המפתחים
- תמיכה ניסיונית בפורמטים של טקסטורות מנורמלות של 16 ביט
- עדכונים של Dawn
Chrome 131
- מרחקי חיתוך ב-WGSL
- GPUCanvasContext getConfiguration()
- לטיפוסים פרימיטיביים של נקודות וקווים אסור שתהיה הטיית עומק
- פונקציות מובנות לסריקה מסכמת של תת קבוצות
- תמיכה ניסיונית בקריאה לציורים מרובים בצורה עקיפה
- אפשרות קימפול "מתימטיקה בלבד" של מודול תוכנת הצללה (shader)
- הסרה של GPUAdapter requestAdapterInfo()
- עדכונים של Dawn
Chrome 130
- מיזוג של שני מקורות
- שיפורים במשך הזמן לקימפול של Shader ב-Metal
- הוצאה משימוש של requestAdapterInfo() של GPUAdapter
- עדכונים של Dawn
Chrome 129
Chrome 128
- התנסות עם תת-קבוצות
- הוצאה משימוש של הגדרת הטיית עומק לקווים ולנקודות
- הסתרת אזהרה בכלי הפיתוח לגבי שגיאה שלא נתפסה אם preventDefault
- WGSL interpolate sampling first and either
- עדכונים של Dawn
Chrome 127
- תמיכה ניסיונית ב-OpenGL ES ב-Android
- המאפיין info של GPUAdapter
- שיפורים ביכולת הפעולה ההדדית של WebAssembly
- שיפורים בשגיאות של מקודד הפקודות
- עדכונים של Dawn
Chrome 126
- הגדלת המגבלה של maxTextureArrayLayers
- אופטימיזציה של העלאת מאגרי נתונים זמניים בבק-אנד ב-Vulkan
- שיפורים במשך הזמן לקימפול של תוכנות הצללה (shader)
- מאגרי נתונים זמניים שנשלחים לצורכי פקודות צריכים להיות ייחודיים
- עדכונים של Dawn
Chrome 125
Chrome 124
- טקסטורות של אחסון לקריאה בלבד ולקריאה וכתיבה
- תמיכה בקובצי שירות (service workers) וב-workers משותפים
- מאפייני מידע חדשים של מתאמים
- תיקוני באגים
- עדכונים של Dawn
Chrome 123
- תמיכה בפונקציות מובנות של DP4a ב-WGSL
- פרמטרים של מצביעים ללא הגבלה ב-WGSL
- תהליך הוספה של סוכר תחבירי לביטול ההפניה למרכיבים ב-WGSL
- מצב נפרד של קריאה בלבד לאספקטים של סטנסיל ועומק
- עדכונים של Dawn
Chrome 122
- הרחבת פוטנציאל החשיפה באמצעות מצב תאימות (תכונה בפיתוח)
- הגדלת המגבלה של maxVertexAttributes
- עדכונים של Dawn
Chrome 121
- תמיכה ב-WebGPU ב-Android
- שימוש ב-DXC במקום ב-FXC לקימפול של shader ב-Windows
- שאילתות של חותמות זמן במעברים של חישוב ועיבוד
- נקודות כניסה שמוגדרות כברירת מחדל למודולים של תוכנת הצללה (shader)
- תמיכה ב-display-p3 כמרחב צבעים של GPUExternalTexture
- מידע של ערימות זיכרון (heaps)
- עדכונים של Dawn
Chrome 120
- תמיכה בערכי נקודה צפה (floating-point) של 16 ביט ב-WGSL
- בלבחון את גבולות האפשר
- שינויים במצב סטנסיל עומק
- עדכונים במידע של מתאמים
- קוונטיזציה של שאילתות שכוללות חותמות זמן
- תכונות של ניקיון כללי
Chrome 119
- מרקמים מסוג מספר ממשי (float) ב-32 ביט שאפשר לסנן
- פורמט ורטקסים unorm10-10-10-2
- פורמט טקסטורה rgb10a2uint
- עדכונים של Dawn
Chrome 118
- תמיכה ב-HTMLImageElement וב-ImageData ב-
copyExternalImageToTexture() - תמיכה ניסיונית בטקסטורות של אחסון לקריאה/כתיבה ולקריאה בלבד
- עדכונים של Dawn
Chrome 117
- לא הוגדר ערך למאגר זמני של ורטקסים
- ביטול ההגדרה של קבוצת קישור
- השבתת שגיאות מיצירת צינורות אסינכרוניים לעיבוד נתונים כשמכשיר אבד
- עדכונים על יצירת מודול תוכנת הצללה (shader) בייצוג SPIR-V
- שיפור חוויית המפתחים
- שמירת צינורות לעיבוד נתונים במטמון עם פריסה שנוצרה אוטומטית
- עדכונים של Dawn
Chrome 116
- WebCodecs integration
- המאפיין isFallbackAdapter של GPUAdapter
requestDevice() - הפעלה חלקה של סרטונים אם יש קריאה ל-
importExternalTexture() - התאמה למפרט
- שיפור חוויית המפתחים
- עדכונים של Dawn
Chrome 115
- תוספים נתמכים לשפת WGSL
- תמיכה ניסיונית ב-Direct3D 11
- קבלת GPU נפרד כברירת מחדל בהפעלה באמצעות מתח AC
- שיפור חוויית המפתחים
- עדכונים של Dawn
Chrome 114
- אופטימיזציה של JavaScript
- הפונקציה getCurrentTexture() בלוח ציור שלא הוגדר מקפיצה את הודעת השגיאה InvalidStateError
- עדכונים של WGSL
- עדכונים של Dawn