diff options
| -rw-r--r-- | drivers/i2c/busses/i2c-s3c2410.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/drivers/i2c/busses/i2c-s3c2410.c b/drivers/i2c/busses/i2c-s3c2410.c index 1305ef190fc1..9e8c875437be 100644 --- a/drivers/i2c/busses/i2c-s3c2410.c +++ b/drivers/i2c/busses/i2c-s3c2410.c | |||
| @@ -290,12 +290,12 @@ static int i2s_s3c_irq_nextbyte(struct s3c24xx_i2c *i2c, unsigned long iicstat) | |||
| 290 | * bus, or started a new i2c message | 290 | * bus, or started a new i2c message |
| 291 | */ | 291 | */ |
| 292 | 292 | ||
| 293 | if (iicstat & S3C2410_IICSTAT_LASTBIT && | 293 | if (iicstat & S3C2410_IICSTAT_LASTBIT && |
| 294 | !(i2c->msg->flags & I2C_M_IGNORE_NAK)) { | 294 | !(i2c->msg->flags & I2C_M_IGNORE_NAK)) { |
| 295 | /* ack was not received... */ | 295 | /* ack was not received... */ |
| 296 | 296 | ||
| 297 | dev_dbg(i2c->dev, "ack was not received\n"); | 297 | dev_dbg(i2c->dev, "ack was not received\n"); |
| 298 | s3c24xx_i2c_stop(i2c, -EREMOTEIO); | 298 | s3c24xx_i2c_stop(i2c, -ENXIO); |
| 299 | goto out_ack; | 299 | goto out_ack; |
| 300 | } | 300 | } |
| 301 | 301 | ||
| @@ -305,7 +305,7 @@ static int i2s_s3c_irq_nextbyte(struct s3c24xx_i2c *i2c, unsigned long iicstat) | |||
| 305 | i2c->state = STATE_WRITE; | 305 | i2c->state = STATE_WRITE; |
| 306 | 306 | ||
| 307 | /* terminate the transfer if there is nothing to do | 307 | /* terminate the transfer if there is nothing to do |
| 308 | * (used by the i2c probe to find devices */ | 308 | * as this is used by the i2c probe to find devices. */ |
| 309 | 309 | ||
| 310 | if (is_lastmsg(i2c) && i2c->msg->len == 0) { | 310 | if (is_lastmsg(i2c) && i2c->msg->len == 0) { |
| 311 | s3c24xx_i2c_stop(i2c, 0); | 311 | s3c24xx_i2c_stop(i2c, 0); |
| @@ -323,7 +323,17 @@ static int i2s_s3c_irq_nextbyte(struct s3c24xx_i2c *i2c, unsigned long iicstat) | |||
| 323 | * end of the message, and if so, work out what to do | 323 | * end of the message, and if so, work out what to do |
| 324 | */ | 324 | */ |
| 325 | 325 | ||
| 326 | if (!(i2c->msg->flags & I2C_M_IGNORE_NAK)) { | ||
| 327 | if (iicstat & S3C2410_IICSTAT_LASTBIT) { | ||
| 328 | dev_dbg(i2c->dev, "WRITE: No Ack\n"); | ||
| 329 | |||
| 330 | s3c24xx_i2c_stop(i2c, -ECONNREFUSED); | ||
| 331 | goto out_ack; | ||
| 332 | } | ||
| 333 | } | ||
| 334 | |||
| 326 | retry_write: | 335 | retry_write: |
| 336 | |||
| 327 | if (!is_msgend(i2c)) { | 337 | if (!is_msgend(i2c)) { |
| 328 | byte = i2c->msg->buf[i2c->msg_ptr++]; | 338 | byte = i2c->msg->buf[i2c->msg_ptr++]; |
| 329 | writeb(byte, i2c->regs + S3C2410_IICDS); | 339 | writeb(byte, i2c->regs + S3C2410_IICDS); |
| @@ -377,17 +387,6 @@ static int i2s_s3c_irq_nextbyte(struct s3c24xx_i2c *i2c, unsigned long iicstat) | |||
| 377 | * going to do any more read/write | 387 | * going to do any more read/write |
| 378 | */ | 388 | */ |
| 379 | 389 | ||
| 380 | if (!(i2c->msg->flags & I2C_M_IGNORE_NAK) && | ||
| 381 | !(is_msglast(i2c) && is_lastmsg(i2c))) { | ||
| 382 | |||
| 383 | if (iicstat & S3C2410_IICSTAT_LASTBIT) { | ||
| 384 | dev_dbg(i2c->dev, "READ: No Ack\n"); | ||
| 385 | |||
| 386 | s3c24xx_i2c_stop(i2c, -ECONNREFUSED); | ||
| 387 | goto out_ack; | ||
| 388 | } | ||
| 389 | } | ||
| 390 | |||
| 391 | byte = readb(i2c->regs + S3C2410_IICDS); | 390 | byte = readb(i2c->regs + S3C2410_IICDS); |
| 392 | i2c->msg->buf[i2c->msg_ptr++] = byte; | 391 | i2c->msg->buf[i2c->msg_ptr++] = byte; |
| 393 | 392 | ||
| @@ -949,3 +948,4 @@ MODULE_DESCRIPTION("S3C24XX I2C Bus driver"); | |||
| 949 | MODULE_AUTHOR("Ben Dooks, <ben@simtec.co.uk>"); | 948 | MODULE_AUTHOR("Ben Dooks, <ben@simtec.co.uk>"); |
| 950 | MODULE_LICENSE("GPL"); | 949 | MODULE_LICENSE("GPL"); |
| 951 | MODULE_ALIAS("platform:s3c2410-i2c"); | 950 | MODULE_ALIAS("platform:s3c2410-i2c"); |
| 951 | MODULE_ALIAS("platform:s3c2440-i2c"); | ||
