90 lines
3.2 KiB
Diff
90 lines
3.2 KiB
Diff
From 3a636aeeb872a3d0719e1cb5e054b0d4af485aaa Mon Sep 17 00:00:00 2001
|
|
From: yiguo <yiguo@eswincomputing.com>
|
|
Date: Fri, 31 May 2024 17:23:52 +0800
|
|
Subject: [PATCH 042/222] fix:adapt linux6.6
|
|
|
|
Changelogs:
|
|
1. add dma-noncoherent; in dts.
|
|
2. add func of start repeatly.
|
|
3. add hdcp1x enable/disable.
|
|
---
|
|
arch/riscv/boot/dts/eswin/eswin-win2030-die0-soc.dtsi | 1 +
|
|
arch/riscv/boot/dts/eswin/eswin-win2030-die1-soc.dtsi | 1 +
|
|
drivers/gpu/drm/eswin/dw_hdmi_hdcp2.c | 7 +++----
|
|
3 files changed, 5 insertions(+), 4 deletions(-)
|
|
|
|
diff --git a/arch/riscv/boot/dts/eswin/eswin-win2030-die0-soc.dtsi b/arch/riscv/boot/dts/eswin/eswin-win2030-die0-soc.dtsi
|
|
index fb5920315be4..3db50303c303 100644
|
|
--- a/arch/riscv/boot/dts/eswin/eswin-win2030-die0-soc.dtsi
|
|
+++ b/arch/riscv/boot/dts/eswin/eswin-win2030-die0-soc.dtsi
|
|
@@ -1905,6 +1905,7 @@ dw_hdmi_hdcp2: hdmi-hdcp2@50290000 {
|
|
clocks = <&d0_clock WIN2030_CLK_VO_CFG_CLK>,
|
|
<&d0_clock WIN2030_CLK_VO_HDMI_IESMCLK>;
|
|
clock-names ="pclk_hdcp2", "hdcp2_clk_hdmi";
|
|
+ dma-noncoherent;
|
|
};
|
|
|
|
d0_usbdrd3_0: usb0@50480000 {
|
|
diff --git a/arch/riscv/boot/dts/eswin/eswin-win2030-die1-soc.dtsi b/arch/riscv/boot/dts/eswin/eswin-win2030-die1-soc.dtsi
|
|
index bbb403cf4776..48a042d05e8e 100644
|
|
--- a/arch/riscv/boot/dts/eswin/eswin-win2030-die1-soc.dtsi
|
|
+++ b/arch/riscv/boot/dts/eswin/eswin-win2030-die1-soc.dtsi
|
|
@@ -1836,6 +1836,7 @@ d1_dw_hdmi_hdcp2: hdmi-hdcp2@70290000 {
|
|
clocks = <&d1_clock WIN2030_CLK_VO_CFG_CLK>,
|
|
<&d1_clock WIN2030_CLK_VO_HDMI_IESMCLK>;
|
|
clock-names ="pclk_hdcp2", "hdcp2_clk_hdmi";
|
|
+ dma-noncoherent;
|
|
};
|
|
|
|
d1_wdt0: watchdog@0x70800000 {
|
|
diff --git a/drivers/gpu/drm/eswin/dw_hdmi_hdcp2.c b/drivers/gpu/drm/eswin/dw_hdmi_hdcp2.c
|
|
index 63ce0ae4fde3..e387f079eb89 100644
|
|
--- a/drivers/gpu/drm/eswin/dw_hdmi_hdcp2.c
|
|
+++ b/drivers/gpu/drm/eswin/dw_hdmi_hdcp2.c
|
|
@@ -61,6 +61,7 @@
|
|
*/
|
|
|
|
#define MAX_HL_DEVICES 16
|
|
+#define TROOT_GRIFFIN
|
|
|
|
static bool randomize_mem = false;
|
|
module_param(randomize_mem, bool, 0);
|
|
@@ -344,7 +345,6 @@ static int alloc_dma_areas(hl_device *hl_dev,
|
|
hl_dev->code_base = info->code_base;
|
|
hl_dev->code = phys_to_virt(hl_dev->code_base);
|
|
} else {
|
|
- dma_set_mask_and_coherent(g_dw_hdcp2->dev, DMA_BIT_MASK(32));
|
|
hl_dev->code =
|
|
dma_alloc_coherent(g_dw_hdcp2->dev, hl_dev->code_size,
|
|
&hl_dev->code_base, GFP_KERNEL);
|
|
@@ -387,7 +387,6 @@ static long init(struct file *f, void __user *arg)
|
|
|
|
if (copy_from_user(&info, arg, sizeof info) != 0)
|
|
return -EFAULT;
|
|
-
|
|
hl_dev = alloc_hl_dev_slot(&info);
|
|
if (!hl_dev)
|
|
return -EMFILE;
|
|
@@ -528,9 +527,8 @@ static long hld_ioctl(struct file *f, unsigned int cmd, unsigned long arg)
|
|
static const struct file_operations hld_file_operations = {
|
|
#ifdef CONFIG_COMPAT
|
|
.compat_ioctl = hld_ioctl,
|
|
-#else
|
|
- .unlocked_ioctl = hld_ioctl,
|
|
#endif
|
|
+ .unlocked_ioctl = hld_ioctl,
|
|
.owner = THIS_MODULE,
|
|
};
|
|
|
|
@@ -708,6 +706,7 @@ static int eswin_hdmi_hdcp2_probe(struct platform_device *pdev)
|
|
g_dw_hdcp2->start = dw_hdcp2_start;
|
|
hld_init();
|
|
dw_hdmi2_hdcp2_clk_enable(hdcp2_dev);
|
|
+ dma_set_mask_and_coherent(hdcp2_dev, DMA_BIT_MASK(32));
|
|
dw_hdmi_hdcp2_init(g_dw_hdcp2);
|
|
dw_hdmi_hdcp2_start(3);
|
|
|
|
--
|
|
2.47.0
|
|
|