mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 6b9748f868
			
		
	
	
		6b9748f868
		
	
	
	
	
		
			
			Add support for wrapper settings for DSI bridge on j721e. Also enable DPI0 --------------- ----------------------- | -------| |------- | | DSS | DPI2 |----->| DPI0 | DSI Wrapper | | -------| |------- | --------------- ----------------------- As shown above DPI2 output of DSS is connected to DPI0 input of DSI Wrapper, DSI wrapper gives control wheather to enable/disable DPI0 input. In j721e above is the only configuration supported Signed-off-by: Rahul T R <r-ravikumar@ti.com> Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Andrzej Hajda <andrzej.hajda@intel.com> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com> Link: https://patchwork.freedesktop.org/patch/msgid/20230103101951.10963-6-r-ravikumar@ti.com
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| /*
 | |
|  * TI j721e Cadence DSI wrapper
 | |
|  *
 | |
|  * Copyright (C) 2022 Texas Instruments Incorporated - http://www.ti.com/
 | |
|  * Author: Rahul T R <r-ravikumar@ti.com>
 | |
|  */
 | |
| 
 | |
| #include <linux/io.h>
 | |
| #include <linux/platform_device.h>
 | |
| 
 | |
| #include "cdns-dsi-j721e.h"
 | |
| 
 | |
| #define DSI_WRAP_REVISION		0x0
 | |
| #define DSI_WRAP_DPI_CONTROL		0x4
 | |
| #define DSI_WRAP_DSC_CONTROL		0x8
 | |
| #define DSI_WRAP_DPI_SECURE		0xc
 | |
| #define DSI_WRAP_DSI_0_ASF_STATUS	0x10
 | |
| 
 | |
| #define DSI_WRAP_DPI_0_EN		BIT(0)
 | |
| #define DSI_WRAP_DSI2_MUX_SEL		BIT(4)
 | |
| 
 | |
| static int cdns_dsi_j721e_init(struct cdns_dsi *dsi)
 | |
| {
 | |
| 	struct platform_device *pdev = to_platform_device(dsi->base.dev);
 | |
| 
 | |
| 	dsi->j721e_regs = devm_platform_ioremap_resource(pdev, 1);
 | |
| 	return PTR_ERR_OR_ZERO(dsi->j721e_regs);
 | |
| }
 | |
| 
 | |
| static void cdns_dsi_j721e_enable(struct cdns_dsi *dsi)
 | |
| {
 | |
| 	/*
 | |
| 	 * Enable DPI0 as its input. DSS0 DPI2 is connected
 | |
| 	 * to DSI DPI0. This is the only supported configuration on
 | |
| 	 * J721E.
 | |
| 	 */
 | |
| 	writel(DSI_WRAP_DPI_0_EN, dsi->j721e_regs + DSI_WRAP_DPI_CONTROL);
 | |
| }
 | |
| 
 | |
| static void cdns_dsi_j721e_disable(struct cdns_dsi *dsi)
 | |
| {
 | |
| 	/* Put everything to defaults  */
 | |
| 	writel(0, dsi->j721e_regs + DSI_WRAP_DPI_CONTROL);
 | |
| }
 | |
| 
 | |
| const struct cdns_dsi_platform_ops dsi_ti_j721e_ops = {
 | |
| 	.init = cdns_dsi_j721e_init,
 | |
| 	.enable = cdns_dsi_j721e_enable,
 | |
| 	.disable = cdns_dsi_j721e_disable,
 | |
| };
 |