[igt-dev] [i-g-t V2 1/2] lib/i915: find scheduler caps for timeslicing

Petri Latvala petri.latvala at intel.com
Mon May 31 11:20:23 UTC 2021


On Fri, May 28, 2021 at 11:25:35AM +0530, Tejas Upadhyay wrote:
> Check scheduler capability for timeslicing in appropriate
> way, which requires wrappers to be created for IGT.
> 
> V2: has_timeslice = has_semaphore && has_preemption || has_guc_submission
> 
> 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..ddfba08b 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));

This mix of bitwise and logical and/ors looks incorrect.

-- 
Petri Latvala



> +}
> +
>  /**
>   * 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");
>  }
> 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 */
> -- 
> 2.31.1
> 
> _______________________________________________
> igt-dev mailing list
> igt-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/igt-dev


More information about the igt-dev mailing list