Merge branch 'i2c/for-current' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux

Pull i2c bugfixes from Wolfram Sang:
"A few driver bugfixes for 3.18"

* 'i2c/for-current' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux:
i2c: omap: fix i207 errata handling
i2c: designware: prevent early stop on TX FIFO empty
i2c: omap: fix NACK and Arbitration Lost irq handling

Changed files
+6 -6
drivers
+1 -1
drivers/i2c/busses/i2c-designware-core.c
··· 359 } 360 361 /* Configure Tx/Rx FIFO threshold levels */ 362 - dw_writel(dev, dev->tx_fifo_depth - 1, DW_IC_TX_TL); 363 dw_writel(dev, 0, DW_IC_RX_TL); 364 365 /* configure the i2c master */
··· 359 } 360 361 /* Configure Tx/Rx FIFO threshold levels */ 362 + dw_writel(dev, dev->tx_fifo_depth / 2, DW_IC_TX_TL); 363 dw_writel(dev, 0, DW_IC_RX_TL); 364 365 /* configure the i2c master */
+5 -5
drivers/i2c/busses/i2c-omap.c
··· 922 if (stat & OMAP_I2C_STAT_NACK) { 923 err |= OMAP_I2C_STAT_NACK; 924 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_NACK); 925 - break; 926 } 927 928 if (stat & OMAP_I2C_STAT_AL) { 929 dev_err(dev->dev, "Arbitration lost\n"); 930 err |= OMAP_I2C_STAT_AL; 931 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_AL); 932 - break; 933 } 934 935 /* ··· 952 if (dev->fifo_size) 953 num_bytes = dev->buf_len; 954 955 - omap_i2c_receive_data(dev, num_bytes, true); 956 - 957 - if (dev->errata & I2C_OMAP_ERRATA_I207) 958 i2c_omap_errata_i207(dev, stat); 959 960 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_RDR); 961 continue; 962 }
··· 922 if (stat & OMAP_I2C_STAT_NACK) { 923 err |= OMAP_I2C_STAT_NACK; 924 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_NACK); 925 } 926 927 if (stat & OMAP_I2C_STAT_AL) { 928 dev_err(dev->dev, "Arbitration lost\n"); 929 err |= OMAP_I2C_STAT_AL; 930 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_AL); 931 } 932 933 /* ··· 954 if (dev->fifo_size) 955 num_bytes = dev->buf_len; 956 957 + if (dev->errata & I2C_OMAP_ERRATA_I207) { 958 i2c_omap_errata_i207(dev, stat); 959 + num_bytes = (omap_i2c_read_reg(dev, 960 + OMAP_I2C_BUFSTAT_REG) >> 8) & 0x3F; 961 + } 962 963 + omap_i2c_receive_data(dev, num_bytes, true); 964 omap_i2c_ack_stat(dev, OMAP_I2C_STAT_RDR); 965 continue; 966 }