diff options
author | nsouch <nsouch@FreeBSD.org> | 1999-02-13 18:01:55 +0000 |
---|---|---|
committer | nsouch <nsouch@FreeBSD.org> | 1999-02-13 18:01:55 +0000 |
commit | a05e5f31788b102fbf47060439852a490b3342a6 (patch) | |
tree | 303797351ffa309ae0474c77da544121a4267a0c /sys/dev/iicbus/iic.c | |
parent | b54915a02a005ac44ae03d3389cbd4bb9eb36eb0 (diff) | |
download | FreeBSD-src-a05e5f31788b102fbf47060439852a490b3342a6.zip FreeBSD-src-a05e5f31788b102fbf47060439852a490b3342a6.tar.gz |
Handle correctly iicbus request/release mechanism. Add iicbus allocation
to the general purpose i/o iic(4) driver.
Diffstat (limited to 'sys/dev/iicbus/iic.c')
-rw-r--r-- | sys/dev/iicbus/iic.c | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/sys/dev/iicbus/iic.c b/sys/dev/iicbus/iic.c index e41d08b..6bcadf9 100644 --- a/sys/dev/iicbus/iic.c +++ b/sys/dev/iicbus/iic.c @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: iic.c,v 1.5 1998/12/07 21:58:16 archie Exp $ + * $Id: iic.c,v 1.6 1999/01/09 18:08:24 nsouch Exp $ * */ #include <sys/param.h> @@ -35,6 +35,7 @@ #include <sys/buf.h> #include <sys/uio.h> #include <sys/malloc.h> +#include <sys/fcntl.h> #include <machine/clock.h> @@ -169,12 +170,17 @@ iicwrite(dev_t dev, struct uio * uio, int ioflag) if (sc->sc_count == 0) return (EINVAL); + if ((error = iicbus_request_bus(device_get_parent(iicdev), iicdev, IIC_DONTWAIT))) + return (error); + count = min(uio->uio_resid, BUFSIZE); uiomove(sc->sc_buffer, count, uio); error = iicbus_block_write(device_get_parent(iicdev), sc->sc_addr, sc->sc_buffer, count, &sent); + iicbus_release_bus(device_get_parent(iicdev), iicdev); + return(error); } @@ -192,6 +198,9 @@ iicread(dev_t dev, struct uio * uio, int ioflag) if (sc->sc_count == 0) return (EINVAL); + if ((error = iicbus_request_bus(device_get_parent(iicdev), iicdev, IIC_DONTWAIT))) + return (error); + /* max amount of data to read */ len = min(uio->uio_resid, BUFSIZE); @@ -202,6 +211,8 @@ iicread(dev_t dev, struct uio * uio, int ioflag) if (bufsize > uio->uio_resid) panic("%s: too much data read!", __FUNCTION__); + iicbus_release_bus(device_get_parent(iicdev), iicdev); + return (uiomove(sc->sc_inbuf, bufsize, uio)); } @@ -217,6 +228,11 @@ iicioctl(dev_t dev, u_long cmd, caddr_t data, int flags, struct proc *p) if (!sc) return (EINVAL); + if ((error = iicbus_request_bus(device_get_parent(iicdev), iicdev, + (flags & O_NONBLOCK) ? IIC_DONTWAIT : + (IIC_WAIT | IIC_INTR)))) + return (error); + switch (cmd) { case I2CSTART: error = iicbus_start(parent, s->slave, 0); @@ -242,6 +258,8 @@ iicioctl(dev_t dev, u_long cmd, caddr_t data, int flags, struct proc *p) error = ENODEV; } + iicbus_release_bus(device_get_parent(iicdev), iicdev); + return (error); } |