[Why]
we need to load SRM before we start HDCP. Because for S3 case the sysfs call 
will be
after we have already enabled HDCP, so we might not be using the latest SRM

[How]
Set srm before starting HDCP.

Signed-off-by: Bhawanpreet Lakha <[email protected]>
Reviewed-by: Rodrigo Siqueira <[email protected]>
---
 drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_hdcp.c | 7 +++++++
 1 file changed, 7 insertions(+)

diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_hdcp.c 
b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_hdcp.c
index 074243a2f808..e6a89cd7ed57 100644
--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_hdcp.c
+++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_hdcp.c
@@ -136,6 +136,13 @@ void hdcp_update_display(struct hdcp_workqueue *hdcp_work,
                hdcp_w->link.adjust.hdcp2.force_type = MOD_HDCP_FORCE_TYPE_0;
 
                if (enable_encryption) {
+                       /* Explicitly set the saved SRM as sysfs call will be 
after we already enabled hdcp
+                        * (s3 resume case)
+                        */
+                       if (hdcp_work->srm_size > 0)
+                               psp_set_srm(hdcp_work->hdcp.config.psp.handle, 
hdcp_work->srm, hdcp_work->srm_size,
+                                           &hdcp_work->srm_version);
+
                        display->adjust.disable = 0;
                        if (content_type == DRM_MODE_HDCP_CONTENT_TYPE0)
                                hdcp_w->link.adjust.hdcp2.force_type = 
MOD_HDCP_FORCE_TYPE_0;
-- 
2.17.1

_______________________________________________
amd-gfx mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to