mirror of
				https://github.com/Ysurac/openmptcprouter.git
				synced 2025-03-09 15:40:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			146 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 6e3f7375acdcf714d1fcbae1238cd39cc9391560 Mon Sep 17 00:00:00 2001
 | |
| From: Bibby Hsieh <bibby.hsieh@mediatek.com>
 | |
| Date: Fri, 21 Sep 2018 11:28:22 +0800
 | |
| Subject: [PATCH] drm/mediatek: config component output by device node port
 | |
| 
 | |
| We can select output component by decive node port.
 | |
| Main path default output component is DSI.
 | |
| External path default output component is DPI.
 | |
| 
 | |
| Signed-off-by: Bibby Hsieh <bibby.hsieh@mediatek.com>
 | |
| 
 | |
| added small fixes for warnings
 | |
| 
 | |
| Signed-off-by: Frank Wunderlich <frank-w@public-files.de>
 | |
| Tested-by: Frank Wunderlich <frank-w@public-files.de>
 | |
| ---
 | |
|  drivers/gpu/drm/mediatek/mtk_drm_drv.c | 46 ++++++++++++++++++++++----
 | |
|  drivers/gpu/drm/mediatek/mtk_drm_drv.h |  4 +--
 | |
|  2 files changed, 42 insertions(+), 8 deletions(-)
 | |
| 
 | |
| diff --git a/drivers/gpu/drm/mediatek/mtk_drm_drv.c b/drivers/gpu/drm/mediatek/mtk_drm_drv.c
 | |
| index 352b81a7a670..33511c77b800 100644
 | |
| --- a/drivers/gpu/drm/mediatek/mtk_drm_drv.c
 | |
| +++ b/drivers/gpu/drm/mediatek/mtk_drm_drv.c
 | |
| @@ -21,6 +21,13 @@
 | |
|  #include <drm/drm_of.h>
 | |
|  #include <drm/drm_probe_helper.h>
 | |
|  #include <drm/drm_vblank.h>
 | |
| +#include <linux/component.h>
 | |
| +#include <linux/iommu.h>
 | |
| +#include <linux/of.h>
 | |
| +#include <linux/of_address.h>
 | |
| +#include <linux/of_graph.h>
 | |
| +#include <linux/of_platform.h>
 | |
| +#include <linux/pm_runtime.h>
 | |
|  
 | |
|  #include "mtk_drm_crtc.h"
 | |
|  #include "mtk_drm_ddp.h"
 | |
| @@ -121,7 +128,7 @@ static const struct drm_mode_config_funcs mtk_drm_mode_config_funcs = {
 | |
|  	.atomic_commit = mtk_atomic_commit,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt2701_mtk_ddp_main[] = {
 | |
| +static enum mtk_ddp_comp_id mt2701_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_OVL0,
 | |
|  	DDP_COMPONENT_RDMA0,
 | |
|  	DDP_COMPONENT_COLOR0,
 | |
| @@ -129,12 +136,12 @@ static const enum mtk_ddp_comp_id mt2701_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_DSI0,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt2701_mtk_ddp_ext[] = {
 | |
| +static enum mtk_ddp_comp_id mt2701_mtk_ddp_ext[] = {
 | |
|  	DDP_COMPONENT_RDMA1,
 | |
|  	DDP_COMPONENT_DPI0,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt2712_mtk_ddp_main[] = {
 | |
| +static enum mtk_ddp_comp_id mt2712_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_OVL0,
 | |
|  	DDP_COMPONENT_COLOR0,
 | |
|  	DDP_COMPONENT_AAL0,
 | |
| @@ -144,7 +151,7 @@ static const enum mtk_ddp_comp_id mt2712_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_PWM0,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt2712_mtk_ddp_ext[] = {
 | |
| +static enum mtk_ddp_comp_id mt2712_mtk_ddp_ext[] = {
 | |
|  	DDP_COMPONENT_OVL1,
 | |
|  	DDP_COMPONENT_COLOR1,
 | |
|  	DDP_COMPONENT_AAL1,
 | |
| @@ -160,7 +167,7 @@ static const enum mtk_ddp_comp_id mt2712_mtk_ddp_third[] = {
 | |
|  	DDP_COMPONENT_PWM2,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt8173_mtk_ddp_main[] = {
 | |
| +static enum mtk_ddp_comp_id mt8173_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_OVL0,
 | |
|  	DDP_COMPONENT_COLOR0,
 | |
|  	DDP_COMPONENT_AAL0,
 | |
| @@ -171,7 +178,7 @@ static const enum mtk_ddp_comp_id mt8173_mtk_ddp_main[] = {
 | |
|  	DDP_COMPONENT_PWM0,
 | |
|  };
 | |
|  
 | |
| -static const enum mtk_ddp_comp_id mt8173_mtk_ddp_ext[] = {
 | |
| +static enum mtk_ddp_comp_id mt8173_mtk_ddp_ext[] = {
 | |
|  	DDP_COMPONENT_OVL1,
 | |
|  	DDP_COMPONENT_COLOR1,
 | |
|  	DDP_COMPONENT_GAMMA,
 | |
| @@ -510,6 +517,7 @@ static int mtk_drm_probe(struct platform_device *pdev)
 | |
|  
 | |
|  	/* Iterate over sibling DISP function blocks */
 | |
|  	for_each_child_of_node(dev->of_node->parent, node) {
 | |
| +		struct device_node *port, *ep, *remote;
 | |
|  		const struct of_device_id *of_id;
 | |
|  		enum mtk_ddp_comp_type comp_type;
 | |
|  		int comp_id;
 | |
| @@ -572,6 +580,32 @@ static int mtk_drm_probe(struct platform_device *pdev)
 | |
|  
 | |
|  			private->ddp_comp[comp_id] = comp;
 | |
|  		}
 | |
| +
 | |
| +		if (comp_type != MTK_DSI && comp_type != MTK_DPI) {
 | |
| +			port = of_graph_get_port_by_id(node, 0);
 | |
| +			if (!port)
 | |
| +				continue;
 | |
| +			ep = of_get_child_by_name(port, "endpoint");
 | |
| +			of_node_put(port);
 | |
| +			if (!ep)
 | |
| +				continue;
 | |
| +			remote = of_graph_get_remote_port_parent(ep);
 | |
| +			of_node_put(ep);
 | |
| +			if (!remote)
 | |
| +				continue;
 | |
| +			of_id = of_match_node(mtk_ddp_comp_dt_ids, remote);
 | |
| +			if (!of_id)
 | |
| +				continue;
 | |
| +			comp_type = (enum mtk_ddp_comp_type)of_id->data;
 | |
| +			for (i = 0; i < private->data->main_len - 1; i++)
 | |
| +				if (private->data->main_path[i] == comp_id)
 | |
| +					private->data->main_path[i + 1] =
 | |
| +					mtk_ddp_comp_get_id(node, comp_type);
 | |
| +			for (i = 0; i < private->data->ext_len - 1; i++)
 | |
| +				if (private->data->ext_path[i] == comp_id)
 | |
| +					private->data->ext_path[i + 1] =
 | |
| +					mtk_ddp_comp_get_id(node, comp_type);
 | |
| +		}
 | |
|  	}
 | |
|  
 | |
|  	if (!private->mutex_node) {
 | |
| diff --git a/drivers/gpu/drm/mediatek/mtk_drm_drv.h b/drivers/gpu/drm/mediatek/mtk_drm_drv.h
 | |
| index e03fea12ff59..5fb723415ff6 100644
 | |
| --- a/drivers/gpu/drm/mediatek/mtk_drm_drv.h
 | |
| +++ b/drivers/gpu/drm/mediatek/mtk_drm_drv.h
 | |
| @@ -21,9 +21,9 @@ struct drm_property;
 | |
|  struct regmap;
 | |
|  
 | |
|  struct mtk_mmsys_driver_data {
 | |
| -	const enum mtk_ddp_comp_id *main_path;
 | |
| +	enum mtk_ddp_comp_id *main_path;
 | |
|  	unsigned int main_len;
 | |
| -	const enum mtk_ddp_comp_id *ext_path;
 | |
| +	enum mtk_ddp_comp_id *ext_path;
 | |
|  	unsigned int ext_len;
 | |
|  	const enum mtk_ddp_comp_id *third_path;
 | |
|  	unsigned int third_len;
 |