summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2007-05-14 00:46:22 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2007-05-14 00:46:22 +0000
commit442df37fb84eb0213e7d22311affe5c255951337 (patch)
tree7babfeb808f782eb2a27f5bd70eee1c0d39f6d66 /sys/dev
parent4ef538b5713951d93732e5e5f00b6287e1bfa80b (diff)
Convert from lockmgr to rwlock.
Initial diff from krw@, uneeded lock_mii()/unlock_mii() on all commands in existing code removed by me so it doesn't try to recurse. ok krw@
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/usb/if_axe.c12
-rw-r--r--sys/dev/usb/if_axereg.h4
2 files changed, 7 insertions, 9 deletions
diff --git a/sys/dev/usb/if_axe.c b/sys/dev/usb/if_axe.c
index d45149e66c6..132c9a955a4 100644
--- a/sys/dev/usb/if_axe.c
+++ b/sys/dev/usb/if_axe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_axe.c,v 1.65 2007/05/05 13:43:25 jsg Exp $ */
+/* $OpenBSD: if_axe.c,v 1.66 2007/05/14 00:46:21 jsg Exp $ */
/*
* Copyright (c) 2005, 2006, 2007 Jonathan Gray <jsg@openbsd.org>
@@ -94,7 +94,7 @@
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/sockio.h>
-#include <sys/lock.h>
+#include <sys/rwlock.h>
#include <sys/mbuf.h>
#include <sys/kernel.h>
#include <sys/proc.h>
@@ -208,13 +208,13 @@ Static void
axe_lock_mii(struct axe_softc *sc)
{
sc->axe_refcnt++;
- usb_lockmgr(&sc->axe_mii_lock, LK_EXCLUSIVE, NULL, curproc);
+ rw_enter_write(&sc->axe_mii_lock);
}
Static void
axe_unlock_mii(struct axe_softc *sc)
{
- usb_lockmgr(&sc->axe_mii_lock, LK_RELEASE, NULL, curproc);
+ rw_exit_write(&sc->axe_mii_lock);
if (--sc->axe_refcnt < 0)
usb_detach_wakeup(USBDEV(sc->axe_dev));
}
@@ -228,7 +228,6 @@ axe_cmd(struct axe_softc *sc, int cmd, int index, int val, void *buf)
if (sc->axe_dying)
return(0);
- axe_lock_mii(sc);
if (AXE_CMD_DIR(cmd))
req.bmRequestType = UT_WRITE_VENDOR_DEVICE;
else
@@ -239,7 +238,6 @@ axe_cmd(struct axe_softc *sc, int cmd, int index, int val, void *buf)
USETW(req.wLength, AXE_CMD_LEN(cmd));
err = usbd_do_request(sc->axe_udev, &req, buf);
- axe_unlock_mii(sc);
if (err)
return(-1);
@@ -588,7 +586,7 @@ USB_ATTACH(axe)
sc->axe_flags = axe_lookup(uaa->vendor, uaa->product)->axe_flags;
usb_init_task(&sc->axe_tick_task, axe_tick_task, sc);
- lockinit(&sc->axe_mii_lock, PZERO, "axemii", 0, LK_CANRECURSE);
+ rw_init(&sc->axe_mii_lock, "axemii");
usb_init_task(&sc->axe_stop_task, (void (*)(void *))axe_stop, sc);
err = usbd_device2interface_handle(dev, AXE_IFACE_IDX, &sc->axe_iface);
diff --git a/sys/dev/usb/if_axereg.h b/sys/dev/usb/if_axereg.h
index 60f17a0c71a..d49156d82d1 100644
--- a/sys/dev/usb/if_axereg.h
+++ b/sys/dev/usb/if_axereg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_axereg.h,v 1.14 2007/04/03 00:56:16 jsg Exp $ */
+/* $OpenBSD: if_axereg.h,v 1.15 2007/05/14 00:46:21 jsg Exp $ */
/*
* Copyright (c) 1997, 1998, 1999, 2000-2003
@@ -223,7 +223,7 @@ struct axe_softc {
struct usb_task axe_tick_task;
struct usb_task axe_stop_task;
- struct lock axe_mii_lock;
+ struct rwlock axe_mii_lock;
int axe_link;
unsigned char axe_ipgs[3];