i2c-s3c2410: Correct use of ! and &
authorJulia Lawall <julia@diku.dk>
Thu, 30 Oct 2008 14:55:47 +0000 (15:55 +0100)
committerJean Delvare <khali@linux-fr.org>
Thu, 30 Oct 2008 14:55:47 +0000 (15:55 +0100)
commitda6801e38b7fba28fbdc0ceae6681d5a261a42a6
tree3a04ba9e00486ecc8490f86ef0ff9d2468d2eb2b
parent846557d3ceb6c7493e090921db5d6158ec237228
i2c-s3c2410: Correct use of ! and &

In commit e6bafba5b4765a5a252f1b8d31cbf6d2459da337, a bug was fixed that
involved converting !x & y to !(x & y).  The code below shows the same
pattern, and thus should perhaps be fixed in the same way.  In particular,
the result of !readl(i2c->regs + S3C2410_IICCON) & S3C2410_IICCON_IRQEN is
always 0.

The semantic patch that makes this change is as follows:
(http://www.emn.fr/x-info/coccinelle/)

// <smpl>
@@ expression E; constant C; @@
(
  !E & !C
|
- !E & C
+ !(E & C)
)
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Cc: Ben Dooks <ben-linux@fluff.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Jean Delvare <khali@linux-fr.org>
drivers/i2c/busses/i2c-s3c2410.c