]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
i2c: i2c-cros-ec-tunnel: Set retries to 3
authorDerek Basehore <dbasehore@chromium.org>
Thu, 18 Sep 2014 15:18:55 +0000 (17:18 +0200)
committerLee Jones <lee.jones@linaro.org>
Mon, 6 Oct 2014 20:30:04 +0000 (21:30 +0100)
Since the i2c bus can get wedged on the EC sometimes, set the number of retries
to 3. Since we un-wedge the bus immediately after the wedge happens, this is the
correct fix since only one transfer will fail.

Signed-off-by: Derek Basehore <dbasehore@chromium.org>
Reviewed-by: Doug Anderson <dianders@chromium.org>
Acked-by: Wolfram Sang <wsa@the-dreams.de>
Signed-off-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
drivers/i2c/busses/i2c-cros-ec-tunnel.c

index 43be23dfb1150447bdd067969cc716cd1c1700fc..8ca5cbbcec915072cfa8a8de4d9d8df7c708dd82 100644 (file)
@@ -16,6 +16,8 @@
 #include <linux/platform_device.h>
 #include <linux/slab.h>
 
+#define I2C_MAX_RETRIES 3
+
 /**
  * struct ec_i2c_device - Driver data for I2C tunnel
  *
@@ -290,6 +292,7 @@ static int ec_i2c_probe(struct platform_device *pdev)
        bus->adap.algo_data = bus;
        bus->adap.dev.parent = &pdev->dev;
        bus->adap.dev.of_node = np;
+       bus->adap.retries = I2C_MAX_RETRIES;
 
        err = i2c_add_adapter(&bus->adap);
        if (err) {