[PATCH] drm/i915/gvt: Init virtual DP port according to host VBT info

Zhenyu Wang zhenyuw at linux.intel.com
Tue Aug 15 08:21:37 UTC 2017


On 2017.08.15 10:51:14 +0800, Xiong Zhang wrote:
> Currently we fixed virtual DP monitor on SKL/KBL PORT_D and BDW
> PORT_B, guest opregion is a copy of host opregion. If vbt port
> info of host opregion claim host PORT_D / PORT_B doesn't support
> DP, then guest kernel won't create DP connector on corresponding
> port, finally guest couldn't find any outputs.
> 
> This patch loop the ports, once its host vbt port info says
> it could support dp, the virtual dp monitor will attach to it.
>

For opregion, the plan is to provide virtualized VBT according to
virtual display implement. Although this change might be better than
current hack, it would still have issue e.g on platform without intel
display at all. So hopefully we would fix this when fix fully virtualized
display.

> Signed-off-by: Xiong Zhang <xiong.y.zhang at intel.com>
> ---
>  drivers/gpu/drm/i915/gvt/display.c | 41 ++++++++++++++++++++++++++++----------
>  1 file changed, 30 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/gvt/display.c b/drivers/gpu/drm/i915/gvt/display.c
> index 7cb0818..da6ec01 100644
> --- a/drivers/gpu/drm/i915/gvt/display.c
> +++ b/drivers/gpu/drm/i915/gvt/display.c
> @@ -412,12 +412,13 @@ void intel_gvt_emulate_vblank(struct intel_gvt *gvt)
>   */
>  void intel_vgpu_clean_display(struct intel_vgpu *vgpu)
>  {
> -	struct drm_i915_private *dev_priv = vgpu->gvt->dev_priv;
> +	enum port port;
>  
> -	if (IS_SKYLAKE(dev_priv) || IS_KABYLAKE(dev_priv))
> -		clean_virtual_dp_monitor(vgpu, PORT_D);
> -	else
> -		clean_virtual_dp_monitor(vgpu, PORT_B);
> +	for (port = PORT_B; port < PORT_E; port++) {
> +		if (intel_vgpu_has_monitor_on_port(vgpu, port) &&
> +		    intel_vgpu_port_is_dp(vgpu, port))
> +			clean_virtual_dp_monitor(vgpu, port);
> +	}
>  }
>  
>  /**
> @@ -433,15 +434,33 @@ void intel_vgpu_clean_display(struct intel_vgpu *vgpu)
>  int intel_vgpu_init_display(struct intel_vgpu *vgpu, u64 resolution)
>  {
>  	struct drm_i915_private *dev_priv = vgpu->gvt->dev_priv;
> +	enum port port;
> +	enum intel_vgpu_port_type type;
>  
>  	intel_vgpu_init_i2c_edid(vgpu);
>  
> -	if (IS_SKYLAKE(dev_priv) || IS_KABYLAKE(dev_priv))
> -		return setup_virtual_dp_monitor(vgpu, PORT_D, GVT_DP_D,
> -						resolution);
> -	else
> -		return setup_virtual_dp_monitor(vgpu, PORT_B, GVT_DP_B,
> -						resolution);
> +	for (port = PORT_B; port < PORT_E; port++) {
> +		if (!dev_priv->vbt.ddi_port_info[port].supports_dp)
> +			continue;
> +
> +		switch (port) {
> +		case PORT_B:
> +			type = GVT_DP_B;
> +			break;
> +		case PORT_C:
> +			type = GVT_DP_C;
> +			break;
> +		case PORT_D:
> +			type = GVT_DP_D;
> +			break;
> +		default:
> +			BUG();
> +		}
> +
> +		return setup_virtual_dp_monitor(vgpu, port, type, resolution);
> +	}
> +
> +	return -EINVAL;
>  }
>  
>  /**
> -- 
> 2.7.4
> 
> _______________________________________________
> intel-gvt-dev mailing list
> intel-gvt-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gvt-dev

-- 
Open Source Technology Center, Intel ltd.

$gpg --keyserver wwwkeys.pgp.net --recv-keys 4D781827
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 195 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/intel-gvt-dev/attachments/20170815/ba66f27b/attachment.sig>


More information about the intel-gvt-dev mailing list