From 0980f2f7a5da0bcda5e97ae50f257b66729094d4 Mon Sep 17 00:00:00 2001 From: James Darpinian Date: Fri, 3 Jan 2025 13:39:33 -0800 Subject: [PATCH] Remove timestamp-query support The timestamp-query feature as currently specced cannot reliably measure anything other than the length of a single render or compute pass. --- sample/workloadSimulator/index.html | 61 +---------------------------- 1 file changed, 2 insertions(+), 59 deletions(-) diff --git a/sample/workloadSimulator/index.html b/sample/workloadSimulator/index.html index 49bc90c1..7b185b8f 100644 --- a/sample/workloadSimulator/index.html +++ b/sample/workloadSimulator/index.html @@ -418,9 +418,6 @@

Web graphics workload simulator

let renderBundleAfterScissor; let renderBundleNumDrawCalls; let renderBundleInstances; -let querySet; -let queryBuffers = []; -let queryResolveBuffer; let mapAsyncArray = new Float32Array(0); let mapAsyncTargetBuffer; let mapAsyncBufferSize = 0; @@ -448,8 +445,6 @@

Web graphics workload simulator

let timeout = null; let rafPending = 0; let postMessagePending = 0; -let timeQueryResultsMs = []; -let lastTimeQueryTime = 0; const animationDirection = [1, 1]; async function render(fromRaf, fromPostMessage) { @@ -596,10 +591,7 @@

Web graphics workload simulator

features: Array.from(adapter.features || []).sort(), limits: adapter.limits }, 0, 2); - const useTimestampQueries = adapter.features.has('timestamp-query'); - device = await adapter.requestDevice({ - requiredFeatures: useTimestampQueries ? ['timestamp-query'] : [], - }); + device = await adapter.requestDevice({}); device.addEventListener('uncapturederror', (e)=>{ if (!errorMessage.textContent) errorMessage.textContent = 'Uncaptured error: ' + e.error.message; }); @@ -709,13 +701,6 @@

Web graphics workload simulator

{ binding: 2, resource: texture.createView() }, ], }); - if (useTimestampQueries && device.createQuerySet) { - querySet = device.createQuerySet({type: 'timestamp', count: 2}); - queryResolveBuffer = device.createBuffer({ - size: 16, - usage: GPUBufferUsage.QUERY_RESOLVE | GPUBufferUsage.COPY_SRC, - }); - } } catch(e) { if (!errorMessage.textContent) errorMessage.textContent = "Error initializing WebGPU: " + e; return; @@ -732,13 +717,6 @@

Web graphics workload simulator

try { const canvasView = canvasContext.getCurrentTexture().createView(); - // Start off by writing a timestamp for the beginning of the frame. - if (querySet) { - const timestampEncoder = device.createCommandEncoder(); - timestampEncoder.beginComputePass({ timestampWrites: { querySet, beginningOfPassWriteIndex: 0, } }).end(); - device.queue.submit([timestampEncoder.finish()]); - } - device.queue.writeBuffer(uniformBuffer, 0, new Float32Array([position[0] / size * 2 - 1, 1 - position[1] * 2 / size])); let buffer = null; @@ -817,7 +795,6 @@

Web graphics workload simulator

clearValue: [1, 1, 1, 1], storeOp: multisampling.checked ? 'discard' : 'store', }, ], - timestampWrites: querySet ? { querySet, endOfPassWriteIndex: 1 } : undefined, }); if (useRenderBundles.checked && renderBundle && instances == renderBundleInstances && renderBundleNumDrawCalls == numDrawCalls) { // If we have valid RenderBundles to use, execute them and we're done. @@ -893,36 +870,7 @@

Web graphics workload simulator

} passEncoder.end(); if (buffer) buffer.destroy(); - let queryBuffer; - if (querySet) { - // We create a queue of staging buffers to hold the timestamps while we - // map them into CPU memory. If the queue is empty, create a new buffer. - if (queryBuffers.length == 0) { - const buffer = device.createBuffer({ - size: 16, - usage: GPUBufferUsage.COPY_DST | GPUBufferUsage.MAP_READ, - }); - queryBuffers.push(buffer); - } - // Write the timestamps into a GPU side buffer and copy into the staging buffer. - queryBuffer = queryBuffers.shift(); - commandEncoder.resolveQuerySet(querySet, 0, 2, queryResolveBuffer, 0); - commandEncoder.copyBufferToBuffer(queryResolveBuffer, 0, queryBuffer, 0, 16); - } device.queue.submit([commandEncoder.finish()]); - if (querySet) { - // Once the staging buffer is mapped we can finally calculate the frame duration - // and put the staging buffer back into the queue. - queryBuffer.mapAsync(GPUMapMode.READ).then(()=>{ - let array = new BigInt64Array(queryBuffer.getMappedRange()); - let nanoseconds = Number(array[1] - array[0]); - if (timeQueryResultsMs.length > 10) timeQueryResultsMs.shift(); - timeQueryResultsMs.push(nanoseconds / 1000000); - lastTimeQueryTime = performance.now(); - queryBuffer.unmap(); - queryBuffers.push(queryBuffer); - }); - } } catch(e) { if (!errorMessage.textContent) errorMessage.textContent = "Error: " + e; throw e; @@ -1174,12 +1122,7 @@

Web graphics workload simulator

} if (showFps.checked) { - if (performance.now() - lastTimeQueryTime < 1000 && timeQueryResultsMs.length) { - const averageTime = timeQueryResultsMs.reduce((x, y) => x + y) / timeQueryResultsMs.length; - fpsSpan.textContent = `${counters['render'].fps.toFixed()}, ${averageTime.toFixed(1)} ms GPU time`; - } else { - fpsSpan.textContent = counters['render'].fps.toFixed(); - } + fpsSpan.textContent = counters['render'].fps.toFixed(); if (showStats.checked) { let text = ""; for (let key in counters) {