Files
renderdoc/util/test/tests/Vulkan/VK_Counters.py
T
baldurk 1bfe6d1492 Add dedicated test for VK_Counters so GPU duration isn't degenerate
* Some cards run it so fast that the triangle takes "0" microseconds
2023-09-12 21:53:23 +01:00

96 lines
4.2 KiB
Python

import renderdoc as rd
import rdtest
class VK_Counters(rdtest.TestCase):
demos_test_name = 'VK_Counters'
def check_capture(self):
avail = self.controller.EnumerateCounters()
wanted = [rd.GPUCounter.EventGPUDuration, rd.GPUCounter.VSInvocations, rd.GPUCounter.PSInvocations,
rd.GPUCounter.IAPrimitives, rd.GPUCounter.RasterizedPrimitives, rd.GPUCounter.RasterizerInvocations,
rd.GPUCounter.SamplesPassed]
counters = list(set(avail).intersection(set(wanted)))
results = self.controller.FetchCounters(counters)
descs = {}
for c in counters:
descs[c] = self.controller.DescribeCounter(c)
action = self.find_action("Draw")
durationAction = action.next
# filter to only results from the draw
results = [r for r in results if r.eventId == action.eventId or r.eventId == durationAction.eventId]
ps = samp = None
for r in results:
desc: rd.CounterDescription = descs[r.counter]
if r.eventId == durationAction.eventId:
if r.counter == rd.GPUCounter.EventGPUDuration:
val = 0.0
if desc.resultByteWidth == 8:
val = r.value.d
elif desc.resultByteWidth == 4:
val = r.value.f
# should not be smaller than 0.1 microseconds, and should not be more than 10 milliseconds
if val < 1.0e-7 or val > 0.01:
raise rdtest.TestFailureException("{} of draw {}s is unexpected".format(desc.name, val))
else:
rdtest.log.success("{} of draw {}s is expected".format(desc.name, val))
else:
if (r.counter == rd.GPUCounter.IAPrimitives or r.counter == rd.GPUCounter.RasterizedPrimitives or
r.counter == rd.GPUCounter.RasterizerInvocations):
val = 0
if desc.resultByteWidth == 8:
val = r.value.u64
elif desc.resultByteWidth == 4:
val = r.value.u32
if val != 1:
raise rdtest.TestFailureException("{} of draw {} is unexpected".format(desc.name, val))
else:
rdtest.log.success("{} of draw {} is expected".format(desc.name, val))
elif r.counter == rd.GPUCounter.VSInvocations:
val = 0
if desc.resultByteWidth == 8:
val = r.value.u64
elif desc.resultByteWidth == 4:
val = r.value.u32
if val != 3:
raise rdtest.TestFailureException("{} of draw {} is unexpected".format(desc.name, val))
else:
rdtest.log.success("{} of draw {} is expected".format(desc.name, val))
elif r.counter == rd.GPUCounter.PSInvocations or r.counter == rd.GPUCounter.SamplesPassed:
val = 0
if desc.resultByteWidth == 8:
val = r.value.u64
elif desc.resultByteWidth == 4:
val = r.value.u32
if r.counter == rd.GPUCounter.PSInvocations:
ps = val
else:
samp = val
# should be around 15000 pixels, but allow for slight rasterization differences
if val < 14500 or val > 15500:
raise rdtest.TestFailureException("{} of draw {} is unexpected".format(desc.name, val))
else:
rdtest.log.success("{} of draw {} is expected".format(desc.name, val))
if ps is not None and samp is not None:
# allow 500 difference for overshading counting
if abs(ps - samp) > 500:
raise rdtest.TestFailureException("Samples passed {} and PS invocations {} don't match".format(samp, ps))
else:
rdtest.log.success("Samples passed {} and PS invocations {} match".format(samp, ps))
rdtest.log.success("All counters have expected values")