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