Re: [Intel-gfx] [PATCH 30/43] drm/i915: Enable and Disable HDCP2.2 port encryption

2018-02-14 Thread Ramalingam C



On Wednesday 14 February 2018 08:08 PM, Chris Wilson wrote:

Quoting Ramalingam C (2018-02-14 14:13:45)

Implements the enable and disable functions for HDCP2.2 encryption
of the PORT.

Signed-off-by: Ramalingam C 
---
  drivers/gpu/drm/i915/intel_hdcp.c | 50 +++
  1 file changed, 50 insertions(+)

diff --git a/drivers/gpu/drm/i915/intel_hdcp.c 
b/drivers/gpu/drm/i915/intel_hdcp.c
index 0cd637dd3f6b..6a0506cdefd5 100644
--- a/drivers/gpu/drm/i915/intel_hdcp.c
+++ b/drivers/gpu/drm/i915/intel_hdcp.c
@@ -20,6 +20,7 @@
  (enum physical_port) (port))
  #define KEY_LOAD_TRIES 5
  #define HDCP2_LC_RETRY_CNT 3
+#define TIME_FOR_ENCRYPT_STATUS_CHANGE 32
  
  static int intel_hdcp_poll_ksv_fifo(struct intel_digital_port *intel_dig_port,

 const struct intel_hdcp_shim *shim)
@@ -1336,3 +1337,52 @@ static int hdcp2_authenticate_sink(struct intel_hdcp 
*hdcp)
  
 return ret;

  }
+
+static int hdcp2_enable_encryption(struct intel_hdcp *hdcp)
+{
+   struct intel_digital_port *intel_dig_port =
+   conn_to_dig_port(hdcp->connector);
+   struct drm_i915_private *dev_priv = to_i915(hdcp->connector->base.dev);
+   enum port port = hdcp->connector->encoder->port;
+   int ret;
+
+   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_ENCRYPTION_STATUS)
+   return 0;
+
+   if (hdcp->hdcp2_shim->toggle_signalling)
+   hdcp->hdcp2_shim->toggle_signalling(intel_dig_port, true);
+
+   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_AUTH_STATUS) {
+
+   /* Link is Authenticated. Now set for Encryption */
+   I915_WRITE(HDCP2_CTR_DDI(port),
+  I915_READ(HDCP2_CTR_DDI(port)) |
+  CTL_LINK_ENCRYPTION_REQ);
+   }
+
+   ret = wait_for(I915_READ(HDCP2_STATUS_DDI(port)) &
+  LINK_ENCRYPTION_STATUS, TIME_FOR_ENCRYPT_STATUS_CHANGE);

Both of these wait_for are intel_wait_for_register. As a rule of thumb
avoid new (and definitely not repeated) use of wait_for().
-Chris

I will change them into intel_wait_for_register.

Thanks
--Ram

___
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx


Re: [Intel-gfx] [PATCH 30/43] drm/i915: Enable and Disable HDCP2.2 port encryption

2018-02-14 Thread Chris Wilson
Quoting Ramalingam C (2018-02-14 14:13:45)
> Implements the enable and disable functions for HDCP2.2 encryption
> of the PORT.
> 
> Signed-off-by: Ramalingam C 
> ---
>  drivers/gpu/drm/i915/intel_hdcp.c | 50 
> +++
>  1 file changed, 50 insertions(+)
> 
> diff --git a/drivers/gpu/drm/i915/intel_hdcp.c 
> b/drivers/gpu/drm/i915/intel_hdcp.c
> index 0cd637dd3f6b..6a0506cdefd5 100644
> --- a/drivers/gpu/drm/i915/intel_hdcp.c
> +++ b/drivers/gpu/drm/i915/intel_hdcp.c
> @@ -20,6 +20,7 @@
>  (enum physical_port) (port))
>  #define KEY_LOAD_TRIES 5
>  #define HDCP2_LC_RETRY_CNT 3
> +#define TIME_FOR_ENCRYPT_STATUS_CHANGE 32
>  
>  static int intel_hdcp_poll_ksv_fifo(struct intel_digital_port 
> *intel_dig_port,
> const struct intel_hdcp_shim *shim)
> @@ -1336,3 +1337,52 @@ static int hdcp2_authenticate_sink(struct intel_hdcp 
> *hdcp)
>  
> return ret;
>  }
> +
> +static int hdcp2_enable_encryption(struct intel_hdcp *hdcp)
> +{
> +   struct intel_digital_port *intel_dig_port =
> +   conn_to_dig_port(hdcp->connector);
> +   struct drm_i915_private *dev_priv = 
> to_i915(hdcp->connector->base.dev);
> +   enum port port = hdcp->connector->encoder->port;
> +   int ret;
> +
> +   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_ENCRYPTION_STATUS)
> +   return 0;
> +
> +   if (hdcp->hdcp2_shim->toggle_signalling)
> +   hdcp->hdcp2_shim->toggle_signalling(intel_dig_port, true);
> +
> +   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_AUTH_STATUS) {
> +
> +   /* Link is Authenticated. Now set for Encryption */
> +   I915_WRITE(HDCP2_CTR_DDI(port),
> +  I915_READ(HDCP2_CTR_DDI(port)) |
> +  CTL_LINK_ENCRYPTION_REQ);
> +   }
> +
> +   ret = wait_for(I915_READ(HDCP2_STATUS_DDI(port)) &
> +  LINK_ENCRYPTION_STATUS, 
> TIME_FOR_ENCRYPT_STATUS_CHANGE);

Both of these wait_for are intel_wait_for_register. As a rule of thumb
avoid new (and definitely not repeated) use of wait_for().
-Chris
___
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx


[Intel-gfx] [PATCH 30/43] drm/i915: Enable and Disable HDCP2.2 port encryption

2018-02-14 Thread Ramalingam C
Implements the enable and disable functions for HDCP2.2 encryption
of the PORT.

Signed-off-by: Ramalingam C 
---
 drivers/gpu/drm/i915/intel_hdcp.c | 50 +++
 1 file changed, 50 insertions(+)

diff --git a/drivers/gpu/drm/i915/intel_hdcp.c 
b/drivers/gpu/drm/i915/intel_hdcp.c
index 0cd637dd3f6b..6a0506cdefd5 100644
--- a/drivers/gpu/drm/i915/intel_hdcp.c
+++ b/drivers/gpu/drm/i915/intel_hdcp.c
@@ -20,6 +20,7 @@
 (enum physical_port) (port))
 #define KEY_LOAD_TRIES 5
 #define HDCP2_LC_RETRY_CNT 3
+#define TIME_FOR_ENCRYPT_STATUS_CHANGE 32
 
 static int intel_hdcp_poll_ksv_fifo(struct intel_digital_port *intel_dig_port,
const struct intel_hdcp_shim *shim)
@@ -1336,3 +1337,52 @@ static int hdcp2_authenticate_sink(struct intel_hdcp 
*hdcp)
 
return ret;
 }
+
+static int hdcp2_enable_encryption(struct intel_hdcp *hdcp)
+{
+   struct intel_digital_port *intel_dig_port =
+   conn_to_dig_port(hdcp->connector);
+   struct drm_i915_private *dev_priv = to_i915(hdcp->connector->base.dev);
+   enum port port = hdcp->connector->encoder->port;
+   int ret;
+
+   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_ENCRYPTION_STATUS)
+   return 0;
+
+   if (hdcp->hdcp2_shim->toggle_signalling)
+   hdcp->hdcp2_shim->toggle_signalling(intel_dig_port, true);
+
+   if (I915_READ(HDCP2_STATUS_DDI(port)) & LINK_AUTH_STATUS) {
+
+   /* Link is Authenticated. Now set for Encryption */
+   I915_WRITE(HDCP2_CTR_DDI(port),
+  I915_READ(HDCP2_CTR_DDI(port)) |
+  CTL_LINK_ENCRYPTION_REQ);
+   }
+
+   ret = wait_for(I915_READ(HDCP2_STATUS_DDI(port)) &
+  LINK_ENCRYPTION_STATUS, TIME_FOR_ENCRYPT_STATUS_CHANGE);
+   return ret;
+}
+
+static int hdcp2_disable_encryption(struct intel_hdcp *hdcp)
+{
+   struct intel_digital_port *intel_dig_port =
+   conn_to_dig_port(hdcp->connector);
+   struct drm_i915_private *dev_priv = to_i915(hdcp->connector->base.dev);
+   enum port port = hdcp->connector->encoder->port;
+   int ret;
+
+   if (!(I915_READ(HDCP2_STATUS_DDI(port)) & LINK_ENCRYPTION_STATUS))
+   return 0;
+
+   I915_WRITE(HDCP2_CTR_DDI(port),
+  I915_READ(HDCP2_CTR_DDI(port)) & ~CTL_LINK_ENCRYPTION_REQ);
+   ret = wait_for(!(I915_READ(HDCP2_STATUS_DDI(port)) &
+  LINK_ENCRYPTION_STATUS), TIME_FOR_ENCRYPT_STATUS_CHANGE);
+
+   if (hdcp->hdcp2_shim->toggle_signalling)
+   hdcp->hdcp2_shim->toggle_signalling(intel_dig_port, false);
+
+   return ret;
+}
-- 
2.7.4

___
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx