[PATCH v2] ARM: davinci: fix GPIO lookup for I2C

David Lechner david at lechnology.com
Tue May 1 19:02:00 PDT 2018


On 05/01/2018 10:31 AM, Sekhar Nori wrote:
> The GPIO chip is called davinci_gpio.0 in legacy mode. Fix it, so that
> I2C can correctly lookup the recovery gpios.
> 
> Note that it is the gpio-davinci driver that sets the gpiochip label to
> davinci_gpio.0.
> 
> Also, the I2C device uses an id of 1 on DM644x and DM355.
> 
> While at it, convert to using GPIO_TO_PIN() for referring to GPIO pin
> numbers, like it is done in rest of the board support files.
> 
> Fixes: e53537653791 ("i2c/ARM: davinci: Deep refactoring of I2C recovery")
> Signed-off-by: Sekhar Nori <nsekhar at ti.com>
> ---
> v2: use GPIO_TO_PIN() to fix comment by David Lechner.
> 
>   arch/arm/mach-davinci/board-dm355-evm.c  |  9 ++++++---
>   arch/arm/mach-davinci/board-dm644x-evm.c | 10 +++++++---
>   2 files changed, 13 insertions(+), 6 deletions(-)
> 
> diff --git a/arch/arm/mach-davinci/board-dm355-evm.c b/arch/arm/mach-davinci/board-dm355-evm.c
> index 762d29683a3a..23ab9e8bc04c 100644
> --- a/arch/arm/mach-davinci/board-dm355-evm.c
> +++ b/arch/arm/mach-davinci/board-dm355-evm.c
> @@ -110,12 +110,15 @@ static struct platform_device davinci_nand_device = {
>   	},
>   };
>   
> +#define DM355_I2C_SDA_PIN	GPIO_TO_PIN(0, 15)
> +#define DM355_I2C_SCL_PIN	GPIO_TO_PIN(0, 14)
> +
>   static struct gpiod_lookup_table i2c_recovery_gpiod_table = {
> -	.dev_id = "i2c_davinci",
> +	.dev_id = "i2c_davinci.1",
>   	.table = {
> -		GPIO_LOOKUP("davinci_gpio", 15, "sda",
> +		GPIO_LOOKUP("davinci_gpio.0", DM355_I2C_SDA_PIN, "sda",
>   			    GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
> -		GPIO_LOOKUP("davinci_gpio", 14, "scl",
> +		GPIO_LOOKUP("davinci_gpio.0", DM355_I2C_SCL_PIN, "scl",
>   			    GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
>   	},
>   };
> diff --git a/arch/arm/mach-davinci/board-dm644x-evm.c b/arch/arm/mach-davinci/board-dm644x-evm.c
> index 95b55aae1366..509e64ab1994 100644
> --- a/arch/arm/mach-davinci/board-dm644x-evm.c
> +++ b/arch/arm/mach-davinci/board-dm644x-evm.c
> @@ -17,6 +17,7 @@
>   #include <linux/i2c.h>
>   #include <linux/platform_data/pcf857x.h>
>   #include <linux/platform_data/at24.h>
> +#include <linux/platform_data/gpio-davinci.h>
>   #include <linux/mtd/mtd.h>
>   #include <linux/mtd/rawnand.h>
>   #include <linux/mtd/partitions.h>
> @@ -596,12 +597,15 @@ static struct i2c_board_info __initdata i2c_info[] =  {
>   	},
>   };
>   
> +#define DM644X_I2C_SDA_PIN	GPIO_TO_PIN(2, 12)
> +#define DM644X_I2C_SCL_PIN	GPIO_TO_PIN(2, 11)
> +
>   static struct gpiod_lookup_table i2c_recovery_gpiod_table = {
> -	.dev_id = "i2c_davinci",
> +	.dev_id = "i2c_davinci.1",
>   	.table = {
> -		GPIO_LOOKUP("davinci_gpio", 44, "sda",
> +		GPIO_LOOKUP("davinci_gpio.0", DM644X_I2C_SDA_PIN, "sda",
>   			    GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
> -		GPIO_LOOKUP("davinci_gpio", 43, "scl",
> +		GPIO_LOOKUP("davinci_gpio.0", DM644X_I2C_SCL_PIN, "scl",
>   			    GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN),
>   	},
>   };
> 

Reviewed-by: David Lechner <david at lechnology.com>




More information about the linux-arm-kernel mailing list