Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/drivers/gpu/drm/bridge/cadence/cdns-mhdp8546-j721e.c
26516 views
1
// SPDX-License-Identifier: GPL-2.0
2
/*
3
* TI j721e Cadence MHDP8546 DP wrapper
4
*
5
* Copyright (C) 2020 Texas Instruments Incorporated - http://www.ti.com/
6
* Author: Jyri Sarha <[email protected]>
7
*/
8
9
#include <linux/io.h>
10
#include <linux/platform_device.h>
11
12
#include "cdns-mhdp8546-j721e.h"
13
14
#define REVISION 0x00
15
#define DPTX_IPCFG 0x04
16
#define ECC_MEM_CFG 0x08
17
#define DPTX_DSC_CFG 0x0c
18
#define DPTX_SRC_CFG 0x10
19
#define DPTX_VIF_SECURE_MODE_CFG 0x14
20
#define DPTX_VIF_CONN_STATUS 0x18
21
#define PHY_CLK_STATUS 0x1c
22
23
#define DPTX_SRC_AIF_EN BIT(16)
24
#define DPTX_SRC_VIF_3_IN30B BIT(11)
25
#define DPTX_SRC_VIF_2_IN30B BIT(10)
26
#define DPTX_SRC_VIF_1_IN30B BIT(9)
27
#define DPTX_SRC_VIF_0_IN30B BIT(8)
28
#define DPTX_SRC_VIF_3_SEL_DPI5 BIT(7)
29
#define DPTX_SRC_VIF_3_SEL_DPI3 0
30
#define DPTX_SRC_VIF_2_SEL_DPI4 BIT(6)
31
#define DPTX_SRC_VIF_2_SEL_DPI2 0
32
#define DPTX_SRC_VIF_1_SEL_DPI3 BIT(5)
33
#define DPTX_SRC_VIF_1_SEL_DPI1 0
34
#define DPTX_SRC_VIF_0_SEL_DPI2 BIT(4)
35
#define DPTX_SRC_VIF_0_SEL_DPI0 0
36
#define DPTX_SRC_VIF_3_EN BIT(3)
37
#define DPTX_SRC_VIF_2_EN BIT(2)
38
#define DPTX_SRC_VIF_1_EN BIT(1)
39
#define DPTX_SRC_VIF_0_EN BIT(0)
40
41
/* TODO turn DPTX_IPCFG fw_mem_clk_en at pm_runtime_suspend. */
42
43
static int cdns_mhdp_j721e_init(struct cdns_mhdp_device *mhdp)
44
{
45
struct platform_device *pdev = to_platform_device(mhdp->dev);
46
47
mhdp->j721e_regs = devm_platform_ioremap_resource(pdev, 1);
48
return PTR_ERR_OR_ZERO(mhdp->j721e_regs);
49
}
50
51
static void cdns_mhdp_j721e_enable(struct cdns_mhdp_device *mhdp)
52
{
53
/*
54
* Enable VIF_0 and select DPI2 as its input. DSS0 DPI0 is connected
55
* to eDP DPI2. This is the only supported SST configuration on
56
* J721E.
57
*/
58
writel(DPTX_SRC_VIF_0_EN | DPTX_SRC_VIF_0_SEL_DPI2,
59
mhdp->j721e_regs + DPTX_SRC_CFG);
60
}
61
62
static void cdns_mhdp_j721e_disable(struct cdns_mhdp_device *mhdp)
63
{
64
/* Put everything to defaults */
65
writel(0, mhdp->j721e_regs + DPTX_DSC_CFG);
66
}
67
68
const struct mhdp_platform_ops mhdp_ti_j721e_ops = {
69
.init = cdns_mhdp_j721e_init,
70
.enable = cdns_mhdp_j721e_enable,
71
.disable = cdns_mhdp_j721e_disable,
72
};
73
74
const u32
75
mhdp_ti_j721e_bridge_input_bus_flags = DRM_BUS_FLAG_PIXDATA_SAMPLE_NEGEDGE |
76
DRM_BUS_FLAG_SYNC_SAMPLE_NEGEDGE |
77
DRM_BUS_FLAG_DE_HIGH;
78
79