Commit 8cafbf26 authored by Rob Herring's avatar Rob Herring Committed by Wolfram Sang

i2c: Use device_get_match_data()

Use preferred device_get_match_data() instead of of_match_device() to
get the driver match data. With this, adjust the includes to explicitly
include the correct headers.
Signed-off-by: default avatarRob Herring <robh@kernel.org>
Reviewed-by: default avatarAndi Shyti <andi.shyti@kernel.org>
Signed-off-by: default avatarWolfram Sang <wsa@kernel.org>
parent 0f75d486
...@@ -19,11 +19,10 @@ ...@@ -19,11 +19,10 @@
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/pinctrl/consumer.h> #include <linux/pinctrl/consumer.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/property.h>
#include <linux/reset.h> #include <linux/reset.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h>
#include <linux/of_irq.h>
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/delay.h> #include <linux/delay.h>
...@@ -859,7 +858,7 @@ static int ...@@ -859,7 +858,7 @@ static int
mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data, mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data,
struct device *dev) struct device *dev)
{ {
const struct of_device_id *device; const struct mv64xxx_i2c_regs *data;
struct device_node *np = dev->of_node; struct device_node *np = dev->of_node;
u32 bus_freq, tclk; u32 bus_freq, tclk;
int rc = 0; int rc = 0;
...@@ -897,11 +896,11 @@ mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data, ...@@ -897,11 +896,11 @@ mv64xxx_of_config(struct mv64xxx_i2c_data *drv_data,
*/ */
drv_data->adapter.timeout = HZ; drv_data->adapter.timeout = HZ;
device = of_match_device(mv64xxx_i2c_of_match_table, dev); data = device_get_match_data(dev);
if (!device) if (!data)
return -ENODEV; return -ENODEV;
memcpy(&drv_data->reg_offsets, device->data, sizeof(drv_data->reg_offsets)); memcpy(&drv_data->reg_offsets, data, sizeof(drv_data->reg_offsets));
/* /*
* For controllers embedded in new SoCs activate the * For controllers embedded in new SoCs activate the
......
...@@ -25,11 +25,11 @@ ...@@ -25,11 +25,11 @@
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/platform_data/i2c-omap.h> #include <linux/platform_data/i2c-omap.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/pinctrl/consumer.h> #include <linux/pinctrl/consumer.h>
#include <linux/property.h>
/* I2C controller revisions */ /* I2C controller revisions */
#define OMAP_I2C_OMAP1_REV_2 0x20 #define OMAP_I2C_OMAP1_REV_2 0x20
...@@ -1358,7 +1358,6 @@ omap_i2c_probe(struct platform_device *pdev) ...@@ -1358,7 +1358,6 @@ omap_i2c_probe(struct platform_device *pdev)
const struct omap_i2c_bus_platform_data *pdata = const struct omap_i2c_bus_platform_data *pdata =
dev_get_platdata(&pdev->dev); dev_get_platdata(&pdev->dev);
struct device_node *node = pdev->dev.of_node; struct device_node *node = pdev->dev.of_node;
const struct of_device_id *match;
int irq; int irq;
int r; int r;
u32 rev; u32 rev;
...@@ -1376,11 +1375,10 @@ omap_i2c_probe(struct platform_device *pdev) ...@@ -1376,11 +1375,10 @@ omap_i2c_probe(struct platform_device *pdev)
if (IS_ERR(omap->base)) if (IS_ERR(omap->base))
return PTR_ERR(omap->base); return PTR_ERR(omap->base);
match = of_match_device(of_match_ptr(omap_i2c_of_match), &pdev->dev); if (pdev->dev.of_node) {
if (match) {
u32 freq = I2C_MAX_STANDARD_MODE_FREQ; u32 freq = I2C_MAX_STANDARD_MODE_FREQ;
pdata = match->data; pdata = device_get_match_data(&pdev->dev);
omap->flags = pdata->flags; omap->flags = pdata->flags;
of_property_read_u32(node, "clock-frequency", &freq); of_property_read_u32(node, "clock-frequency", &freq);
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
#include <linux/pinctrl/consumer.h> #include <linux/pinctrl/consumer.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/platform_data/i2c-pxa.h> #include <linux/platform_data/i2c-pxa.h>
#include <linux/property.h>
#include <linux/slab.h> #include <linux/slab.h>
/* I2C register field definitions */ /* I2C register field definitions */
...@@ -1252,10 +1253,8 @@ static int i2c_pxa_probe_dt(struct platform_device *pdev, struct pxa_i2c *i2c, ...@@ -1252,10 +1253,8 @@ static int i2c_pxa_probe_dt(struct platform_device *pdev, struct pxa_i2c *i2c,
enum pxa_i2c_types *i2c_types) enum pxa_i2c_types *i2c_types)
{ {
struct device_node *np = pdev->dev.of_node; struct device_node *np = pdev->dev.of_node;
const struct of_device_id *of_id =
of_match_device(i2c_pxa_dt_ids, &pdev->dev);
if (!of_id) if (!pdev->dev.of_node)
return 1; return 1;
/* For device tree we always use the dynamic or alias-assigned ID */ /* For device tree we always use the dynamic or alias-assigned ID */
...@@ -1264,7 +1263,7 @@ static int i2c_pxa_probe_dt(struct platform_device *pdev, struct pxa_i2c *i2c, ...@@ -1264,7 +1263,7 @@ static int i2c_pxa_probe_dt(struct platform_device *pdev, struct pxa_i2c *i2c,
i2c->use_pio = of_property_read_bool(np, "mrvl,i2c-polling"); i2c->use_pio = of_property_read_bool(np, "mrvl,i2c-polling");
i2c->fast_mode = of_property_read_bool(np, "mrvl,i2c-fast-mode"); i2c->fast_mode = of_property_read_bool(np, "mrvl,i2c-fast-mode");
*i2c_types = (enum pxa_i2c_types)(of_id->data); *i2c_types = (enum pxa_i2c_types)device_get_match_data(&pdev->dev);
return 0; return 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