Commit e1704914 authored by Rob Herring's avatar Rob Herring

drm: Use device_get_match_data()

Use preferred device_get_match_data() instead of of_match_device() to
get the driver match data in a single step. With this, adjust the
includes to explicitly include the correct headers. That also serves as
preparation to remove implicit includes within the DT headers
(of_device.h in particular).
Reviewed-by: default avatarTomi Valkeinen <tomi.valkeinen@ideasonboard.com>
Reviewed-by: default avatarAndrew Jeffery <andrew@codeconstruct.com.au>
Link: https://lore.kernel.org/r/20231020125214.2930329-1-robh@kernel.orgSigned-off-by: default avatarRob Herring <robh@kernel.org>
parent 19b4c60c
...@@ -7,8 +7,9 @@ ...@@ -7,8 +7,9 @@
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/component.h> #include <linux/component.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_device.h> #include <linux/of.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/property.h>
#include <drm/drm_atomic.h> #include <drm/drm_atomic.h>
#include <drm/drm_atomic_helper.h> #include <drm/drm_atomic_helper.h>
...@@ -1012,26 +1013,17 @@ armada_lcd_bind(struct device *dev, struct device *master, void *data) ...@@ -1012,26 +1013,17 @@ armada_lcd_bind(struct device *dev, struct device *master, void *data)
int irq = platform_get_irq(pdev, 0); int irq = platform_get_irq(pdev, 0);
const struct armada_variant *variant; const struct armada_variant *variant;
struct device_node *port = NULL; struct device_node *port = NULL;
struct device_node *np, *parent = dev->of_node;
if (irq < 0) if (irq < 0)
return irq; return irq;
if (!dev->of_node) {
const struct platform_device_id *id;
id = platform_get_device_id(pdev); variant = device_get_match_data(dev);
if (!id) if (!variant)
return -ENXIO;
variant = (const struct armada_variant *)id->driver_data;
} else {
const struct of_device_id *match;
struct device_node *np, *parent = dev->of_node;
match = of_match_device(dev->driver->of_match_table, dev);
if (!match)
return -ENXIO; return -ENXIO;
if (parent) {
np = of_get_child_by_name(parent, "ports"); np = of_get_child_by_name(parent, "ports");
if (np) if (np)
parent = np; parent = np;
...@@ -1041,8 +1033,6 @@ armada_lcd_bind(struct device *dev, struct device *master, void *data) ...@@ -1041,8 +1033,6 @@ armada_lcd_bind(struct device *dev, struct device *master, void *data)
dev_err(dev, "no port node found in %pOF\n", parent); dev_err(dev, "no port node found in %pOF\n", parent);
return -ENXIO; return -ENXIO;
} }
variant = match->data;
} }
return armada_drm_crtc_create(drm, dev, res, irq, variant, port); return armada_drm_crtc_create(drm, dev, res, irq, variant, port);
......
...@@ -6,10 +6,10 @@ ...@@ -6,10 +6,10 @@
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/mfd/syscon.h> #include <linux/mfd/syscon.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of.h> #include <linux/mod_devicetable.h>
#include <linux/of_device.h>
#include <linux/of_reserved_mem.h> #include <linux/of_reserved_mem.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/property.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/reset.h> #include <linux/reset.h>
...@@ -143,7 +143,6 @@ static int aspeed_gfx_load(struct drm_device *drm) ...@@ -143,7 +143,6 @@ static int aspeed_gfx_load(struct drm_device *drm)
struct aspeed_gfx *priv = to_aspeed_gfx(drm); struct aspeed_gfx *priv = to_aspeed_gfx(drm);
struct device_node *np = pdev->dev.of_node; struct device_node *np = pdev->dev.of_node;
const struct aspeed_gfx_config *config; const struct aspeed_gfx_config *config;
const struct of_device_id *match;
struct resource *res; struct resource *res;
int ret; int ret;
...@@ -152,10 +151,9 @@ static int aspeed_gfx_load(struct drm_device *drm) ...@@ -152,10 +151,9 @@ static int aspeed_gfx_load(struct drm_device *drm)
if (IS_ERR(priv->base)) if (IS_ERR(priv->base))
return PTR_ERR(priv->base); return PTR_ERR(priv->base);
match = of_match_device(aspeed_gfx_match, &pdev->dev); config = device_get_match_data(&pdev->dev);
if (!match) if (!config)
return -EINVAL; return -EINVAL;
config = match->data;
priv->dac_reg = config->dac_reg; priv->dac_reg = config->dac_reg;
priv->int_clr_reg = config->int_clear_reg; priv->int_clr_reg = config->int_clear_reg;
......
...@@ -11,9 +11,10 @@ ...@@ -11,9 +11,10 @@
#include <linux/component.h> #include <linux/component.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/mfd/syscon.h> #include <linux/mfd/syscon.h>
#include <linux/of_device.h> #include <linux/mod_devicetable.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/property.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <drm/drm_fourcc.h> #include <drm/drm_fourcc.h>
...@@ -103,7 +104,7 @@ struct gsc_context { ...@@ -103,7 +104,7 @@ struct gsc_context {
unsigned int num_formats; unsigned int num_formats;
void __iomem *regs; void __iomem *regs;
const char **clk_names; const char *const *clk_names;
struct clk *clocks[GSC_MAX_CLOCKS]; struct clk *clocks[GSC_MAX_CLOCKS];
int num_clocks; int num_clocks;
struct gsc_scaler sc; struct gsc_scaler sc;
...@@ -1217,7 +1218,7 @@ static const unsigned int gsc_tiled_formats[] = { ...@@ -1217,7 +1218,7 @@ static const unsigned int gsc_tiled_formats[] = {
static int gsc_probe(struct platform_device *pdev) static int gsc_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct gsc_driverdata *driver_data; const struct gsc_driverdata *driver_data;
struct exynos_drm_ipp_formats *formats; struct exynos_drm_ipp_formats *formats;
struct gsc_context *ctx; struct gsc_context *ctx;
int num_formats, ret, i, j; int num_formats, ret, i, j;
...@@ -1226,7 +1227,7 @@ static int gsc_probe(struct platform_device *pdev) ...@@ -1226,7 +1227,7 @@ static int gsc_probe(struct platform_device *pdev)
if (!ctx) if (!ctx)
return -ENOMEM; return -ENOMEM;
driver_data = (struct gsc_driverdata *)of_device_get_match_data(dev); driver_data = device_get_match_data(dev);
ctx->dev = dev; ctx->dev = dev;
ctx->num_clocks = driver_data->num_clocks; ctx->num_clocks = driver_data->num_clocks;
ctx->clk_names = driver_data->clk_names; ctx->clk_names = driver_data->clk_names;
......
...@@ -12,8 +12,10 @@ ...@@ -12,8 +12,10 @@
#include <linux/mfd/syscon.h> #include <linux/mfd/syscon.h>
#include <linux/mfd/syscon/imx6q-iomuxc-gpr.h> #include <linux/mfd/syscon/imx6q-iomuxc-gpr.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_device.h> #include <linux/of.h>
#include <linux/of_graph.h> #include <linux/of_graph.h>
#include <linux/platform_device.h>
#include <linux/property.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/videodev2.h> #include <linux/videodev2.h>
...@@ -617,7 +619,6 @@ static int imx_ldb_probe(struct platform_device *pdev) ...@@ -617,7 +619,6 @@ static int imx_ldb_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct device_node *np = dev->of_node; struct device_node *np = dev->of_node;
const struct of_device_id *of_id = of_match_device(imx_ldb_dt_ids, dev);
struct device_node *child; struct device_node *child;
struct imx_ldb *imx_ldb; struct imx_ldb *imx_ldb;
int dual; int dual;
...@@ -638,9 +639,7 @@ static int imx_ldb_probe(struct platform_device *pdev) ...@@ -638,9 +639,7 @@ static int imx_ldb_probe(struct platform_device *pdev)
regmap_write(imx_ldb->regmap, IOMUXC_GPR2, 0); regmap_write(imx_ldb->regmap, IOMUXC_GPR2, 0);
imx_ldb->dev = dev; imx_ldb->dev = dev;
imx_ldb->lvds_mux = device_get_match_data(dev);
if (of_id)
imx_ldb->lvds_mux = of_id->data;
dual = of_property_read_bool(np, "fsl,dual-channel"); dual = of_property_read_bool(np, "fsl,dual-channel");
if (dual) if (dual)
......
...@@ -11,9 +11,10 @@ ...@@ -11,9 +11,10 @@
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/dma-mapping.h> #include <linux/dma-mapping.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/mod_devicetable.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_device.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/property.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <drm/drm_atomic_helper.h> #include <drm/drm_atomic_helper.h>
...@@ -346,18 +347,13 @@ MODULE_DEVICE_TABLE(of, mxsfb_dt_ids); ...@@ -346,18 +347,13 @@ MODULE_DEVICE_TABLE(of, mxsfb_dt_ids);
static int mxsfb_probe(struct platform_device *pdev) static int mxsfb_probe(struct platform_device *pdev)
{ {
struct drm_device *drm; struct drm_device *drm;
const struct of_device_id *of_id =
of_match_device(mxsfb_dt_ids, &pdev->dev);
int ret; int ret;
if (!pdev->dev.of_node)
return -ENODEV;
drm = drm_dev_alloc(&mxsfb_driver, &pdev->dev); drm = drm_dev_alloc(&mxsfb_driver, &pdev->dev);
if (IS_ERR(drm)) if (IS_ERR(drm))
return PTR_ERR(drm); return PTR_ERR(drm);
ret = mxsfb_load(drm, of_id->data); ret = mxsfb_load(drm, device_get_match_data(&pdev->dev));
if (ret) if (ret)
goto err_free; goto err_free;
......
...@@ -22,11 +22,11 @@ ...@@ -22,11 +22,11 @@
#include <linux/hardirq.h> #include <linux/hardirq.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/property.h>
#include <linux/sizes.h> #include <linux/sizes.h>
#include <linux/mfd/syscon.h> #include <linux/mfd/syscon.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h>
#include <linux/component.h> #include <linux/component.h>
#include <linux/sys_soc.h> #include <linux/sys_soc.h>
#include <drm/drm_fourcc.h> #include <drm/drm_fourcc.h>
...@@ -4765,7 +4765,7 @@ static int dispc_bind(struct device *dev, struct device *master, void *data) ...@@ -4765,7 +4765,7 @@ static int dispc_bind(struct device *dev, struct device *master, void *data)
if (soc) if (soc)
dispc->feat = soc->data; dispc->feat = soc->data;
else else
dispc->feat = of_match_device(dispc_of_match, &pdev->dev)->data; dispc->feat = device_get_match_data(&pdev->dev);
r = dispc_errata_i734_wa_init(dispc); r = dispc_errata_i734_wa_init(dispc);
if (r) if (r)
......
...@@ -22,12 +22,13 @@ ...@@ -22,12 +22,13 @@
#include <linux/pinctrl/consumer.h> #include <linux/pinctrl/consumer.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/property.h>
#include <linux/gfp.h> #include <linux/gfp.h>
#include <linux/sizes.h> #include <linux/sizes.h>
#include <linux/mfd/syscon.h> #include <linux/mfd/syscon.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h> #include <linux/of_platform.h>
#include <linux/of_graph.h> #include <linux/of_graph.h>
#include <linux/regulator/consumer.h> #include <linux/regulator/consumer.h>
#include <linux/suspend.h> #include <linux/suspend.h>
...@@ -1445,7 +1446,7 @@ static int dss_probe(struct platform_device *pdev) ...@@ -1445,7 +1446,7 @@ static int dss_probe(struct platform_device *pdev)
if (soc) if (soc)
dss->feat = soc->data; dss->feat = soc->data;
else else
dss->feat = of_match_device(dss_of_match, &pdev->dev)->data; dss->feat = device_get_match_data(&pdev->dev);
/* Map I/O registers, get and setup clocks. */ /* Map I/O registers, get and setup clocks. */
dss->base = devm_platform_ioremap_resource(pdev, 0); dss->base = devm_platform_ioremap_resource(pdev, 0);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment