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