[Intel-gfx] [PATCH v2 3/6] drm/i915: Always enable execlists on BDW for vgpu
Joonas Lahtinen
joonas.lahtinen at linux.intel.com
Mon Aug 31 05:50:47 PDT 2015
On pe, 2015-08-28 at 15:41 +0800, Zhiyuan Lv wrote:
> Broadwell hardware supports both ring buffer mode and execlist mode.
> When i915 runs inside a VM with Intel GVT-g, we allow execlist mode
> only.
>
> The main reason of EXECLIST only is that GVT-g does not support the
> dynamic mode switch between ring buffer mode and execlist mode when
> running multiple virtual machines.
>
> v2:
> - Adjust the position of vgpu check in sanitize function (Joonas)
> - Add vgpu error check in context initialization. (Joonas, Daniel)
>
> Signed-off-by: Zhiyuan Lv <zhiyuan.lv at intel.com>
> Signed-off-by: Zhi Wang <zhi.a.wang at intel.com>
Reviewed-by: Joonas Lahtinen <joonas.lahtinen at linux.intel.com>
> ---
> drivers/gpu/drm/i915/i915_gem_context.c | 7 +++++++
> drivers/gpu/drm/i915/intel_lrc.c | 6 ++++++
> 2 files changed, 13 insertions(+)
>
> diff --git a/drivers/gpu/drm/i915/i915_gem_context.c
> b/drivers/gpu/drm/i915/i915_gem_context.c
> index 8e893b3..74aa0c9 100644
> --- a/drivers/gpu/drm/i915/i915_gem_context.c
> +++ b/drivers/gpu/drm/i915/i915_gem_context.c
> @@ -332,6 +332,13 @@ int i915_gem_context_init(struct drm_device
> *dev)
> if (WARN_ON(dev_priv->ring[RCS].default_context))
> return 0;
>
> + if (intel_vgpu_active(dev) &&
> HAS_LOGICAL_RING_CONTEXTS(dev)) {
> + if (!i915.enable_execlists) {
> + DRM_INFO("Only EXECLIST mode is supported in
> vgpu.\n");
> + return -EINVAL;
> + }
> + }
> +
> if (i915.enable_execlists) {
> /* NB: intentionally left blank. We will allocate
> our own
> * backing objects as we need them, thank you very
> much */
> diff --git a/drivers/gpu/drm/i915/intel_lrc.c
> b/drivers/gpu/drm/i915/intel_lrc.c
> index 258af9b..e9520af 100644
> --- a/drivers/gpu/drm/i915/intel_lrc.c
> +++ b/drivers/gpu/drm/i915/intel_lrc.c
> @@ -236,6 +236,12 @@ int intel_sanitize_enable_execlists(struct
> drm_device *dev, int enable_execlists
> {
> WARN_ON(i915.enable_ppgtt == -1);
>
> + /* On platforms with execlist available, vGPU will only
> + * support execlist mode, no ring buffer mode.
> + */
> + if (HAS_LOGICAL_RING_CONTEXTS(dev) &&
> intel_vgpu_active(dev))
> + return 1;
> +
> if (INTEL_INFO(dev)->gen >= 9)
> return 1;
>
More information about the Intel-gfx
mailing list