Commit e5353765 authored by Linus Walleij's avatar Linus Walleij Committed by Wolfram Sang

i2c/ARM: davinci: Deep refactoring of I2C recovery

Alter the DaVinci GPIO recovery fetch to use descriptors
all the way down into the board files.
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Acked-by: default avatarSekhar Nori <nsekhar@ti.com>
Tested-by: default avatarSekhar Nori <nsekhar@ti.com>
Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarWolfram Sang <wsa@the-dreams.de>
parent 7d42762d
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include <linux/mtd/rawnand.h> #include <linux/mtd/rawnand.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/gpio.h> #include <linux/gpio.h>
#include <linux/gpio/machine.h>
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/videodev2.h> #include <linux/videodev2.h>
#include <media/i2c/tvp514x.h> #include <media/i2c/tvp514x.h>
...@@ -108,11 +109,20 @@ static struct platform_device davinci_nand_device = { ...@@ -108,11 +109,20 @@ static struct platform_device davinci_nand_device = {
}, },
}; };
static struct gpiod_lookup_table i2c_recovery_gpiod_table = {
.dev_id = "i2c_davinci",
.table = {
GPIO_LOOKUP("davinci_gpio", 15, "sda",
GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
GPIO_LOOKUP("davinci_gpio", 14, "scl",
GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
},
};
static struct davinci_i2c_platform_data i2c_pdata = { static struct davinci_i2c_platform_data i2c_pdata = {
.bus_freq = 400 /* kHz */, .bus_freq = 400 /* kHz */,
.bus_delay = 0 /* usec */, .bus_delay = 0 /* usec */,
.sda_pin = 15, .gpio_recovery = true,
.scl_pin = 14,
}; };
static int dm355evm_mmc_gpios = -EINVAL; static int dm355evm_mmc_gpios = -EINVAL;
...@@ -141,6 +151,7 @@ static struct i2c_board_info dm355evm_i2c_info[] = { ...@@ -141,6 +151,7 @@ static struct i2c_board_info dm355evm_i2c_info[] = {
static void __init evm_init_i2c(void) static void __init evm_init_i2c(void)
{ {
gpiod_add_lookup_table(&i2c_recovery_gpiod_table);
davinci_init_i2c(&i2c_pdata); davinci_init_i2c(&i2c_pdata);
gpio_request(5, "dm355evm_msp"); gpio_request(5, "dm355evm_msp");
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#include <linux/dma-mapping.h> #include <linux/dma-mapping.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/gpio.h> #include <linux/gpio.h>
#include <linux/gpio/machine.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/platform_data/pcf857x.h> #include <linux/platform_data/pcf857x.h>
#include <linux/platform_data/at24.h> #include <linux/platform_data/at24.h>
...@@ -595,18 +596,28 @@ static struct i2c_board_info __initdata i2c_info[] = { ...@@ -595,18 +596,28 @@ static struct i2c_board_info __initdata i2c_info[] = {
}, },
}; };
static struct gpiod_lookup_table i2c_recovery_gpiod_table = {
.dev_id = "i2c_davinci",
.table = {
GPIO_LOOKUP("davinci_gpio", 44, "sda",
GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
GPIO_LOOKUP("davinci_gpio", 43, "scl",
GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
},
};
/* The msp430 uses a slow bitbanged I2C implementation (ergo 20 KHz), /* The msp430 uses a slow bitbanged I2C implementation (ergo 20 KHz),
* which requires 100 usec of idle bus after i2c writes sent to it. * which requires 100 usec of idle bus after i2c writes sent to it.
*/ */
static struct davinci_i2c_platform_data i2c_pdata = { static struct davinci_i2c_platform_data i2c_pdata = {
.bus_freq = 20 /* kHz */, .bus_freq = 20 /* kHz */,
.bus_delay = 100 /* usec */, .bus_delay = 100 /* usec */,
.sda_pin = 44, .gpio_recovery = true,
.scl_pin = 43,
}; };
static void __init evm_init_i2c(void) static void __init evm_init_i2c(void)
{ {
gpiod_add_lookup_table(&i2c_recovery_gpiod_table);
davinci_init_i2c(&i2c_pdata); davinci_init_i2c(&i2c_pdata);
i2c_add_driver(&dm6446evm_msp_driver); i2c_add_driver(&dm6446evm_msp_driver);
i2c_register_board_info(1, i2c_info, ARRAY_SIZE(i2c_info)); i2c_register_board_info(1, i2c_info, ARRAY_SIZE(i2c_info));
......
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
#include <linux/io.h> #include <linux/io.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/cpufreq.h> #include <linux/cpufreq.h>
#include <linux/gpio.h> #include <linux/gpio/consumer.h>
#include <linux/of_device.h> #include <linux/of_device.h>
#include <linux/platform_data/i2c-davinci.h> #include <linux/platform_data/i2c-davinci.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
...@@ -869,19 +869,20 @@ static int davinci_i2c_probe(struct platform_device *pdev) ...@@ -869,19 +869,20 @@ static int davinci_i2c_probe(struct platform_device *pdev)
if (dev->pdata->has_pfunc) if (dev->pdata->has_pfunc)
adap->bus_recovery_info = &davinci_i2c_scl_recovery_info; adap->bus_recovery_info = &davinci_i2c_scl_recovery_info;
else if (dev->pdata->scl_pin) { else if (dev->pdata->gpio_recovery) {
rinfo = &davinci_i2c_gpio_recovery_info; rinfo = &davinci_i2c_gpio_recovery_info;
adap->bus_recovery_info = rinfo; adap->bus_recovery_info = rinfo;
r = gpio_request_one(dev->pdata->scl_pin, GPIOF_OPEN_DRAIN | rinfo->scl_gpiod = devm_gpiod_get(&pdev->dev, "scl",
GPIOF_OUT_INIT_HIGH, "i2c-scl"); GPIOD_OUT_HIGH_OPEN_DRAIN);
if (r) if (IS_ERR(rinfo->scl_gpiod)) {
r = PTR_ERR(rinfo->scl_gpiod);
goto err_unuse_clocks; goto err_unuse_clocks;
rinfo->scl_gpiod = gpio_to_desc(dev->pdata->scl_pin); }
rinfo->sda_gpiod = devm_gpiod_get(&pdev->dev, "sda", GPIOD_IN);
r = gpio_request_one(dev->pdata->sda_pin, GPIOF_IN, "i2c-sda"); if (IS_ERR(rinfo->sda_gpiod)) {
if (r) r = PTR_ERR(rinfo->sda_gpiod);
goto err_unuse_clocks; goto err_unuse_clocks;
rinfo->sda_gpiod = gpio_to_desc(dev->pdata->scl_pin); }
} }
adap->nr = pdev->id; adap->nr = pdev->id;
......
...@@ -16,9 +16,8 @@ ...@@ -16,9 +16,8 @@
struct davinci_i2c_platform_data { struct davinci_i2c_platform_data {
unsigned int bus_freq; /* standard bus frequency (kHz) */ unsigned int bus_freq; /* standard bus frequency (kHz) */
unsigned int bus_delay; /* post-transaction delay (usec) */ unsigned int bus_delay; /* post-transaction delay (usec) */
unsigned int sda_pin; /* GPIO pin ID to use for SDA */ bool gpio_recovery; /* Use GPIO recovery method */
unsigned int scl_pin; /* GPIO pin ID to use for SCL */ bool has_pfunc; /* Chip has a ICPFUNC register */
bool has_pfunc; /*chip has a ICPFUNC register */
}; };
/* for board setup code */ /* for board setup code */
......
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