drm/i915/hdcp: switch the HDCP GSC message interface from u8* to void*
authorJani Nikula <jani.nikula@intel.com>
Thu, 24 Apr 2025 20:01:39 +0000 (23:01 +0300)
committerJani Nikula <jani.nikula@intel.com>
Fri, 2 May 2025 10:26:19 +0000 (13:26 +0300)
The in/out buffers are just opaque data, and don't need to be considered
u8*. Switching to void* lets us drop a ton of unnecessary casts.

Cc: Suraj Kandpal <suraj.kandpal@intel.com>
Reviewed-by: Suraj Kandpal <suraj.kandpal@intel.com>
Link: https://lore.kernel.org/r/ea005adb713e85b797d83204c80de0a2a8e5ab47.1745524803.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_hdcp_gsc.c
drivers/gpu/drm/i915/display/intel_hdcp_gsc.h
drivers/gpu/drm/i915/display/intel_hdcp_gsc_message.c
drivers/gpu/drm/xe/display/xe_hdcp_gsc.c

index 77c4df6c6181370621bd58ddd722afe52a72643f..1ea2c7204444379762cad40ed715cf90d4fd6b9d 100644 (file)
@@ -174,8 +174,8 @@ static int intel_gsc_send_sync(struct drm_i915_private *i915,
  * will follow
  */
 ssize_t intel_hdcp_gsc_msg_send(struct intel_hdcp_gsc_context *gsc_context,
-                               u8 *msg_in, size_t msg_in_len,
-                               u8 *msg_out, size_t msg_out_len)
+                               void *msg_in, size_t msg_in_len,
+                               void *msg_out, size_t msg_out_len)
 {
        struct drm_i915_private *i915 = gsc_context->i915;
        struct intel_gt *gt = i915->media_gt;
index 7133e631a938d45a8f1f872792b4df0a4fe7650f..fbef56db54f2554be091bbd08f58aebf4520a7f8 100644 (file)
@@ -14,8 +14,8 @@ struct intel_hdcp_gsc_context;
 
 bool intel_hdcp_gsc_cs_required(struct intel_display *display);
 ssize_t intel_hdcp_gsc_msg_send(struct intel_hdcp_gsc_context *gsc_context,
-                               u8 *msg_in, size_t msg_in_len,
-                               u8 *msg_out, size_t msg_out_len);
+                               void *msg_in, size_t msg_in_len,
+                               void *msg_out, size_t msg_out_len);
 bool intel_hdcp_gsc_check_status(struct intel_display *display);
 
 struct intel_hdcp_gsc_context *intel_hdcp_gsc_context_alloc(struct intel_display *display);
index d87f61d773ca821905a12e1380b8016c85aea241..4226e8705d2b3b425281d33a270630321774046e 100644 (file)
@@ -44,9 +44,9 @@ intel_hdcp_gsc_initiate_session(struct device *dev, struct hdcp_port_data *data,
        session_init_in.port.attached_transcoder = (u8)data->hdcp_transcoder;
        session_init_in.protocol = data->protocol;
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&session_init_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &session_init_in,
                                       sizeof(session_init_in),
-                                      (u8 *)&session_init_out,
+                                      &session_init_out,
                                       sizeof(session_init_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -106,9 +106,9 @@ intel_hdcp_gsc_verify_receiver_cert_prepare_km(struct device *dev,
        memcpy(verify_rxcert_in.r_rx, &rx_cert->r_rx, HDCP_2_2_RRX_LEN);
        memcpy(verify_rxcert_in.rx_caps, rx_cert->rx_caps, HDCP_2_2_RXCAPS_LEN);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&verify_rxcert_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &verify_rxcert_in,
                                       sizeof(verify_rxcert_in),
-                                      (u8 *)&verify_rxcert_out,
+                                      &verify_rxcert_out,
                                       sizeof(verify_rxcert_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed: %zd\n", byte);
@@ -169,9 +169,9 @@ intel_hdcp_gsc_verify_hprime(struct device *dev, struct hdcp_port_data *data,
        memcpy(send_hprime_in.h_prime, rx_hprime->h_prime,
               HDCP_2_2_H_PRIME_LEN);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&send_hprime_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &send_hprime_in,
                                       sizeof(send_hprime_in),
-                                      (u8 *)&send_hprime_out,
+                                      &send_hprime_out,
                                       sizeof(send_hprime_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -220,9 +220,9 @@ intel_hdcp_gsc_store_pairing_info(struct device *dev, struct hdcp_port_data *dat
        memcpy(pairing_info_in.e_kh_km, pairing_info->e_kh_km,
               HDCP_2_2_E_KH_KM_LEN);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&pairing_info_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &pairing_info_in,
                                       sizeof(pairing_info_in),
-                                      (u8 *)&pairing_info_out,
+                                      &pairing_info_out,
                                       sizeof(pairing_info_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -269,8 +269,8 @@ intel_hdcp_gsc_initiate_locality_check(struct device *dev,
        lc_init_in.port.physical_port = (u8)data->hdcp_ddi;
        lc_init_in.port.attached_transcoder = (u8)data->hdcp_transcoder;
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&lc_init_in, sizeof(lc_init_in),
-                                      (u8 *)&lc_init_out, sizeof(lc_init_out));
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &lc_init_in, sizeof(lc_init_in),
+                                      &lc_init_out, sizeof(lc_init_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
                return byte;
@@ -321,9 +321,9 @@ intel_hdcp_gsc_verify_lprime(struct device *dev, struct hdcp_port_data *data,
        memcpy(verify_lprime_in.l_prime, rx_lprime->l_prime,
               HDCP_2_2_L_PRIME_LEN);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&verify_lprime_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &verify_lprime_in,
                                       sizeof(verify_lprime_in),
-                                      (u8 *)&verify_lprime_out,
+                                      &verify_lprime_out,
                                       sizeof(verify_lprime_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -370,8 +370,8 @@ intel_hdcp_gsc_get_session_key(struct device *dev,
        get_skey_in.port.physical_port = (u8)data->hdcp_ddi;
        get_skey_in.port.attached_transcoder = (u8)data->hdcp_transcoder;
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&get_skey_in, sizeof(get_skey_in),
-                                      (u8 *)&get_skey_out, sizeof(get_skey_out));
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &get_skey_in, sizeof(get_skey_in),
+                                      &get_skey_out, sizeof(get_skey_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
                return byte;
@@ -434,9 +434,9 @@ intel_hdcp_gsc_repeater_check_flow_prepare_ack(struct device *dev,
        memcpy(verify_repeater_in.receiver_ids, rep_topology->receiver_ids,
               HDCP_2_2_RECEIVER_IDS_MAX_LEN);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&verify_repeater_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &verify_repeater_in,
                                       sizeof(verify_repeater_in),
-                                      (u8 *)&verify_repeater_out,
+                                      &verify_repeater_out,
                                       sizeof(verify_repeater_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -504,8 +504,8 @@ intel_hdcp_gsc_verify_mprime(struct device *dev,
 
        verify_mprime_in->k = cpu_to_be16(data->k);
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)verify_mprime_in, cmd_size,
-                                      (u8 *)&verify_mprime_out,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, verify_mprime_in, cmd_size,
+                                      &verify_mprime_out,
                                       sizeof(verify_mprime_out));
        kfree(verify_mprime_in);
        if (byte < 0) {
@@ -552,9 +552,9 @@ static int intel_hdcp_gsc_enable_authentication(struct device *dev,
        enable_auth_in.port.attached_transcoder = (u8)data->hdcp_transcoder;
        enable_auth_in.stream_type = data->streams[0].stream_type;
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&enable_auth_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &enable_auth_in,
                                       sizeof(enable_auth_in),
-                                      (u8 *)&enable_auth_out,
+                                      &enable_auth_out,
                                       sizeof(enable_auth_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
@@ -599,9 +599,9 @@ intel_hdcp_gsc_close_session(struct device *dev, struct hdcp_port_data *data)
        session_close_in.port.physical_port = (u8)data->hdcp_ddi;
        session_close_in.port.attached_transcoder = (u8)data->hdcp_transcoder;
 
-       byte = intel_hdcp_gsc_msg_send(gsc_context, (u8 *)&session_close_in,
+       byte = intel_hdcp_gsc_msg_send(gsc_context, &session_close_in,
                                       sizeof(session_close_in),
-                                      (u8 *)&session_close_out,
+                                      &session_close_out,
                                       sizeof(session_close_out));
        if (byte < 0) {
                drm_dbg_kms(display->drm, "intel_hdcp_gsc_msg_send failed. %zd\n", byte);
index 7b8237a5aeee6dbfe854d66c0cb6520b6e3b9be0..7712d53627f02b78162982849d753ffc9d4d9b0e 100644 (file)
@@ -161,8 +161,8 @@ static int xe_gsc_send_sync(struct xe_device *xe,
 }
 
 ssize_t intel_hdcp_gsc_msg_send(struct intel_hdcp_gsc_context *gsc_context,
-                               u8 *msg_in, size_t msg_in_len,
-                               u8 *msg_out, size_t msg_out_len)
+                               void *msg_in, size_t msg_in_len,
+                               void *msg_out, size_t msg_out_len)
 {
        struct xe_device *xe = gsc_context->xe;
        const size_t max_msg_size = PAGE_SIZE - HDCP_GSC_HEADER_SIZE;