diff --git a/sample/workloadSimulator/index.html b/sample/workloadSimulator/index.html
index 41dba534..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({
- nonGuaranteedFeatures: 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;
@@ -731,15 +716,10 @@ Web graphics workload simulator
}
try {
const canvasView = canvasContext.getCurrentTexture().createView();
- const commandBuffers = [];
+
device.queue.writeBuffer(uniformBuffer, 0, new Float32Array([position[0] / size * 2 - 1, 1 - position[1] * 2 / size]));
let buffer = null;
- // Start off by writing a timestamp for the beginning of the frame.
- const timestampEncoder = device.createCommandEncoder();
- if (querySet) timestampEncoder.writeTimestamp(querySet, 0);
- device.queue.submit([timestampEncoder.finish()]);
-
// Upload data using createBuffer with mappedAtCreation.
if (bufferData.value > 0) {
buffer = device.createBuffer({ size: bufferDataArray.byteLength, usage: GPUBufferUsage.VERTEX, mappedAtCreation: true });
@@ -890,39 +870,7 @@ Web graphics workload simulator
}
passEncoder.end();
if (buffer) buffer.destroy();
- let queryBuffer;
- if (querySet) {
- // Timestamp for the end of the frame.
- commandEncoder.writeTimestamp(querySet, 1);
- // 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);
- }
- commandBuffers.push(commandEncoder.finish());
- device.queue.submit(commandBuffers);
- 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);
- });
- }
+ device.queue.submit([commandEncoder.finish()]);
} 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) {