[U-Boot] [PATCH 7/8 V2] I2C: Add support for Multi channel

Joonyoung Shim dofmind at gmail.com
Fri Jun 15 09:15:11 CEST 2012


Hi,

2012/6/7 Rajeshwari Shinde <rajeshwari.s at samsung.com>:
> This adds multiple i2c channel support for I2C.
>
> Signed-off-by: Alim Akhtar <alim.akhtar at samsung.com>
> Signed-off-by: Rajeshwari Shinde <rajeshwari.s at samsung.com>
> Acked-by: Simon Glass <sjg at chromium.org>
> ---
>  drivers/i2c/s3c24x0_i2c.c |   27 +++++++++++++++++++++++++++
>  1 files changed, 27 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/i2c/s3c24x0_i2c.c b/drivers/i2c/s3c24x0_i2c.c
> index a71f147..7521cb8 100644
> --- a/drivers/i2c/s3c24x0_i2c.c
> +++ b/drivers/i2c/s3c24x0_i2c.c
> @@ -191,6 +191,33 @@ static void i2c_bus_init(struct s3c24x0_i2c *i2c, unsigned int bus)
>        i2c_ch_init(i2c, CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);
>  }
>
> +/*
> + * MULTI BUS I2C support
> + */
> +
> +#ifdef CONFIG_I2C_MULTI_BUS
> +int i2c_set_bus_num(unsigned int bus)
> +{
> +       struct s3c24x0_i2c *i2c;
> +
> +       if ((bus < 0) || (bus >= CONFIG_MAX_I2C_NUM)) {
> +               debug("Bad bus: %d\n", bus);
> +               return -1;
> +       }
> +
> +       g_current_bus = bus;
> +       i2c = get_base_i2c(g_current_bus);
> +       i2c_bus_init(i2c, g_current_bus);

This causes duplicated pin configuration whenever calls i2c_set_bus_num().

> +
> +       return 0;
> +}
> +
> +unsigned int i2c_get_bus_num(void)
> +{
> +       return g_current_bus;
> +}
> +#endif

Does only EXYNOS5 support CONFIG_I2C_MULTI_BUS?

> +
>  #ifdef CONFIG_EXYNOS5
>  void i2c_init(int speed, int slaveadd)
>  {
> --
> 1.7.4.4
>
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot

Thanks.

-- 
- Joonyoung Shim


More information about the U-Boot mailing list