[U-Boot] [PATCH 7/8] I2C: Add support for Multi channel
Simon Glass
sjg at chromium.org
Fri Jun 1 03:18:09 CEST 2012
On Fri, May 18, 2012 at 5:12 AM, Rajeshwari Shinde <rajeshwari.s at samsung.com
> wrote:
> 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 61b54a9..39875cd 100644
> --- a/drivers/i2c/s3c24x0_i2c.c
> +++ b/drivers/i2c/s3c24x0_i2c.c
> @@ -189,6 +189,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);
> +
> + return 0;
> +}
> +
> +unsigned int i2c_get_bus_num(void)
> +{
> + return g_current_bus;
> +}
> +#endif
> +
> #ifdef CONFIG_EXYNOS5
> void i2c_init(int speed, int slaveadd)
> {
> --
> 1.7.4.4
>
>
More information about the U-Boot
mailing list