162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * TI j721e Cadence MHDP8546 DP wrapper 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2020 Texas Instruments Incorporated - http://www.ti.com/ 662306a36Sopenharmony_ci * Author: Jyri Sarha <jsarha@ti.com> 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <linux/io.h> 1062306a36Sopenharmony_ci#include <linux/platform_device.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include "cdns-mhdp8546-j721e.h" 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#define REVISION 0x00 1562306a36Sopenharmony_ci#define DPTX_IPCFG 0x04 1662306a36Sopenharmony_ci#define ECC_MEM_CFG 0x08 1762306a36Sopenharmony_ci#define DPTX_DSC_CFG 0x0c 1862306a36Sopenharmony_ci#define DPTX_SRC_CFG 0x10 1962306a36Sopenharmony_ci#define DPTX_VIF_SECURE_MODE_CFG 0x14 2062306a36Sopenharmony_ci#define DPTX_VIF_CONN_STATUS 0x18 2162306a36Sopenharmony_ci#define PHY_CLK_STATUS 0x1c 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci#define DPTX_SRC_AIF_EN BIT(16) 2462306a36Sopenharmony_ci#define DPTX_SRC_VIF_3_IN30B BIT(11) 2562306a36Sopenharmony_ci#define DPTX_SRC_VIF_2_IN30B BIT(10) 2662306a36Sopenharmony_ci#define DPTX_SRC_VIF_1_IN30B BIT(9) 2762306a36Sopenharmony_ci#define DPTX_SRC_VIF_0_IN30B BIT(8) 2862306a36Sopenharmony_ci#define DPTX_SRC_VIF_3_SEL_DPI5 BIT(7) 2962306a36Sopenharmony_ci#define DPTX_SRC_VIF_3_SEL_DPI3 0 3062306a36Sopenharmony_ci#define DPTX_SRC_VIF_2_SEL_DPI4 BIT(6) 3162306a36Sopenharmony_ci#define DPTX_SRC_VIF_2_SEL_DPI2 0 3262306a36Sopenharmony_ci#define DPTX_SRC_VIF_1_SEL_DPI3 BIT(5) 3362306a36Sopenharmony_ci#define DPTX_SRC_VIF_1_SEL_DPI1 0 3462306a36Sopenharmony_ci#define DPTX_SRC_VIF_0_SEL_DPI2 BIT(4) 3562306a36Sopenharmony_ci#define DPTX_SRC_VIF_0_SEL_DPI0 0 3662306a36Sopenharmony_ci#define DPTX_SRC_VIF_3_EN BIT(3) 3762306a36Sopenharmony_ci#define DPTX_SRC_VIF_2_EN BIT(2) 3862306a36Sopenharmony_ci#define DPTX_SRC_VIF_1_EN BIT(1) 3962306a36Sopenharmony_ci#define DPTX_SRC_VIF_0_EN BIT(0) 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci/* TODO turn DPTX_IPCFG fw_mem_clk_en at pm_runtime_suspend. */ 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_cistatic int cdns_mhdp_j721e_init(struct cdns_mhdp_device *mhdp) 4462306a36Sopenharmony_ci{ 4562306a36Sopenharmony_ci struct platform_device *pdev = to_platform_device(mhdp->dev); 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci mhdp->j721e_regs = devm_platform_ioremap_resource(pdev, 1); 4862306a36Sopenharmony_ci return PTR_ERR_OR_ZERO(mhdp->j721e_regs); 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistatic void cdns_mhdp_j721e_enable(struct cdns_mhdp_device *mhdp) 5262306a36Sopenharmony_ci{ 5362306a36Sopenharmony_ci /* 5462306a36Sopenharmony_ci * Enable VIF_0 and select DPI2 as its input. DSS0 DPI0 is connected 5562306a36Sopenharmony_ci * to eDP DPI2. This is the only supported SST configuration on 5662306a36Sopenharmony_ci * J721E. 5762306a36Sopenharmony_ci */ 5862306a36Sopenharmony_ci writel(DPTX_SRC_VIF_0_EN | DPTX_SRC_VIF_0_SEL_DPI2, 5962306a36Sopenharmony_ci mhdp->j721e_regs + DPTX_SRC_CFG); 6062306a36Sopenharmony_ci} 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_cistatic void cdns_mhdp_j721e_disable(struct cdns_mhdp_device *mhdp) 6362306a36Sopenharmony_ci{ 6462306a36Sopenharmony_ci /* Put everything to defaults */ 6562306a36Sopenharmony_ci writel(0, mhdp->j721e_regs + DPTX_DSC_CFG); 6662306a36Sopenharmony_ci} 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ciconst struct mhdp_platform_ops mhdp_ti_j721e_ops = { 6962306a36Sopenharmony_ci .init = cdns_mhdp_j721e_init, 7062306a36Sopenharmony_ci .enable = cdns_mhdp_j721e_enable, 7162306a36Sopenharmony_ci .disable = cdns_mhdp_j721e_disable, 7262306a36Sopenharmony_ci}; 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ciconst u32 7562306a36Sopenharmony_cimhdp_ti_j721e_bridge_input_bus_flags = DRM_BUS_FLAG_PIXDATA_SAMPLE_NEGEDGE | 7662306a36Sopenharmony_ci DRM_BUS_FLAG_SYNC_SAMPLE_NEGEDGE | 7762306a36Sopenharmony_ci DRM_BUS_FLAG_DE_HIGH; 78