Commit dfaf305b authored by Suraj Kandpal's avatar Suraj Kandpal Committed by Ankit Nautiyal

drm/i915/hdcp: HDCP Capability for the downstream device

Currently we are only checking capability of remote device and not
immediate downstream device but during capability check we need are
concerned with only the HDCP capability of downstream device.
During i915_display_info reporting we need HDCP Capability for both
the monitors and downstream branch device if any this patch adds that.

--v2
-Use MST Hub HDCP version [Ankit]

--v3
-Redefined how we seprate remote and direct read to make sure HDMI
shim functions are not touched [Ankit]

--v4
- Fix the conditions so that hdcp_info with remote_req true is sent
only when encoder is mst [Ankit]

--v5
-No need to have the MST Hub version in i915_hdcp_sink_capability[Ankit]
Signed-off-by: default avatarSuraj Kandpal <suraj.kandpal@intel.com>
Reviewed-by: default avatarAnkit Nautiyal <ankit.k.nautiyal@intel.com>
Signed-off-by: default avatarAnkit Nautiyal <ankit.k.nautiyal@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240223081453.1576918-9-suraj.kandpal@intel.com
parent 813cca96
...@@ -188,7 +188,8 @@ static void intel_panel_info(struct seq_file *m, ...@@ -188,7 +188,8 @@ static void intel_panel_info(struct seq_file *m,
} }
static void intel_hdcp_info(struct seq_file *m, static void intel_hdcp_info(struct seq_file *m,
struct intel_connector *intel_connector) struct intel_connector *intel_connector,
bool remote_req)
{ {
bool hdcp_cap, hdcp2_cap; bool hdcp_cap, hdcp2_cap;
...@@ -197,8 +198,14 @@ static void intel_hdcp_info(struct seq_file *m, ...@@ -197,8 +198,14 @@ static void intel_hdcp_info(struct seq_file *m,
goto out; goto out;
} }
hdcp_cap = intel_hdcp_get_capability(intel_connector); if (remote_req) {
hdcp2_cap = intel_hdcp2_get_capability(intel_connector); intel_hdcp_get_remote_capability(intel_connector,
&hdcp_cap,
&hdcp2_cap);
} else {
hdcp_cap = intel_hdcp_get_capability(intel_connector);
hdcp2_cap = intel_hdcp2_get_capability(intel_connector);
}
if (hdcp_cap) if (hdcp_cap)
seq_puts(m, "HDCP1.4 "); seq_puts(m, "HDCP1.4 ");
...@@ -285,7 +292,11 @@ static void intel_connector_info(struct seq_file *m, ...@@ -285,7 +292,11 @@ static void intel_connector_info(struct seq_file *m,
} }
seq_puts(m, "\tHDCP version: "); seq_puts(m, "\tHDCP version: ");
intel_hdcp_info(m, intel_connector); if (intel_encoder_is_mst(encoder)) {
intel_hdcp_info(m, intel_connector, true);
seq_puts(m, "\tMST Hub HDCP version: ");
}
intel_hdcp_info(m, intel_connector, false);
seq_printf(m, "\tmax bpc: %u\n", connector->display_info.bpc); seq_printf(m, "\tmax bpc: %u\n", connector->display_info.bpc);
...@@ -1131,7 +1142,7 @@ static int i915_hdcp_sink_capability_show(struct seq_file *m, void *data) ...@@ -1131,7 +1142,7 @@ static int i915_hdcp_sink_capability_show(struct seq_file *m, void *data)
seq_printf(m, "%s:%d HDCP version: ", connector->base.name, seq_printf(m, "%s:%d HDCP version: ", connector->base.name,
connector->base.base.id); connector->base.base.id);
intel_hdcp_info(m, connector); intel_hdcp_info(m, connector, false);
out: out:
drm_modeset_unlock(&i915->drm.mode_config.connection_mutex); drm_modeset_unlock(&i915->drm.mode_config.connection_mutex);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment