diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2005-11-18 23:19:29 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2005-11-18 23:19:29 +0000 |
commit | dd9ef7ccc24fee1cd11d32e88dbf3aadd9e09802 (patch) | |
tree | 4eb26fc5bde2f019ae3f6b15128bef88b950fad0 | |
parent | b5c587053d4bd5ee3c33d88f93a6bc204296e720 (diff) |
Fix writes on the i2c bus.
ok deraadt@
-rw-r--r-- | sys/arch/macppc/dev/ki2c.c | 23 |
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); |