Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 9 Jun 2007 19:49:42 GMT
From:      Andrew Thompson <thompsa@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 121288 for review
Message-ID:  <200706091949.l59JngJE014515@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=121288

Change 121288 by thompsa@thompsa_heff on 2007/06/09 19:48:50

	Remove the scan naming for the command queue, its generic now.

Affected files ...

.. //depot/projects/wifi/sys/dev/iwi/if_iwi.c#45 edit
.. //depot/projects/wifi/sys/dev/iwi/if_iwivar.h#19 edit

Differences ...

==== //depot/projects/wifi/sys/dev/iwi/if_iwi.c#45 (text+ko) ====

@@ -174,7 +174,7 @@
 static void     iwi_assoc(struct ieee80211com *ic);
 static void     iwi_disassoc(struct ieee80211com *);
 static void	iwi_ops(void *, int);
-static int	iwi_scan_cmd(struct iwi_softc *, int);
+static int	iwi_queue_cmd(struct iwi_softc *, int);
 static int	iwi_auth_and_assoc(struct iwi_softc *);
 static int	iwi_disassociate(struct iwi_softc *, int quiet);
 static void	iwi_init(void *);
@@ -261,7 +261,7 @@
 	sc->sc_dev = dev;
 
 	IWI_LOCK_INIT(sc);
-	IWI_SCAN_LOCK_INIT(sc);
+	IWI_CMD_LOCK_INIT(sc);
 
 	sc->sc_unr = new_unrhdr(1, IWI_MAX_IBSSNODE-1, &sc->sc_mtx);
 
@@ -488,7 +488,7 @@
 		delete_unrhdr(sc->sc_unr);
 
 	IWI_LOCK_DESTROY(sc);
-	IWI_SCAN_LOCK_DESTROY(sc);
+	IWI_CMD_LOCK_DESTROY(sc);
 
 	return 0;
 }
@@ -1079,7 +1079,7 @@
 	 * will get sent down to the adapter as part of the
 	 * work iwi_auth_and_assoc does.
 	 */
-	return (iwi_scan_cmd(sc, IWI_SET_WME));
+	return (iwi_queue_cmd(sc, IWI_SET_WME));
 }
 
 static int
@@ -3510,16 +3510,16 @@
 	int cmd;
 
 again:
-	IWI_SCAN_LOCK(sc);
-	cmd = sc->sc_scanop[sc->sc_scan_cur];
+	IWI_CMD_LOCK(sc);
+	cmd = sc->sc_cmd[sc->sc_cmd_cur];
 	if (cmd == 0) {
 		/* No more commands to process */
-		IWI_SCAN_UNLOCK(sc);
+		IWI_CMD_UNLOCK(sc);
 		return;
 	}
-	sc->sc_scanop[sc->sc_scan_cur] = 0;	/* free the slot */
-	sc->sc_scan_cur = (sc->sc_scan_cur + 1) % IWI_SCAN_OPS;
-	IWI_SCAN_UNLOCK(sc);
+	sc->sc_cmd[sc->sc_cmd_cur] = 0;	/* free the slot */
+	sc->sc_cmd_cur = (sc->sc_cmd_cur + 1) % IWI_CMD_MAXOPS;
+	IWI_CMD_UNLOCK(sc);
 
 	IWI_LOCK(sc);
 	while  ((ic->ic_state !=  IEEE80211_S_INIT) && (sc->flags & IWI_FLAG_BUSY)) {
@@ -3566,19 +3566,19 @@
 }
 
 static int
-iwi_scan_cmd(struct iwi_softc *sc, int cmd)
+iwi_queue_cmd(struct iwi_softc *sc, int cmd)
 {
-	IWI_SCAN_LOCK(sc);
-	if (sc->sc_scanop[sc->sc_scan_next] != 0) {
-		IWI_SCAN_UNLOCK(sc);
-		DPRINTF(("%s: scan command %d dropped\n", __func__, cmd));
+	IWI_CMD_LOCK(sc);
+	if (sc->sc_cmd[sc->sc_cmd_next] != 0) {
+		IWI_CMD_UNLOCK(sc);
+		DPRINTF(("%s: command %d dropped\n", __func__, cmd));
 		return (EBUSY);
 	}
 
-	sc->sc_scanop[sc->sc_scan_next] = cmd;
-	sc->sc_scan_next = (sc->sc_scan_next + 1) % IWI_SCAN_OPS;
+	sc->sc_cmd[sc->sc_cmd_next] = cmd;
+	sc->sc_cmd_next = (sc->sc_cmd_next + 1) % IWI_CMD_MAXOPS;
 	taskqueue_enqueue(sc->sc_tq, &sc->sc_opstask);
-	IWI_SCAN_UNLOCK(sc);
+	IWI_CMD_UNLOCK(sc);
 	return (0);
 }
 
@@ -3588,7 +3588,7 @@
 	struct ifnet *ifp = ic->ic_ifp;
 	struct iwi_softc *sc = ifp->if_softc;
 
-	iwi_scan_cmd(sc, IWI_SCAN_START);
+	iwi_queue_cmd(sc, IWI_SCAN_START);
 }
 
 static void
@@ -3607,7 +3607,7 @@
 	struct iwi_softc *sc = ifp->if_softc;
 
 	sc->sc_maxdwell = maxdwell;
-	iwi_scan_cmd(sc, IWI_SCAN_CURCHAN);
+	iwi_queue_cmd(sc, IWI_SCAN_CURCHAN);
 }
 
 #if 0
@@ -3618,7 +3618,7 @@
 	struct iwi_softc *sc = ifp->if_softc;
 
 	sc->sc_maxdwell = maxdwell;
-	iwi_scan_cmd(sc, IWI_SCAN_ALLCHAN);
+	iwi_queue_cmd(sc, IWI_SCAN_ALLCHAN);
 }
 #endif
 
@@ -3634,7 +3634,7 @@
 	struct ifnet *ifp = ic->ic_ifp;
 	struct iwi_softc *sc = ifp->if_softc;
 
-	iwi_scan_cmd(sc, IWI_SCAN_END);
+	iwi_queue_cmd(sc, IWI_SCAN_END);
 }
 
 static void
@@ -3643,7 +3643,7 @@
 	struct ifnet *ifp = ic->ic_ifp;
 	struct iwi_softc *sc = ifp->if_softc;
 
-	iwi_scan_cmd(sc, IWI_ASSOC);
+	iwi_queue_cmd(sc, IWI_ASSOC);
 }
 
 static void
@@ -3652,5 +3652,5 @@
 	struct ifnet *ifp = ic->ic_ifp;
 	struct iwi_softc *sc = ifp->if_softc;
 
-	iwi_scan_cmd(sc, IWI_DISASSOC);
+	iwi_queue_cmd(sc, IWI_DISASSOC);
 }

==== //depot/projects/wifi/sys/dev/iwi/if_iwivar.h#19 (text+ko) ====

@@ -123,8 +123,8 @@
 	device_t		sc_dev;
 
 	struct mtx		sc_mtx;
-	struct mtx		sc_scanlock;
-	char			sc_scanname[12];	/* e.g. "iwi0_scan" */
+	struct mtx		sc_cmdlock;
+	char			sc_cmdname[12];	/* e.g. "iwi0_cmd" */
 	uint8_t			sc_mcast[IEEE80211_ADDR_LEN];
 	struct unrhdr		*sc_unr;
 	struct taskqueue	*sc_tq;		/* private task queue */
@@ -215,10 +215,10 @@
 #define	IWI_SCAN_CURCHAN	(1 << 5)
 #define	IWI_SCAN_ALLCHAN	(1 << 6)
 #define	IWI_SET_WME		(1 << 7)
-#define	IWI_SCAN_OPS		5
-	int                     sc_scanop[IWI_SCAN_OPS];
-	int                     sc_scan_cur;    /* current queued scan task */
-	int                     sc_scan_next;   /* last queued scan task */
+#define	IWI_CMD_MAXOPS		10
+	int                     sc_cmd[IWI_CMD_MAXOPS];
+	int                     sc_cmd_cur;    /* current queued scan task */
+	int                     sc_cmd_next;   /* last queued scan task */
 	unsigned long		sc_maxdwell;	/* max dwell time for curchan */
 	struct bpf_if		*sc_drvbpf;
 
@@ -255,11 +255,11 @@
 	if (!__waslocked)			\
 		mtx_unlock(&(sc)->sc_mtx);	\
 } while (0)
-#define	IWI_SCAN_LOCK_INIT(sc) do { \
-	snprintf((sc)->sc_scanname, sizeof((sc)->sc_scanname), "%s_scan", \
+#define	IWI_CMD_LOCK_INIT(sc) do { \
+	snprintf((sc)->sc_cmdname, sizeof((sc)->sc_cmdname), "%s_cmd", \
 		device_get_nameunit((sc)->sc_dev)); \
-	mtx_init(&(sc)->sc_scanlock, (sc)->sc_scanname, NULL, MTX_DEF); \
+	mtx_init(&(sc)->sc_cmdlock, (sc)->sc_cmdname, NULL, MTX_DEF); \
 } while (0)
-#define	IWI_SCAN_LOCK_DESTROY(sc)	mtx_destroy(&(sc)->sc_scanlock)
-#define	IWI_SCAN_LOCK(sc)		mtx_lock(&(sc)->sc_scanlock)
-#define	IWI_SCAN_UNLOCK(sc)		mtx_unlock(&(sc)->sc_scanlock)
+#define	IWI_CMD_LOCK_DESTROY(sc)	mtx_destroy(&(sc)->sc_cmdlock)
+#define	IWI_CMD_LOCK(sc)		mtx_lock(&(sc)->sc_cmdlock)
+#define	IWI_CMD_UNLOCK(sc)		mtx_unlock(&(sc)->sc_cmdlock)



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200706091949.l59JngJE014515>