Commit 5c470f39 authored by John Bonesio's avatar John Bonesio Committed by Ben Dooks

i2c: Tegra: Add DeviceTree support

This patch modifies the tegra i2c driver so that it can be initiailized
using the device tree along with the devices connected to the i2c bus.
Signed-off-by: default avatarJohn Bonesio <bones@secretlab.ca>
Acked-by: default avatarGrant Likely <grant.likely@secretlab.ca>
Acked-by: default avatarOIof Johansson <olof@lixom.net>
Signed-off-by: default avatarBen Dooks <ben-linux@fluff.org>
parent ba5b56cb
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/i2c-tegra.h> #include <linux/i2c-tegra.h>
#include <linux/of_i2c.h>
#include <asm/unaligned.h> #include <asm/unaligned.h>
...@@ -546,6 +547,7 @@ static int tegra_i2c_probe(struct platform_device *pdev) ...@@ -546,6 +547,7 @@ static int tegra_i2c_probe(struct platform_device *pdev)
struct resource *iomem; struct resource *iomem;
struct clk *clk; struct clk *clk;
struct clk *i2c_clk; struct clk *i2c_clk;
const unsigned int *prop;
void *base; void *base;
int irq; int irq;
int ret = 0; int ret = 0;
...@@ -603,7 +605,17 @@ static int tegra_i2c_probe(struct platform_device *pdev) ...@@ -603,7 +605,17 @@ static int tegra_i2c_probe(struct platform_device *pdev)
i2c_dev->irq = irq; i2c_dev->irq = irq;
i2c_dev->cont_id = pdev->id; i2c_dev->cont_id = pdev->id;
i2c_dev->dev = &pdev->dev; i2c_dev->dev = &pdev->dev;
i2c_dev->bus_clk_rate = pdata ? pdata->bus_clk_rate : 100000;
i2c_dev->bus_clk_rate = 100000; /* default clock rate */
if (pdata) {
i2c_dev->bus_clk_rate = pdata->bus_clk_rate;
} else if (i2c_dev->dev->of_node) { /* if there is a device tree node ... */
prop = of_get_property(i2c_dev->dev->of_node,
"clock-frequency", NULL);
if (prop)
i2c_dev->bus_clk_rate = be32_to_cpup(prop);
}
if (pdev->id == 3) if (pdev->id == 3)
i2c_dev->is_dvc = 1; i2c_dev->is_dvc = 1;
...@@ -633,6 +645,7 @@ static int tegra_i2c_probe(struct platform_device *pdev) ...@@ -633,6 +645,7 @@ static int tegra_i2c_probe(struct platform_device *pdev)
i2c_dev->adapter.algo = &tegra_i2c_algo; i2c_dev->adapter.algo = &tegra_i2c_algo;
i2c_dev->adapter.dev.parent = &pdev->dev; i2c_dev->adapter.dev.parent = &pdev->dev;
i2c_dev->adapter.nr = pdev->id; i2c_dev->adapter.nr = pdev->id;
i2c_dev->adapter.dev.of_node = pdev->dev.of_node;
ret = i2c_add_numbered_adapter(&i2c_dev->adapter); ret = i2c_add_numbered_adapter(&i2c_dev->adapter);
if (ret) { if (ret) {
...@@ -640,6 +653,8 @@ static int tegra_i2c_probe(struct platform_device *pdev) ...@@ -640,6 +653,8 @@ static int tegra_i2c_probe(struct platform_device *pdev)
goto err_free_irq; goto err_free_irq;
} }
of_i2c_register_devices(&i2c_dev->adapter);
return 0; return 0;
err_free_irq: err_free_irq:
free_irq(i2c_dev->irq, i2c_dev); free_irq(i2c_dev->irq, i2c_dev);
......
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