mxc_i2c: call i2c_imx_stop on error in i2c_read/i2c_write
authorTroy Kisky <troy.kisky@boundarydevices.com>
Thu, 19 Jul 2012 08:18:07 +0000 (08:18 +0000)
committerHeiko Schocher <hs@denx.de>
Tue, 31 Jul 2012 05:43:25 +0000 (07:43 +0200)
Signed-off-by: Troy Kisky <troy.kisky@boundarydevices.com>
drivers/i2c/mxc_i2c.c

index 4ce695a52d0d9a93d213f3a6f3e572e6ead6bd3b..55a688a80282cba2dec42c0f5a8f9d56dde66f48 100644 (file)
@@ -337,8 +337,10 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buf, int len)
        writeb(temp, &i2c_regs->i2cr);
 
        ret = tx_byte(i2c_regs, (chip << 1) | 1);
-       if (ret < 0)
+       if (ret < 0) {
+               i2c_imx_stop();
                return ret;
+       }
 
        /* setup bus to read data */
        temp = readb(&i2c_regs->i2cr);
@@ -352,8 +354,10 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buf, int len)
        /* read data */
        for (i = 0; i < len; i++) {
                ret = i2c_imx_trx_complete();
-               if (ret)
+               if (ret) {
+                       i2c_imx_stop();
                        return ret;
+               }
 
                /*
                 * It must generate STOP before read I2DR to prevent
@@ -395,7 +399,7 @@ int i2c_write(uchar chip, uint addr, int alen, uchar *buf, int len)
        for (i = 0; i < len; i++) {
                ret = tx_byte(i2c_regs, buf[i]);
                if (ret < 0)
-                       return ret;
+                       break;
        }
 
        i2c_imx_stop();