summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2017-12-15 14:33:36 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2017-12-22 15:08:42 +0000
commitc0a60eb5096a39440c9599af7b5cc34c59e2c712 (patch)
tree69c04523b3b49adb0759451bd75b7957f2035a80 /tests
parent865a47ca2b93b208ba016f3c4fc00831ec7bfec6 (diff)
igt/perf_pmu: Tighten busy measurement
Sleep for a known duration. In particular, CI once saw a measurement for busyness greater than the intended batch_duration! v2: Go back to starting pmu sampling outside of spinner; the GPU should be idle. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=104241 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/perf_pmu.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/tests/perf_pmu.c b/tests/perf_pmu.c
index db769611..38fd05dc 100644
--- a/tests/perf_pmu.c
+++ b/tests/perf_pmu.c
@@ -103,7 +103,7 @@ static void pmu_read_multi(int fd, unsigned int num, uint64_t *val)
igt_assert_f((double)(x) <= (1.0 + (tolerance)) * (double)(ref) && \
(double)(x) >= (1.0 - (tolerance)) * (double)(ref), \
"'%s' != '%s' (%f not within %f%% tolerance of %f)\n",\
- #x, #ref, (double)(x), (tolerance) * 100.0, (double)ref)
+ #x, #ref, (double)(x), (tolerance) * 100.0, (double)(ref))
/*
* Helper for cases where we assert on time spent sleeping (directly or
@@ -133,30 +133,28 @@ static unsigned int e2ring(int gem_fd, const struct intel_execution_engine2 *e)
static void
single(int gem_fd, const struct intel_execution_engine2 *e, bool busy)
{
- double ref = busy ? batch_duration_ns : 0.0f;
+ unsigned long slept;
igt_spin_t *spin;
uint64_t val;
int fd;
fd = open_pmu(I915_PMU_ENGINE_BUSY(e->class, e->instance));
- if (busy) {
+ if (busy)
spin = igt_spin_batch_new(gem_fd, 0, e2ring(gem_fd, e), 0);
- igt_spin_batch_set_timeout(spin, batch_duration_ns);
- } else {
- usleep(batch_duration_ns / 1000);
- }
+ else
+ spin = NULL;
- if (busy)
- gem_sync(gem_fd, spin->handle);
+ slept = measured_usleep(batch_duration_ns / 1000);
+ igt_spin_batch_end(spin);
val = pmu_read_single(fd);
- if (busy)
- igt_spin_batch_free(gem_fd, spin);
+ igt_spin_batch_free(gem_fd, spin);
close(fd);
- assert_within_epsilon(val, ref, tolerance);
+ assert_within_epsilon(val, busy ? slept : 0.f, tolerance);
+ gem_quiescent_gpu(gem_fd);
}
static void log_busy(int fd, unsigned int num_engines, uint64_t *val)