diff options
| author | Tony Lindgren <tony@atomide.com> | 2020-02-26 10:02:19 -0800 | 
|---|---|---|
| committer | Tony Lindgren <tony@atomide.com> | 2020-02-26 10:02:19 -0800 | 
| commit | cef766300353613aa273791f70b3125d1f0420ae (patch) | |
| tree | 6a88132b37c1ef2511f49ee8b7b93f2d45867fca /drivers/gpu/drm/omapdrm/dss/dss.c | |
| parent | bb6d3fb354c5ee8d6bde2d576eb7220ea09862b9 (diff) | |
drm/omap: Prepare DSS for probing without legacy platform data
In order to probe display subsystem (DSS) components with ti-sysc
interconnect target module without legacy platform data and using
devicetree, we need to update dss probing a bit.
In the device tree, we will be defining the data also for the interconnect
target modules as DSS really is a private interconnect. There is some
information about that in 4460 TRM in "Figure 10-3. DSS Integration" for
example where it mentions "32-bit interconnect (SLX)".
The changes we need to make are:
1. Parse also device tree subnodes for the compatible property fixup
2. Update the component code to consider device tree subnodes
Cc: dri-devel@lists.freedesktop.org
Cc: Jyri Sarha <jsarha@ti.com>
Cc: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: Tomi Valkeinen <tomi.valkeinen@ti.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Sebastian Reichel <sebastian.reichel@collabora.com>
Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'drivers/gpu/drm/omapdrm/dss/dss.c')
| -rw-r--r-- | drivers/gpu/drm/omapdrm/dss/dss.c | 25 | 
1 files changed, 22 insertions, 3 deletions
| diff --git a/drivers/gpu/drm/omapdrm/dss/dss.c b/drivers/gpu/drm/omapdrm/dss/dss.c index 225ec808b01a..44e8faecedc7 100644 --- a/drivers/gpu/drm/omapdrm/dss/dss.c +++ b/drivers/gpu/drm/omapdrm/dss/dss.c @@ -1339,9 +1339,15 @@ static int dss_component_compare(struct device *dev, void *data)  	return dev == child;  } +struct dss_component_match_data { +	struct device *dev; +	struct component_match **match; +}; +  static int dss_add_child_component(struct device *dev, void *data)  { -	struct component_match **match = data; +	struct dss_component_match_data *cmatch = data; +	struct component_match **match = cmatch->match;  	/*  	 * HACK @@ -1352,7 +1358,17 @@ static int dss_add_child_component(struct device *dev, void *data)  	if (strstr(dev_name(dev), "rfbi"))  		return 0; -	component_match_add(dev->parent, match, dss_component_compare, dev); +	/* +	 * Handle possible interconnect target modules defined within the DSS. +	 * The DSS components can be children of an interconnect target module +	 * after the device tree has been updated for the module data. +	 * See also omapdss_boot_init() for compatible fixup. +	 */ +	if (strstr(dev_name(dev), "target-module")) +		return device_for_each_child(dev, cmatch, +					     dss_add_child_component); + +	component_match_add(cmatch->dev, match, dss_component_compare, dev);  	return 0;  } @@ -1395,6 +1411,7 @@ static int dss_probe_hardware(struct dss_device *dss)  static int dss_probe(struct platform_device *pdev)  {  	const struct soc_device_attribute *soc; +	struct dss_component_match_data cmatch;  	struct component_match *match = NULL;  	struct resource *dss_mem;  	struct dss_device *dss; @@ -1472,7 +1489,9 @@ static int dss_probe(struct platform_device *pdev)  	omapdss_gather_components(&pdev->dev); -	device_for_each_child(&pdev->dev, &match, dss_add_child_component); +	cmatch.dev = &pdev->dev; +	cmatch.match = &match; +	device_for_each_child(&pdev->dev, &cmatch, dss_add_child_component);  	r = component_master_add_with_match(&pdev->dev, &dss_component_ops, match);  	if (r) | 
