Die Anzahl der WebGPU-Funktionen mag diesmal etwas gering erscheinen, aber es stehen große Fortschritte bevor. Die nächsten Releases enthalten Funktionen wie DP4a, Lese- und Schreibspeichertexturen, separate Steuerung von Stencil und Tiefenbereich, Rendering in 3D-Texturschichten und Verbesserungen bei der Shader-Kompilierung.
In der Zwischenzeit können Sie sich darüber informieren, wie Sie Ihre Web-KI-Modelltests mit WebGPU- und WebGL-Unterstützung in der headless Chrome-Version optimieren und warum WebGPU in Chrome möglicherweise deaktiviert ist oder nicht funktioniert.
Reichweite mit dem Kompatibilitätsmodus erhöhen (Funktion in der Entwicklung)
WebGPU passt gut zu modernen Grafik-APIs (Vulkan, Metal und D3D12), aber einige Geräte unterstützen diese nicht. Dies schränkt die Verfügbarkeit von WebGPU ein, insbesondere auf Plattformen wie Windows (31% der Chrome-Nutzer haben keine D3D11.1 oder höher), Android (23% haben keine Vulkan 1.1 oder höher) und ChromeOS (die Vulkan-Akzeptanz steigt).
Das Chrome-Team arbeitet an einem Kompatibilitätsmodus in WebGPU, um dieses Problem zu beheben. Dazu wird eine etwas eingeschränkte Version von WebGPU angeboten, die mit älteren APIs wie D3D11 und OpenGL ES funktioniert. Dadurch wird die potenzielle Nutzerbasis von WebGPU erweitert.
Anwendungen, die den Kompatibilitätsmodus verwenden, bleiben vollwertige WebGPU-Anwendungen. Auf Geräten ohne Unterstützung des Kompatibilitätsmodus wird standardmäßig der WebGPU-Kernadapter verwendet, was eine breite Nutzerfreundlichkeit ermöglicht.
Weitere Informationen finden Sie im Vorschlag und im Kommentar.
Limit für maxVertexAttributes erhöhen
Die maximale Anzahl von Attributen insgesamt in Buffers beim Erstellen einer GPURenderPipeline beträgt standardmäßig 16. Mit dem Grenzwert maxVertexAttributes können jetzt bis zu 30 angefordert werden, sofern unterstützt. Weitere Informationen finden Sie im folgenden Beispiel und in Issue dawn:2223.
const adapter = await navigator.gpu.requestAdapter();
if (adapter.limits.maxVertexAttributes < 30) {
// When the desired limit isn't supported, take action to either fall back to
// a code path that does not require the higher limit or notify the user that
// their device does not meet minimum requirements.
}
// Request highest limit of max vertex attributes.
const device = await adapter.requestDevice({
requiredLimits: { maxVertexAttributes: 30 },
});
Dawn-Updates
Es wurde eine neue Instanz-Ein/Aus-Schaltfläche namens „expose_wgsl_experimental_features“ hinzugefügt, mit der die Instanz nur die experimentellen WGSL-Funktionen, aber nicht die unsicheren, freigibt. So können sichere experimentelle WGSL-Funktionen verwendet werden, ohne dass die Ein/Aus-Schaltfläche „allow_unsafe_apis“ aktiviert werden muss. Siehe Problem dawn:2260.
Zu den jüngsten Verbesserungen an den Dawn-Bindungen für Node.js gehören:
GPUSupportedFeatures::getSize()
wurde hinzugefügt.GPUAdapter
Die Funktion „Alte Daten“ wurde implementiert.GPUInternalError
wird jetzt korrekt für Geräte erfasst.- Attribute können jetzt aufgezählt werden.
Dies sind nur einige der wichtigsten Highlights. Eine vollständige Liste der Commits
Das ist neu bei WebGPU
Eine Liste aller Themen, die in der Reihe Was ist neu in WebGPU? behandelt wurden.
Chrome 132
- Verwendung der Texturansicht
- 32-Bit-Gleitkommatextur-Mischverfahren
- Attribut „adapterInfo“ von „GPUDevice“
- Bei der Konfiguration des Canvas-Kontexts mit einem ungültigen Format wird ein JavaScript-Fehler geworfen
- Einschränkungen für Filter-Sampler bei Texturen
- Erweiterte Tests mit Untergruppen
- Entwicklerfreundlichkeit verbessern
- Experimentelle Unterstützung für 16-Bit-normalisierte Texturformate
- Updates zu Dawn
Chrome 131
- Entfernungen in WGSL zuschneiden
- GPUCanvasContext getConfiguration()
- Punkt- und Linienprimitive dürfen keine Tiefenverzerrung haben.
- Integrierte Funktionen für inklusiven Scan für Untergruppen
- Experimentelle Unterstützung für indirekte Multi-Draw-Anweisungen
- Shader-Modul-Kompilierungsoption „strict math“
- GPUAdapter-Methode „requestAdapterInfo()“ entfernen
- Updates zu Dawn
Chrome 130
- Zusammenführen von zwei Quellen
- Verbesserte Shader-Kompilierungszeiten unter Metal
- Einstellung der GPUAdapter-Methode „requestAdapterInfo()“
- Updates zu Dawn
Chrome 129
- HDR-Unterstützung mit Canvas-Tone-Mapping-Modus
- Erweiterter Support für Untergruppen
- Updates zu Dawn
Chrome 128
- Mit Untergruppen experimentieren
- Einstellung der Tiefenverzerrung für Linien und Punkte eingestellt
- Nicht erfasste Fehlerwarnung in den Entwicklertools bei preventDefault ausblenden
- WGSL interpoliert zuerst die Stichprobe und
- Dawn-Updates
Chrome 127
- Experimenteller Support für OpenGL ES auf Android-Geräten
- Attribut „info“ von „GPUAdapter“
- Verbesserungen bei der WebAssembly-Interoperabilität
- Verbesserte Fehlermeldungen beim Befehls-Encoder
- Dawn-Updates
Chrome 126
- Maximale Anzahl von Texture-Array-Ebenen erhöhen
- Optimierung des Pufferuploads für das Vulkan-Backend
- Verbesserte Shader-Kompilierungszeiten
- Eingereichte Befehlspuffere müssen eindeutig sein.
- Updates zu Dawn
Chrome 125
Chrome 124
- Lese- und Lese-/Schreibspeichertextur
- Unterstützung für Dienst- und freigegebene Worker
- Neue Attribute für Adapterinformationen
- Diverse Fehlerkorrekturen
- Dawn-Updates
Chrome 123
- Unterstützung für integrierte DP4a-Funktionen in WGSL
- Uneingeschränkte Zeigerparameter in WGSL
- Syntax-Optimierung für die Dereferenzierung von Kompositen in WGSL
- Separater schreibgeschützter Status für Stencil- und Tiefenansichten
- Dawn-Updates
Chrome 122
- Reichweite mit Kompatibilitätsmodus erhöhen (Funktion in Entwicklung)
- Limit für maxVertexAttributes erhöhen
- Dawn-Updates
Chrome 121
- Unterstützung von WebGPU auf Android-Geräten
- DXC anstelle von FXC für die Shaderkompilierung unter Windows verwenden
- Zeitstempelabfragen in Compute- und Rendering-Passes
- Standardeinstiegspunkte zu Shadermodulen
- Unterstützung von display-p3 als GPUExternalTexture-Farbraum
- Informationen zu Speicherheaps
- Dawn-Updates
Chrome 120
- Unterstützung von 16‑Bit-Gleitkommawerten in WGSL
- Grenzen überschreiten
- Änderungen am Tiefen-/Schatten-Status
- Aktualisierte Informationen zu Adaptern
- Quantisierung von Zeitstempelabfragen
- Funktionen für den Frühjahrsputz
Chrome 119
- Filterbare 32-Bit-Gleitkommatextur
- unorm10-10-10-2-Vertex-Format
- rgb10a2uint-Texturformat
- Updates zu Dawn
Chrome 118
- Unterstützung von HTMLImageElement und ImageData in
copyExternalImageToTexture()
- Experimentelle Unterstützung für Lese-/Schreib- und schreibgeschützte Speichertextur
- Dawn-Updates
Chrome 117
- Vertex-Buffer zurücksetzen
- Bindungsgruppe aufheben
- Fehler bei der Erstellung einer asynchronen Pipeline bei verlorenem Gerät ignorieren
- Aktualisierungen beim Erstellen von SPIR-V-Shadermodulen
- Entwicklerfreundlichkeit verbessern
- Pipelines mit automatisch generiertem Layout im Cache speichern
- Dawn-Updates
Chrome 116
- WebCodecs-Integration
- Verlorenes Gerät, das von GPUAdapter
requestDevice()
zurückgegeben wurde - Videowiedergabe bei Aufruf von
importExternalTexture()
flüssig halten - Einhaltung der Spezifikationen
- Entwicklerfreundlichkeit verbessern
- Dawn-Updates
Chrome 115
- Unterstützte WGSL-Spracherweiterungen
- Experimentelle Unterstützung für Direct3D 11
- Unterstützung für diskrete GPU standardmäßig bei Wechselstromversorgung
- Entwicklerfreundlichkeit verbessern
- Dawn-Updates
Chrome 114
- JavaScript optimieren
- Bei nicht konfiguriertem Canvas wird bei getCurrentTexture() ein InvalidStateError geworfen
- WGSL-Updates
- Updates zu Dawn