kernel/0066-fix-Delete-HDCP1.4-authentication-key.patch
2025-01-02 22:30:57 -05:00

499 lines
7.4 KiB
Diff

From 6dcf142df7b7761fb851b43aba876dabc96a8630 Mon Sep 17 00:00:00 2001
From: denglei <denglei@eswincomputing.com>
Date: Mon, 8 Jul 2024 19:56:12 +0800
Subject: [PATCH 066/222] fix:Delete HDCP1.4 authentication key.
Changelogs:
Delete HDCP1.4 authentication key.
Signed-off-by: denglei <denglei@eswincomputing.com>
---
drivers/gpu/drm/eswin/dw_hdmi_hdcp.c | 396 +++------------------------
1 file changed, 32 insertions(+), 364 deletions(-)
diff --git a/drivers/gpu/drm/eswin/dw_hdmi_hdcp.c b/drivers/gpu/drm/eswin/dw_hdmi_hdcp.c
index b69b1be14e0d..a6bb3a8b939d 100644
--- a/drivers/gpu/drm/eswin/dw_hdmi_hdcp.c
+++ b/drivers/gpu/drm/eswin/dw_hdmi_hdcp.c
@@ -22,7 +22,6 @@
#include <linux/module.h>
#include <linux/of_device.h>
#include <linux/spinlock.h>
-//#include <linux/soc/eswin/eswin_vendor_storage.h>
#include <linux/uaccess.h>
#include <linux/fs.h>
#include <linux/module.h>
@@ -43,332 +42,6 @@
#define DPK_WR_OK_TIMEOUT_US 30000
#define HDMI_HDCP1X_ID 5
-/* HDCP DCP KEY & SEED */
-const u8 hdcp_const_data[320] = {
- /* 0 1 2 3 4 5 6 */
- 0x00,
- 0x00,
- 0xf0,
- 0xff,
- 0xff,
- 0x00,
- 0x00,
- 0x00, //KSV
- 0x91,
- 0x71,
- 0x7,
- 0x42,
- 0x86,
- 0xC1,
- 0xD1,
- 0x89,
- 0x0E,
- 0x2D,
- 0xFF,
- 0x92,
- 0x95,
- 0x28,
- 0xF4,
- 0x7D,
- 0x7B,
- 0x1F,
- 0x2A,
- 0xD9,
- 0xBB,
- 0xE4,
- 0xFD,
- 0x10,
- 0x18,
- 0xAA,
- 0xFB,
- 0x99,
- 0x5A,
- 0x83,
- 0x97,
- 0xD5,
- 0xDA,
- 0x85,
- 0x2D,
- 0x52,
- 0x8B,
- 0xB5,
- 0xB2,
- 0x49,
- 0xDC,
- 0x64,
- 0xC6,
- 0x62,
- 0xF0,
- 0xDB,
- 0xAA,
- 0x48,
- 0x2E,
- 0x84,
- 0xAD,
- 0x21,
- 0xCD,
- 0xB9,
- 0xD6,
- 0x47,
- 0xC7,
- 0xD7,
- 0xD1,
- 0x9F,
- 0xD4,
- 0xB1,
- 0x29,
- 0x4E,
- 0x98,
- 0xC6,
- 0xAE,
- 0xA4,
- 0xF5,
- 0xA6,
- 0xFE,
- 0x68,
- 0x3D,
- 0x43,
- 0x97,
- 0x7B,
- 0x52,
- 0xC7,
- 0xA1,
- 0x65,
- 0x7B,
- 0xF9,
- 0x8C,
- 0xCC,
- 0x20,
- 0x8C,
- 0xCB,
- 0x2F,
- 0x7D,
- 0xFA,
- 0xC5,
- 0x80,
- 0xD8,
- 0xDB,
- 0x5A,
- 0x72,
- 0x2D,
- 0xE1,
- 0xA6,
- 0x79,
- 0xF4,
- 0xAE,
- 0x96,
- 0x1D,
- 0xE8,
- 0x28,
- 0x85,
- 0x5F,
- 0xBD,
- 0x64,
- 0xF8,
- 0xBF,
- 0x7A,
- 0xE7,
- 0xFF,
- 0xBC,
- 0x1F,
- 0xC6,
- 0x75,
- 0x56,
- 0xB9,
- 0xF9,
- 0x0F,
- 0x36,
- 0x29,
- 0x5A,
- 0x3B,
- 0xF3,
- 0x76,
- 0x7B,
- 0x8B,
- 0xF8,
- 0xFD,
- 0x13,
- 0x80,
- 0x49,
- 0xAB,
- 0x5C,
- 0x12,
- 0x63,
- 0xB9,
- 0xE7,
- 0x91,
- 0x2A,
- 0xBA,
- 0x82,
- 0xF3,
- 0xCD,
- 0xFA,
- 0xFB,
- 0x4E,
- 0xA7,
- 0xE1,
- 0xBD,
- 0x8B,
- 0xC3,
- 0x24,
- 0xEC,
- 0x31,
- 0xBC,
- 0x1,
- 0xB1,
- 0xCE,
- 0x9A,
- 0x4,
- 0x9C,
- 0x69,
- 0x5D,
- 0xBA,
- 0x3C,
- 0xF7,
- 0x97,
- 0x50,
- 0x88,
- 0xE2,
- 0xA2,
- 0xE1,
- 0x3,
- 0xDB,
- 0x39,
- 0xDD,
- 0x93,
- 0x0A,
- 0x24,
- 0x5C,
- 0x6E,
- 0x17,
- 0xE9,
- 0x1,
- 0x4C,
- 0x25,
- 0xF5,
- 0x9,
- 0x24,
- 0xC6,
- 0x91,
- 0xC6,
- 0x6A,
- 0x7A,
- 0x40,
- 0x89,
- 0x62,
- 0x7F,
- 0xED,
- 0x6B,
- 0x8E,
- 0x5F,
- 0x79,
- 0xAD,
- 0xF2,
- 0x50,
- 0x59,
- 0xC4,
- 0x11,
- 0x2E,
- 0x1,
- 0xC2,
- 0xDC,
- 0x8,
- 0xCE,
- 0xDC,
- 0x51,
- 0x14,
- 0xF4,
- 0x8C,
- 0x3D,
- 0x9E,
- 0xB7,
- 0x16,
- 0xB3,
- 0x9C,
- 0xF3,
- 0x55,
- 0xC0,
- 0xCE,
- 0x74,
- 0x5B,
- 0x19,
- 0x4E,
- 0xF5,
- 0x39,
- 0x37,
- 0xA6,
- 0xEA,
- 0xB5,
- 0x20,
- 0xBF,
- 0xD7,
- 0x79,
- 0x24,
- 0xE2,
- 0x8D,
- 0x13,
- 0xBC,
- 0x38,
- 0x10,
- 0x60,
- 0x93,
- 0xAE,
- 0x70,
- 0xA9,
- 0x66,
- 0x81,
- 0xF3,
- 0x19,
- 0xEC,
- 0x45,
- 0xEC,
- 0xE5,
- 0x5,
- 0x47,
- 0xE4,
- 0x67,
- 0x65,
- 0x4C,
- 0x62,
- 0x1,
- 0x98,
- 0xA3,
- 0x52,
- //SHA1
- 0x18,
- 0xb4,
- 0x70,
- 0x59,
- 0xfe,
- 0x13,
- 0x38,
- 0xc4,
- 0x15,
- 0xae,
- 0xf0,
- 0x81,
- 0xcb,
- 0x96,
- 0x27,
- 0xe7,
- 0xd9,
- 0x7b,
- 0xc5,
- 0x27,
- 0x20, //seed 0x2020
- 0x20,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
- 0x00,
-};
-
/* HDCP Registers */
#define HDMI_A_KSVMEMCTRL 0x5016
#define HDMI_HDCPREG_ANCONF 0x7805
@@ -466,15 +139,11 @@ static void hdcp_modb(struct dw_hdcp *hdcp, u8 data, u8 mask, unsigned int reg)
static int hdcp_load_keys_cb(struct dw_hdcp *hdcp)
{
- u32 size;
u8 hdcp_vendor_data[320];
- int i;
-#if 0
- int j;
- struct file *fp;
- loff_t pos = 0;
- ssize_t nread;
-#endif
+ struct file *fp;
+ loff_t pos = 0;
+ ssize_t nread;
+
hdcp->keys = kmalloc(HDCP_KEY_SIZE, GFP_KERNEL);
if (!hdcp->keys)
return -ENOMEM;
@@ -484,27 +153,11 @@ static int hdcp_load_keys_cb(struct dw_hdcp *hdcp)
kfree(hdcp->keys);
return -ENOMEM;
}
-#if 1
- // size = eswin_vendor_read(HDMI_HDCP1X_ID, hdcp_vendor_data, 314);
-
- for (i = 0; i < sizeof(hdcp_vendor_data); i++)
- hdcp_vendor_data[i] = hdcp_const_data[i];
- size = 320;
- if (size < (HDCP_KEY_SIZE + HDCP_KEY_SEED_SIZE)) {
- dev_dbg(hdcp->dev, "HDCP: read size %d\n", size);
- memset(hdcp->keys, 0, HDCP_KEY_SIZE);
- memset(hdcp->seeds, 0, HDCP_KEY_SEED_SIZE);
- } else {
- memcpy(hdcp->keys, hdcp_vendor_data, HDCP_KEY_SIZE);
- memcpy(hdcp->seeds, hdcp_vendor_data + HDCP_KEY_SIZE,
- HDCP_KEY_SEED_SIZE);
- }
-#else
fp = filp_open(HDCP_KEY_PATH, O_RDONLY, 0644);
if (IS_ERR(fp)) {
- printk("Error, Tx_A2_TestDPK_encrypted.txt doesn't exist.\n");
- return 0;
+ printk("Error, Tx_A2_TestDPK_encrypted doesn't exist.\n");
+ goto err;
}
nread = kernel_read(fp, hdcp_vendor_data, sizeof(hdcp_vendor_data),
@@ -513,7 +166,8 @@ static int hdcp_load_keys_cb(struct dw_hdcp *hdcp)
if (nread != sizeof(hdcp_vendor_data)) {
printk("Error, failed to read %ld bytes to non volatile memory area,ret %ld\n",
sizeof(hdcp_vendor_data), nread);
- return -EIO;
+ filp_close(fp, NULL);
+ goto err;
}
memcpy(hdcp->keys, hdcp_vendor_data, HDCP_KEY_SIZE);
@@ -521,9 +175,13 @@ static int hdcp_load_keys_cb(struct dw_hdcp *hdcp)
HDCP_KEY_SEED_SIZE);
filp_close(fp, NULL);
-#endif
-
return 0;
+err:
+ kfree(hdcp->keys);
+ kfree(hdcp->seeds);
+ hdcp->keys = NULL;
+ hdcp->seeds = NULL;
+ return -EIO;
}
static int dw_hdmi_hdcp_load_key(struct dw_hdcp *hdcp)
@@ -599,6 +257,7 @@ static int dw_hdmi_hdcp1x_start(struct dw_hdcp *hdcp)
int i;
int val;
u8 An[8];
+ int ret;
if (!hdcp->enable)
return -EPERM;
@@ -607,11 +266,6 @@ static int dw_hdmi_hdcp1x_start(struct dw_hdcp *hdcp)
hdcp->status == DW_HDCP_AUTH_SUCCESS)
return 0;
- /* disable the pixel clock*/
- dev_dbg(hdcp->dev, "start hdcp with disable hdmi pixel clock\n");
- hdcp_modb(hdcp, HDMI_MC_CLKDIS_PIXELCLK_DISABLE,
- HDMI_MC_CLKDIS_PIXELCLK_MASK, HDMI_MC_CLKDIS);
-
/* Update An */
get_random_bytes(&An, sizeof(An));
for (i = 0; i < 8; i++)
@@ -619,8 +273,18 @@ static int dw_hdmi_hdcp1x_start(struct dw_hdcp *hdcp)
hdcp->write(hdmi, 0x01, HDMI_HDCPREG_ANCONF);
- if (!(hdcp->read(hdmi, HDMI_HDCPREG_RMSTS) & 0x3f))
- dw_hdmi_hdcp_load_key(hdcp);
+ if (!(hdcp->read(hdmi, HDMI_HDCPREG_RMSTS) & 0x3f)) {
+ ret = dw_hdmi_hdcp_load_key(hdcp);
+ if (ret) {
+ dev_err(hdcp->dev, "load hdcp key failed, ret=%d\n", ret);
+ return ret;
+ }
+ }
+
+ /* disable the pixel clock*/
+ dev_dbg(hdcp->dev, "start hdcp with disable hdmi pixel clock\n");
+ hdcp_modb(hdcp, HDMI_MC_CLKDIS_PIXELCLK_DISABLE,
+ HDMI_MC_CLKDIS_PIXELCLK_MASK, HDMI_MC_CLKDIS);
if (hdcp->hdcp2) {
for (i = 0; i < 100; i++) {
@@ -879,6 +543,7 @@ static ssize_t hdcp_enable_write(struct device *device,
{
bool enable;
struct dw_hdcp *hdcp = g_hdcp;
+ int ret;
if (!hdcp)
return -EINVAL;
@@ -895,7 +560,10 @@ static ssize_t hdcp_enable_write(struct device *device,
if (hdcp->read(hdcp->hdmi, HDMI_PHY_STAT0) &
HDMI_PHY_HPD) {
- dw_hdmi_hdcp1x_start(hdcp);
+ ret = dw_hdmi_hdcp1x_start(hdcp);
+ if (ret) {
+ hdcp->enable = 0;
+ }
}
} else {
if (hdcp->status != DW_HDCP_DISABLED) {
--
2.47.0