summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2005-11-18 23:19:29 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2005-11-18 23:19:29 +0000
commitdd9ef7ccc24fee1cd11d32e88dbf3aadd9e09802 (patch)
tree4eb26fc5bde2f019ae3f6b15128bef88b950fad0
parentb5c587053d4bd5ee3c33d88f93a6bc204296e720 (diff)
Fix writes on the i2c bus.
ok deraadt@
-rw-r--r--sys/arch/macppc/dev/ki2c.c23
1 files changed, 15 insertions, 8 deletions
diff --git a/sys/arch/macppc/dev/ki2c.c b/sys/arch/macppc/dev/ki2c.c
index 24ac4cd0821..c0cf0292e5d 100644
--- a/sys/arch/macppc/dev/ki2c.c
+++ b/sys/arch/macppc/dev/ki2c.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ki2c.c,v 1.7 2005/11/15 15:35:34 deraadt Exp $ */
+/* $OpenBSD: ki2c.c,v 1.8 2005/11/18 23:19:28 kettenis Exp $ */
/* $NetBSD: ki2c.c,v 1.1 2003/12/27 02:19:34 grant Exp $ */
/*-
@@ -365,21 +365,28 @@ ki2c_i2c_exec(void *cookie, i2c_op_t op, i2c_addr_t addr,
const void *cmdbuf, size_t cmdlen, void *buf, size_t len, int flags)
{
struct ki2c_softc *sc = cookie;
+ u_int mode = I2C_STDSUBMODE;
+ u_int8_t cmd = 0;
- if (!I2C_OP_STOP_P(op))
+ if (!I2C_OP_STOP_P(op) || cmdlen > 1)
return (EINVAL);
- /* We handle the subaddress stuff ourselves. */
- ki2c_setmode(sc, I2C_STDMODE, addr & 0x80);
+ if (cmdlen == 0)
+ mode = I2C_STDMODE;
+ else if (I2C_OP_READ_P(op))
+ mode = I2C_COMBMODE;
+
+ if (cmdlen > 0)
+ cmd = *(u_int8_t *)cmdbuf;
+
+ ki2c_setmode(sc, mode, addr & 0x80);
addr &= 0x7f;
- if (ki2c_write(sc, (addr << 1), 0, cmdbuf, cmdlen) != 0)
- return (EIO);
if (I2C_OP_READ_P(op)) {
- if (ki2c_read(sc, (addr << 1), 0, buf, len) != 0)
+ if (ki2c_read(sc, (addr << 1), cmd, buf, len) != 0)
return (EIO);
} else {
- if (ki2c_write(sc, (addr << 1), 0, buf, len) != 0)
+ if (ki2c_write(sc, (addr << 1), cmd, buf, len) != 0)
return (EIO);
}
return (0);