summaryrefslogtreecommitdiff
path: root/benchmarks/gem_wsim.c
AgeCommit message (Collapse)Author
2017-11-22gem_wsim: Busy stats balancersTvrtko Ursulin
Add busy and busy-avg balancers which make balancing decisions by looking at engine busyness via the i915 PMU. And thus are able to make decisions on the actual instantaneous load of the system, and not use metrics that lag behind by a batch or two. In doing so, each client should be able to greedily maximise their own usage of the system, leading to improved load balancing even in the face of other uncooperative clients. On the other hand, we are only using the instantaneous load without coupling in the predictive factor for dispatch and execution length. v2: * Commit text. (Chris Wilson) * Rename get_stats to get_pmu_stats. (Chris Wilson) * Fix PMU readout in VCS remap mode. v3: * Integrated Petri's meson build recipe. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Petri Latvala <petri.latvala@intel.com>
2017-11-21lib: Use drm-uapi/i915_drm.h instead of local defines.Eric Anholt
The MMAP_V2 is replaced by just using MMAP, since the official header has the updated struct. The gem_create_v2 and gem_get_aperture are left as is, because they seem to not be reflected in the UABI header! Signed-off-by: Eric Anholt <eric@anholt.net> Acked-by: Petri Latvala <petri.latvala@intel.com> Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>
2017-06-08gem_wsim: Fix heartbeats in GT2 modeTvrtko Ursulin
VCS2 needs to be redirected to BCS in the remapping mode otherwise the update will get missed. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-06-08gem_wsim: Detect invalid duration rangeTvrtko Ursulin
Maximum has to be larger than minimum and all values positive. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-06-08gem_wsim: Late balancing decision modeTvrtko Ursulin
An approximation of in kernel balancing where balancing decision is postponed to just before submitting the batch for execution. This is implemented by waiting on data dependencies in userspace before submitting each batch. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-06-08gem_wsim: Add static context balancerTvrtko Ursulin
This one assigns VCS engines for each created context in a round- robin fashion. By default each client starts the assignment from the first engine. In global mode the engines are assigned in the round-robin fashion between all the clients - which is identical to the i915 behaviour. Important difference is that doing it from gem_wsim means the assignment always start from a known point so the run-to-run behaviour is identical and repeatable, contrary to when i915 round- robin assignment is used. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-06-08gem_wsim: Added missing -H help textTvrtko Ursulin
Also check that the usage makes sense. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-06-07benchmarks/gem_wsim: Add LOCAL fence definesArkadiusz Hiler
Same as in other benchmarks using them, as not every system is updated with libdrm having those defines. Signed-off-by: Arkadiusz Hiler <arkadiusz.hiler@intel.com> Reviewed-by: Petri Latvala <petri.latvala@intel.com>
2017-05-31lib: Moving gem_execbuf_wr to ioctl_wrappersLukasz Fiedorowicz
gem_execbuf_wr was duplicated in multiple places. Moving everything to lib/ Signed-off-by: Lukasz Fiedorowicz <lukasz.fiedorowicz@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-23gem_wsim: Add global balancing modeTvrtko Ursulin
In this mode ('-G' on the command line) all balancing operations are routed via the first client so the complete balancing state is shared. In other words the overall balancing behaviours is like there is only one client submitting the aggregate workload. This can help with the observed metrics and lead to better balancing decisions in a lot of cases. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-23gem_wsim: Move seqno status page access to helpersTvrtko Ursulin
Refactoring for upcoming changes. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-23gem_wsim: Move seqno allocation and query into helpersTvrtko Ursulin
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-23gem_wsim: Convert clients to threadsTvrtko Ursulin
Will make the userspace balancing daemon simulation easier. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-19gem_wsim: Add missing help text for -pTvrtko Ursulin
Document priority support in the help text. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-17wsim: Allow assigning priorities to each workloadChris Wilson
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-17wsim: Fix reporting of workload/s for slavesChris Wilson
Slaves just keep on running, far beyond the repeat target of their master. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-17gem_wsim: Fix client exit with more than one background workloadTvrtko Ursulin
Need to close more pipe ends to support master with more than one background workloads. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-17wsim: Only require execbuf wr ioctl for FENCE_OUTChris Wilson
Just a micro-optimisation to avoid copying back the struct to userspace if we aren't looking for an output. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-16gem_wsim: Implement sw sync point supportTvrtko Ursulin
Two new workload commands are added, 'f' and 'q.<idx>' which enable creation and signalling of non i915 fences. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-16gem_wsync: Clearer step metadata handlingTvrtko Ursulin
Introduce an anonymous union so each step type can use its own name for the metadata. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-16gem_wsim: Fence supportTvrtko Ursulin
Add sync fence dependency support to workload steps. Only one sync fence dependency per step is supported at the moment. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-16gem_wsim: Simplify batch offset block a bitTvrtko Ursulin
Just compact it a bit by avoiding the min != max check duplication and change get_duration to change w_step. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-16gem_wsim: Add append workloadTvrtko Ursulin
Used with the '-a' command line switch which follows the same usage as '-w' and '-W', it enables to add append workload steps to the end of all normal workloads. This for example allows running any workload in the real-time mode: gem_wsim -w <some-workload> -a p.16667 Makes a workload to be run with the 60 Hz period. At the same time fix the periodic mode execution with dropped frames, or almost dropped frames. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-16gem_wsim: Two small tidiesTvrtko Ursulin
Tidy last in the array presumed offset setting even though this code path is not used at the moment. Also use READ_ONCE on all fields we are trying to read from the status page. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-11gem_wsim: Minimize startup gapTvrtko Ursulin
Do the GPU quiesce as close as possible in time to the start of the workload in order to minimize the gap in engine utilization tracking. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-11wsim: Set the seqno/time stamp on each batch to every engineChris Wilson
We need to track queue depth not just when we are asked to load balance but for specific engine requests so that we include those in our balancing. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Use a loop over engines to calculate RTChris Wilson
Simple code tidy to reduce some duplication. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Feed qd into ewmaChris Wilson
Thinking of qd as an estimator for the speed/latency of execution, applying an average to produce a more stable estimation. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Switch off heartbeat by defaultChris Wilson
For reasons I haven't completely fathomed, adding a heartbeat per frame is upsetting the qd-balancer when run with just a single client, e.g. ./gem_wsim -n 341724 -w wsim/media_mfe2_480p.wsim -c 1 -r 100 -b 1 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Limit the information updated during the heartbeatChris Wilson
The heartbeat should be sent after a period of idleness, it's sole purpose is to update our idea of the external load. As we are sending it currently in the middle of a busy period, we can reduce it to just bumping the queue-depth and reusing the most recent clocks, so that we do not perturb the RT timings greatly. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Limit heartbeats to sync pointsChris Wilson
We only need a heartbeat if we don't have any inflight batches to those engine (the idea is to try and keep track of external usage). It only needs to be periodic, but use once a wait point for simplicity. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Cache the heartbeat batch and locationChris Wilson
Skip having to emit a nop batch to allocation a page and retrieve its address from the kernel by using a persistent object. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Avoid the workload_step being tracked simultaneously on multiple enginesChris Wilson
If the workload is repeated without a full barrier, we may try to add the step onto a new request list before we remove it from its last. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10wsim: Stop treating wrk->status_page as just a single uint32_tChris Wilson
Map the whole page since we actually do use it! Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-10gem_wsim: Refactor balancer selection and help textTvrtko Ursulin
Moved it to a table of balancer structs for easier maintenance and less chance of partial updates. Also added qdr and rand balancers. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-10gem_wsim: Fix master workload handling and statsTvrtko Ursulin
Handling was broken in quiet mode which got expose by the conversion to verbosity. And I want to have the runtime stats for the master workload printed in the default verbosity as well. Also tidy help text adding rtavg to id and group cmd line options not taking any parameters together. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-09wsim: Compact the per-engine heartbeat into a single bufferChris Wilson
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Convert the RT multiple reads to a latched readChris Wilson
Use a latch value to detect read/write tearing of the individual reads. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Fixup breaking the read loop after the seqno advances.Chris Wilson
Oops. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Loop over the multiple u32 reads from the status pageChris Wilson
Use the seqno as a seqlock so that we hopefully only read a coherent set of results for a single update. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: qd throttling now works independently of balancer->get_qdChris Wilson
Since we are tracking the request depth outside of the balancer, we can apply the qd thottle unconditionally. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Introduce verbosityChris Wilson
Slightly more fine-grained than a single on/off switch. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Add rtavg balancerChris Wilson
An improved version of the rt balancer that tracks the average latency on each engine, rather than the last instantaneous execution latency. This makes it much less sensitive to rapid changes, which is both a positive and a negative. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Improve rt balancer to use history across sync pointsChris Wilson
Include the next batch in our estimated run time (that is the time to execute the remaining queued requests plus ours). This is a better estimate of queue length and also provides a bit of history to guide judgement after a sync point. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Add a small tolerance to rt balancingChris Wilson
Discard the low cycles when comparing queue length between engines as we expect a small amount of instabilty. The threshold is chosen to be around 50us. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Send a periodic depth stamp down each queueChris Wilson
In order to measure external load (from other clients), we need a periodic marker along each queue. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: per-engine throttlingChris Wilson
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09wsim: Per-client prng pool for miscellaneous randomsChris Wilson
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
2017-05-09gem_wsim: Slightly more robust workload parsingTvrtko Ursulin
Stronger checks for some of the fields like dependencies out of range and invalid values. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
2017-05-09gem_wsim: Allow symbolic balancer selectionTvrtko Ursulin
Instead of numbers passed to -b also allow strings. Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>