Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/phil-wifi]: src/sys/net80211 Final changes for 200 hour contract. Still...
details: https://anonhg.NetBSD.org/src/rev/ab42a5bc7e18
branches: phil-wifi
changeset: 1025115:ab42a5bc7e18
user: phil <phil%NetBSD.org@localhost>
date: Wed Aug 15 17:07:02 2018 +0000
description:
Final changes for 200 hour contract. Still a lot of work to do.
With these changes, Station mode works with an open AP.
diffstat:
sys/arch/amd64/conf/TESTWIFI | 8 +-
sys/dev/usb/if_urtwn.c | 101 ++++++++++---------
sys/dev/usb/if_urtwnvar.h | 5 +-
sys/net80211/ieee80211.c | 5 +-
sys/net80211/ieee80211_input.c | 3 +-
sys/net80211/ieee80211_ioctl.c | 195 +++++++++++++++++++++++++++++++++++--
sys/net80211/ieee80211_ioctl.h | 28 +++++-
sys/net80211/ieee80211_netbsd.c | 14 +-
sys/net80211/ieee80211_netbsd.h | 6 +-
sys/net80211/ieee80211_node.c | 18 +-
sys/net80211/ieee80211_output.c | 4 +-
sys/net80211/ieee80211_proto.c | 30 +++--
sys/net80211/ieee80211_scan_sta.c | 5 +-
sys/net80211/ieee80211_sta.c | 4 +-
14 files changed, 315 insertions(+), 111 deletions(-)
diffs (truncated from 1015 to 300 lines):
diff -r a32b1f3d37a8 -r ab42a5bc7e18 sys/arch/amd64/conf/TESTWIFI
--- a/sys/arch/amd64/conf/TESTWIFI Fri Aug 03 19:47:25 2018 +0000
+++ b/sys/arch/amd64/conf/TESTWIFI Wed Aug 15 17:07:02 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: TESTWIFI,v 1.1.2.2 2018/08/03 19:47:25 phil Exp $
+# $NetBSD: TESTWIFI,v 1.1.2.3 2018/08/15 17:07:02 phil Exp $
#
# GENERIC machine description file
#
@@ -22,7 +22,7 @@
options INCLUDE_CONFIG_FILE # embed config file in kernel binary
-#ident "GENERIC-$Revision: 1.1.2.2 $"
+#ident "GENERIC-$Revision: 1.1.2.3 $"
maxusers 64 # estimated number of users
@@ -194,7 +194,7 @@
# Networking options
#options GATEWAY # packet forwarding
options INET # IP + ICMP + TCP + UDP
-options INET6 # IPV6
+#options INET6 # IPV6
options IPSEC # IP security
#options IPSEC_DEBUG # debug for IP security
#options MPLS # MultiProtocol Label Switching (needs mpls)
@@ -1306,7 +1306,7 @@
pseudo-device gif # IPv[46] over IPv[46] tunnel (RFC1933)
pseudo-device ipsecif # tunnel interface for routing based ipsec
#pseudo-device faith # IPv[46] tcp relay translation i/f
-pseudo-device stf # 6to4 IPv6 over IPv4 encapsulation
+#pseudo-device stf # 6to4 IPv6 over IPv4 encapsulation
pseudo-device vlan # IEEE 802.1q encapsulation
pseudo-device bridge # simple inter-network bridging
#options BRIDGE_IPF # bridge uses IP/IPv6 pfil hooks too
diff -r a32b1f3d37a8 -r ab42a5bc7e18 sys/dev/usb/if_urtwn.c
--- a/sys/dev/usb/if_urtwn.c Fri Aug 03 19:47:25 2018 +0000
+++ b/sys/dev/usb/if_urtwn.c Wed Aug 15 17:07:02 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_urtwn.c,v 1.59.2.5 2018/08/03 19:47:25 phil Exp $ */
+/* $NetBSD: if_urtwn.c,v 1.59.2.6 2018/08/15 17:07:02 phil Exp $ */
/* $OpenBSD: if_urtwn.c,v 1.42 2015/02/10 23:25:46 mpi Exp $ */
/*-
@@ -42,7 +42,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.5 2018/08/03 19:47:25 phil Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.6 2018/08/15 17:07:02 phil Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -111,7 +111,7 @@
#define DBG_REG __BIT(6)
#define DBG_ALL 0xffffffffU
/* NNN Reset urtwn_debug to 0 when done debugging. */
-u_int urtwn_debug = DBG_FN;
+u_int urtwn_debug = 0;
#define DPRINTFN(n, s) \
do { if (urtwn_debug & (n)) printf s; } while (/*CONSTCOND*/0)
#else
@@ -342,15 +342,15 @@
static void urtwn_vap_delete(struct ieee80211vap *);
static int urtwn_ioctl(struct ifnet *, u_long, void *);
static void urtwn_parent(struct ieee80211com *);
+static void urtwn_getradiocaps(struct ieee80211com *, int, int *,
+ struct ieee80211_channel []);
static void urtwn_scan_start(struct ieee80211com *);
static void urtwn_scan_end(struct ieee80211com *);
static void urtwn_set_channel(struct ieee80211com *);
static int urtwn_transmit(struct ieee80211com *, struct mbuf *);
-static int urtwn_send_mgmt(struct ieee80211_node *, int, int);
static int urtwn_raw_xmit(struct ieee80211_node *, struct mbuf *,
const struct ieee80211_bpf_params *);
-static void urtwn_getradiocaps(struct ieee80211com *, int, int *,
- struct ieee80211_channel []);
+//static int urtwn_send_mgmt(struct ieee80211_node *, int, int);
/* Aliases. */
#define urtwn_bb_write urtwn_write_4
@@ -393,6 +393,14 @@
/* Name the ic. */
ic->ic_name = "urtwn";
+ /* Driver Send queue, separate from the if send queue*/
+ sc->sc_sendq.ifq_maxlen = 32;
+ /* NNN how should this be initialized? */
+ sc->sc_sendq.ifq_head = sc->sc_sendq.ifq_tail = NULL;
+ sc->sc_sendq.ifq_len = 0;
+ sc->sc_sendq.ifq_drops = 0;
+ IFQ_LOCK_INIT(&sc->sc_sendq);
+
sc->chip = 0;
dev = urtwn_lookup(urtwn_devs, uaa->uaa_vendor, uaa->uaa_product);
if (dev != NULL && ISSET(dev->flags, FLAG_RTL8188E))
@@ -554,7 +562,7 @@
}
/* Debug all! NNN */
- vap->iv_debug = IEEE80211_MSG_ANY;
+ // vap->iv_debug = IEEE80211_MSG_ANY;
bpf_attach2(vap->iv_ifp, DLT_IEEE802_11_RADIO,
sizeof(struct ieee80211_frame) + IEEE80211_RADIOTAP_HDRLEN,
@@ -611,6 +619,10 @@
urtwn_close_pipes(sc);
}
+ /* sendq destroy */
+ IFQ_PURGE(&sc->sc_sendq);
+ IFQ_LOCK_DESTROY(&sc->sc_sendq);
+
splx(s);
usbd_add_drv_event(USB_EVENT_DRIVER_DETACH, sc->sc_udev, sc->sc_dev);
@@ -2082,7 +2094,7 @@
case IEEE80211_S_ASSOC:
break;
- case IEEE80211_S_RUN:
+ case IEEE80211_S_RUN:
ni = vap->iv_bss;
/* XXX: Set 20MHz mode */
@@ -2794,6 +2806,7 @@
/* Finalize mbuf. */
m_set_rcvif(m, ifp);
wh = (struct ieee80211_frame *)((uint8_t *)&stat[1] + infosz);
+
memcpy(mtod(m, uint8_t *), wh, pktlen);
m->m_pkthdr.len = m->m_len = pktlen;
@@ -2977,7 +2990,7 @@
}
ifp->if_opackets++;
- urtwn_start(ifp);
+ urtwn_start(ifp);
splx(s);
}
@@ -2997,11 +3010,6 @@
DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
- KASSERT(sc != NULL); // NNN
- KASSERT(m != NULL);
- KASSERT(ni != NULL);
- KASSERT(data != NULL);
-
wh = mtod(m, struct ieee80211_frame *);
type = wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK;
txd_len = sizeof(*txd);
@@ -3177,8 +3185,13 @@
xferlen = txd_len + m->m_pkthdr.len + padsize;
m_copydata(m, 0, m->m_pkthdr.len, (char *)&txd[0] + txd_len + padsize);
- printf ("urtwn_tx just before splnet()\n");
- KASSERT(data != NULL);
+ if (data->xfer == NULL) {
+ /* NNN Don't crash ... but what is going on! */
+ printf ("urtwn_tx: data->xfer is NULL\n");
+ m_print(m,"", printf);
+ return -1;
+ }
+
s = splnet();
usbd_setup_xfer(data->xfer, data, data->buf, xferlen,
USBD_FORCE_SHORT_XFER, URTWN_TX_TIMEOUT,
@@ -3192,7 +3205,6 @@
return error;
}
splx(s);
- printf ("urtwn_tx just before splnet()\n");
return 0;
}
@@ -3252,7 +3264,7 @@
break;
/* Encapsulate and send data frames. */
- IFQ_POLL(&ifp->if_snd, m);
+ IFQ_POLL(&sc->sc_sendq, m);
if (m == NULL)
break;
@@ -3275,7 +3287,7 @@
device_xname(sc->sc_dev)));
return;
}
- IFQ_DEQUEUE(&ifp->if_snd, m);
+ IFQ_DEQUEUE(&sc->sc_sendq, m);
if (m->m_len < (int)sizeof(*eh) &&
(m = m_pullup(m, sizeof(*eh))) == NULL) {
@@ -3292,17 +3304,9 @@
continue;
}
- bpf_mtap(ifp, m, BPF_D_OUT);
-
- if ((m = ieee80211_encap(vap, ni, m)) == NULL) {
- ieee80211_free_node(ni);
- printf("ERROR4\n");
- ifp->if_oerrors++;
- continue;
- }
+ //bpf_mtap(ifp, m, BPF_D_OUT);
+
sendit:
- bpf_mtap3(vap->iv_rawbpf, m, BPF_D_OUT);
-
if (urtwn_tx(sc, m, ni, data) != 0) {
m_freem(m);
ieee80211_free_node(ni);
@@ -3317,7 +3321,7 @@
}
}
-static void
+static __unused void
urtwn_watchdog(struct ifnet *ifp)
{
struct ieee80211vap *vap = ifp->if_softc;
@@ -3368,8 +3372,6 @@
return NULL;
}
- printf ("vap_create: after vap_setup\n");
-
/* Local setup */
vap->iv_reset = urtwn_reset;
@@ -3377,9 +3379,9 @@
ifp->if_init = urtwn_init;
ifp->if_ioctl = urtwn_ioctl;
ifp->if_start = urtwn_start;
- ifp->if_watchdog = urtwn_watchdog;
+ // ifp->if_watchdog = urtwn_watchdog; NNN
ifp->if_extflags |= IFEF_MPSAFE;
- IFQ_SET_READY(&ifp->if_snd);
+ // IFQ_SET_READY(&ifp->if_snd);
memcpy(ifp->if_xname, device_xname(sc->sc_dev), IFNAMSIZ);
/* Override state transition machine. */
@@ -3530,7 +3532,6 @@
struct urtwn_softc *sc = ic->ic_softc;
struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
int s;
- int error;
size_t pktlen = m->m_pkthdr.len;
bool mcast = (m->m_flags & M_MCAST) != 0;
@@ -3538,11 +3539,7 @@
s = splnet();
- IFQ_ENQUEUE(&vap->iv_ifp->if_snd, m, error);
- if (error != 0) {
- /* mbuf is already freed */
- goto out;
- }
+ IF_ENQUEUE(&sc->sc_sendq, m);
vap->iv_ifp->if_obytes += pktlen;
if (mcast)
@@ -3550,18 +3547,28 @@
if ((vap->iv_ifp->if_flags & IFF_OACTIVE) == 0)
if_start_lock(vap->iv_ifp);
-out:
splx(s);
- return error;
+ urtwn_start(vap->iv_ifp);
+
+ return 0;
}
-static __unused int urtwn_send_mgmt(struct ieee80211_node *ni, int type, int arg)
-{
- printf ("urtwn_send_mgmt: type %d, arg %d\n", type, arg);
- return ENOENT;
+#if 0
+static int
+urtwn_send_mgmt(struct ieee80211_node *ni, int arg1, int arg2) {
+#ifdef URTWN_DEBUG
+ // struct ieee80211vap *vap = ni->ni_vap;
+ struct ieee80211com *ic = ni->ni_ic;
+ struct urtwn_softc *sc = ic->ic_softc;
+#endif
+
+ DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+ /* Don't know what to do right now. */
+ return ENOTTY;
}
-
Home |
Main Index |
Thread Index |
Old Index