Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/ic diff reduction with openbsd; turn debugging on.
details: https://anonhg.NetBSD.org/src/rev/436fbc3fdeaa
branches: trunk
changeset: 346088:436fbc3fdeaa
user: christos <christos%NetBSD.org@localhost>
date: Fri Jun 24 16:08:54 2016 +0000
description:
diff reduction with openbsd; turn debugging on.
diffstat:
sys/dev/ic/rt2860.c | 31 ++++++++++++++++++++++++++-----
1 files changed, 26 insertions(+), 5 deletions(-)
diffs (80 lines):
diff -r d482d4090523 -r 436fbc3fdeaa sys/dev/ic/rt2860.c
--- a/sys/dev/ic/rt2860.c Fri Jun 24 15:25:43 2016 +0000
+++ b/sys/dev/ic/rt2860.c Fri Jun 24 16:08:54 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rt2860.c,v 1.16 2016/06/17 17:03:20 christos Exp $ */
+/* $NetBSD: rt2860.c,v 1.17 2016/06/24 16:08:54 christos Exp $ */
/* $OpenBSD: rt2860.c,v 1.90 2016/04/13 10:49:26 mpi Exp $ */
/*-
@@ -23,7 +23,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rt2860.c,v 1.16 2016/06/17 17:03:20 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rt2860.c,v 1.17 2016/06/24 16:08:54 christos Exp $");
#include <sys/param.h>
#include <sys/sockio.h>
@@ -64,7 +64,7 @@
#ifdef RAL_DEBUG
#define DPRINTF(x) do { if (rt2860_debug > 0) printf x; } while (0)
#define DPRINTFN(n, x) do { if (rt2860_debug >= (n)) printf x; } while (0)
-int rt2860_debug = 0;
+int rt2860_debug = 4;
#else
#define DPRINTF(x)
#define DPRINTFN(n, x)
@@ -1776,6 +1776,8 @@
continue;
}
+ bpf_mtap(ifp, m);
+
eh = mtod(m, struct ether_header *);
ni = ieee80211_find_txnode(ic, eh->ether_dhost);
if (ni == NULL) {
@@ -1784,8 +1786,6 @@
continue;
}
- bpf_mtap(ifp, m);
-
if ((m = ieee80211_encap(ic, m, ni)) == NULL) {
ieee80211_free_node(ni);
ifp->if_oerrors++;
@@ -1863,6 +1863,22 @@
}
break;
+ case SIOCS80211CHANNEL:
+ /*
+ * This allows for fast channel switching in monitor mode
+ * (used by kismet). In IBSS mode, we must explicitly reset
+ * the interface to generate a new beacon frame.
+ */
+ error = ieee80211_ioctl(ic, cmd, data);
+ if (error == ENETRESET &&
+ ic->ic_opmode == IEEE80211_M_MONITOR) {
+ if ((ifp->if_flags & (IFF_UP | IFF_RUNNING)) ==
+ (IFF_UP | IFF_RUNNING))
+ rt2860_switch_chan(sc, ic->ic_ibss_chan);
+ error = 0;
+ }
+ break;
+
default:
error = ieee80211_ioctl(ic, cmd, data);
}
@@ -2753,6 +2769,11 @@
uint8_t mode, wcid, iv[8];
struct ieee80211_key *k = __UNCONST(ck); /* XXX */
+ /* defer setting of WEP keys until interface is brought up */
+ if ((ic->ic_if.if_flags & (IFF_UP | IFF_RUNNING)) !=
+ (IFF_UP | IFF_RUNNING))
+ return 0;
+
/* map net80211 cipher to RT2860 security mode */
switch (k->wk_cipher->ic_cipher) {
case IEEE80211_CIPHER_WEP:
Home |
Main Index |
Thread Index |
Old Index