[igt-dev] [i-g-t V3 1/2] lib/i915: find scheduler caps for timeslicing
Tvrtko Ursulin
tvrtko.ursulin at linux.intel.com
Tue Jun 1 10:07:32 UTC 2021
On 31/05/2021 14:41, Tejas Upadhyay wrote:
> Check scheduler capability for timeslicing in appropriate
> way, which requires wrappers to be created for IGT.
>
> V3:
> removed conditional error - petri
> V2: has_timeslice = has_semaphore && has_preemption ||
> has_guc_submission - Tvrtko
>
> Signed-off-by: Tejas Upadhyay <tejaskumarx.surendrakumar.upadhyay at intel.com>
> ---
> lib/i915/gem_scheduler.c | 21 +++++++++++++++++++++
> lib/i915/gem_scheduler.h | 1 +
> 2 files changed, 22 insertions(+)
>
> diff --git a/lib/i915/gem_scheduler.c b/lib/i915/gem_scheduler.c
> index 184da843..f59c451f 100644
> --- a/lib/i915/gem_scheduler.c
> +++ b/lib/i915/gem_scheduler.c
> @@ -29,6 +29,7 @@
> #include "ioctl_wrappers.h"
>
> #include "i915/gem_scheduler.h"
> +#include "i915/gem_submission.h"
>
> /**
> * SECTION:gem_scheduler
> @@ -129,6 +130,22 @@ bool gem_scheduler_has_engine_busy_stats(int fd)
> I915_SCHEDULER_CAP_ENGINE_BUSY_STATS;
> }
>
> +/**
> + * gem_scheduler_has_timeslicing:
> + * @fd: open i915 drm file descriptor
> + *
> + * Feature test macro to query whether the driver supports using HW preemption
> + * to implement timeslicing of userspace batches. This allows userspace to
> + * implement micro-level scheduling within their own batches.
> + */
> +bool gem_scheduler_has_timeslicing(int fd)
> +{
> + return ((gem_scheduler_capability(fd) &
> + (I915_SCHEDULER_CAP_PREEMPTION |
> + I915_SCHEDULER_CAP_SEMAPHORES))
> + || gem_has_guc_submission(fd));
> +}
> +
> /**
> * gem_scheduler_print_capability:
> * @fd: open i915 drm file descriptor
> @@ -151,4 +168,8 @@ void gem_scheduler_print_capability(int fd)
> igt_info(" - With HW semaphores enabled\n");
> if (caps & I915_SCHEDULER_CAP_ENGINE_BUSY_STATS)
> igt_info(" - With engine busy statistics\n");
> + if ((caps & (I915_SCHEDULER_CAP_PREEMPTION
> + | I915_SCHEDULER_CAP_SEMAPHORES))
> + || gem_has_guc_submission(fd))
> + igt_info(" - With user timeslicing enabled\n");
I don't think it's "user timeslicing" but just timeslicing. Otherwise
looks okay.
Regards,
Tvrtko
> }
> diff --git a/lib/i915/gem_scheduler.h b/lib/i915/gem_scheduler.h
> index 14bd4cac..d43e84bd 100644
> --- a/lib/i915/gem_scheduler.h
> +++ b/lib/i915/gem_scheduler.h
> @@ -32,6 +32,7 @@ bool gem_scheduler_has_ctx_priority(int fd);
> bool gem_scheduler_has_preemption(int fd);
> bool gem_scheduler_has_semaphores(int fd);
> bool gem_scheduler_has_engine_busy_stats(int fd);
> +bool gem_scheduler_has_timeslicing(int fd);
> void gem_scheduler_print_capability(int fd);
>
> #endif /* GEM_SCHEDULER_H */
>
More information about the igt-dev
mailing list