diff options
author | Ionut Nicu <ioan.nicu.ext@nsn.com> | 2013-10-11 14:17:10 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-12-04 10:55:50 -0800 |
commit | d9d317655d19d5cb583333e5643b0ada4ef5b48e (patch) | |
tree | 3ad88c836b8b8ecdc4a1ea304ec4d573d7e0dd37 /drivers/i2c | |
parent | 12ea4499abf3cabc3dcea7efed13d15b99930405 (diff) | |
download | linux-stable-d9d317655d19d5cb583333e5643b0ada4ef5b48e.tar.gz linux-stable-d9d317655d19d5cb583333e5643b0ada4ef5b48e.tar.bz2 linux-stable-d9d317655d19d5cb583333e5643b0ada4ef5b48e.zip |
i2c: mux: gpio: use gpio_set_value_cansleep()
commit 250ad590d6f12d93f4d85be305b0a598d609232e upstream.
Some gpio chips may have get/set operations that
can sleep. gpio_set_value() only works for chips
which do not sleep, for the others we will get a
kernel warning. Using gpio_set_value_cansleep()
will work for both chips that do sleep and those
who don't.
Signed-off-by: Ionut Nicu <ioan.nicu.ext@nsn.com>
Acked-by: Peter Korsgaard <peter.korsgaard@barco.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/i2c')
-rw-r--r-- | drivers/i2c/muxes/i2c-mux-gpio.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/i2c/muxes/i2c-mux-gpio.c b/drivers/i2c/muxes/i2c-mux-gpio.c index 4879796dddc5..bb4f69f75f3c 100644 --- a/drivers/i2c/muxes/i2c-mux-gpio.c +++ b/drivers/i2c/muxes/i2c-mux-gpio.c @@ -31,8 +31,8 @@ static void i2c_mux_gpio_set(const struct gpiomux *mux, unsigned val) int i; for (i = 0; i < mux->data.n_gpios; i++) - gpio_set_value(mux->gpio_base + mux->data.gpios[i], - val & (1 << i)); + gpio_set_value_cansleep(mux->gpio_base + mux->data.gpios[i], + val & (1 << i)); } static int i2c_mux_gpio_select(struct i2c_adapter *adap, void *data, u32 chan) |