diff options
author | nsouch <nsouch@FreeBSD.org> | 1999-11-01 23:15:29 +0000 |
---|---|---|
committer | nsouch <nsouch@FreeBSD.org> | 1999-11-01 23:15:29 +0000 |
commit | bfcfa15e6865b531634b7968310a861ce2fa7e70 (patch) | |
tree | 83bd3e3e44238222b8915eab88db8daf0db45cdc /sys/dev/iicbus/iiconf.c | |
parent | 373247212ef9f2056a82796de13a14040b5b57d6 (diff) | |
download | FreeBSD-src-bfcfa15e6865b531634b7968310a861ce2fa7e70.zip FreeBSD-src-bfcfa15e6865b531634b7968310a861ce2fa7e70.tar.gz |
Sync with RELENG_3.
Diffstat (limited to 'sys/dev/iicbus/iiconf.c')
-rw-r--r-- | sys/dev/iicbus/iiconf.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/sys/dev/iicbus/iiconf.c b/sys/dev/iicbus/iiconf.c index 42d3a96..52e92f7 100644 --- a/sys/dev/iicbus/iiconf.c +++ b/sys/dev/iicbus/iiconf.c @@ -104,8 +104,12 @@ iicbus_request_bus(device_t bus, device_t dev, int how) int s, error = 0; /* first, ask the underlying layers if the request is ok */ - error = IICBUS_CALLBACK(device_get_parent(bus), IIC_REQUEST_BUS, - (caddr_t)&how); + do { + error = IICBUS_CALLBACK(device_get_parent(bus), + IIC_REQUEST_BUS, (caddr_t)&how); + if (error) + error = iicbus_poll(sc, how); + } while (error == EWOULDBLOCK); while (!error) { s = splhigh(); |