aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomoya MORINAGA <tomoya-linux@dsn.okisemi.com>2011-06-08 22:29:29 -0400
committerBen Dooks <ben-linux@fluff.org>2011-07-26 19:02:28 -0400
commit7a9c42ccc9fd4317383e55209f825f974e64aa99 (patch)
treeb5af15e25456fa0a591232367edf25aa7268bafe
parent5c470f39eea66ff00b31136f8bce9359d6b95375 (diff)
i2c-eg20t : Support Combined R/W transfer mode
Currently, Combined R/W transfer mode is not supported. This patch enables Combined R/W transfer mode. Signed-off-by: Tomoya MORINAGA <tomoya-linux@dsn.okisemi.com> Signed-off-by: Ben Dooks <ben-linux@fluff.org>
-rw-r--r--drivers/i2c/busses/i2c-eg20t.c39
1 files changed, 20 insertions, 19 deletions
diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
index 8abfa4a03ce1..9b072fd42108 100644
--- a/drivers/i2c/busses/i2c-eg20t.c
+++ b/drivers/i2c/busses/i2c-eg20t.c
@@ -673,25 +673,26 @@ static s32 pch_i2c_xfer(struct i2c_adapter *i2c_adap,
673 /* transfer not completed */ 673 /* transfer not completed */
674 adap->pch_i2c_xfer_in_progress = true; 674 adap->pch_i2c_xfer_in_progress = true;
675 675
676 pmsg = &msgs[0]; 676 for (i = 0; i < num; i++) {
677 pmsg->flags |= adap->pch_buff_mode_en; 677 pmsg = &msgs[i];
678 status = pmsg->flags; 678 pmsg->flags |= adap->pch_buff_mode_en;
679 pch_dbg(adap, 679 status = pmsg->flags;
680 "After invoking I2C_MODE_SEL :flag= 0x%x\n", status); 680 pch_dbg(adap,
681 /* calculate sub address length and message length */ 681 "After invoking I2C_MODE_SEL :flag= 0x%x\n", status);
682 /* these are applicable only for buffer mode */ 682 /* calculate sub address length and message length */
683 subaddrlen = pmsg->buf[0]; 683 /* these are applicable only for buffer mode */
684 /* calculate actual message length excluding 684 subaddrlen = pmsg->buf[0];
685 * the sub address fields */ 685 /* calculate actual message length excluding
686 msglen = (pmsg->len) - (subaddrlen + 1); 686 * the sub address fields */
687 if (status & (I2C_M_RD)) { 687 msglen = (pmsg->len) - (subaddrlen + 1);
688 pch_dbg(adap, "invoking pch_i2c_readbytes\n"); 688
689 ret = pch_i2c_readbytes(i2c_adap, pmsg, (i + 1 == num), 689 if ((status & (I2C_M_RD)) != false) {
690 (i == 0)); 690 ret = pch_i2c_readbytes(i2c_adap, pmsg, (i + 1 == num),
691 } else { 691 (i == 0));
692 pch_dbg(adap, "invoking pch_i2c_writebytes\n"); 692 } else {
693 ret = pch_i2c_writebytes(i2c_adap, pmsg, (i + 1 == num), 693 ret = pch_i2c_writebytes(i2c_adap, pmsg, (i + 1 == num),
694 (i == 0)); 694 (i == 0));
695 }
695 } 696 }
696 697
697 adap->pch_i2c_xfer_in_progress = false; /* transfer completed */ 698 adap->pch_i2c_xfer_in_progress = false; /* transfer completed */