Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/phil-wifi]: src/sys State save.
details: https://anonhg.NetBSD.org/src/rev/381d98f3628d
branches: phil-wifi
changeset: 324850:381d98f3628d
user: phil <phil%NetBSD.org@localhost>
date: Mon Jul 16 20:11:11 2018 +0000
description:
State save.
urtwn now can attach and shows up in the "ifconfig -a" list.
diffstat:
sys/dev/usb/if_urtwn.c | 179 ++++++++++++++++++++++++---------
sys/dev/usb/if_urtwnvar.h | 8 +-
sys/net80211/ieee80211.c | 46 +++++++-
sys/net80211/ieee80211_acl.c | 10 +-
sys/net80211/ieee80211_amrr.c | 10 +-
sys/net80211/ieee80211_crypto.c | 11 +-
sys/net80211/ieee80211_crypto_tkip.c | 12 ++-
sys/net80211/ieee80211_crypto_wep.c | 8 +-
sys/net80211/ieee80211_ht.c | 6 +-
sys/net80211/ieee80211_hwmp.c | 7 +-
sys/net80211/ieee80211_input.c | 10 +-
sys/net80211/ieee80211_ioctl.c | 13 ++-
sys/net80211/ieee80211_mesh.c | 20 +++-
sys/net80211/ieee80211_netbsd.c | 37 +++---
sys/net80211/ieee80211_netbsd.h | 5 +-
sys/net80211/ieee80211_node.c | 19 +++-
sys/net80211/ieee80211_output.c | 8 +-
sys/net80211/ieee80211_proto.c | 45 +++++++-
sys/net80211/ieee80211_proto.h | 15 ++-
sys/net80211/ieee80211_ratectl.c | 32 +++++-
sys/net80211/ieee80211_ratectl.h | 5 +-
sys/net80211/ieee80211_ratectl_none.c | 11 +-
sys/net80211/ieee80211_rssadapt.c | 10 +-
sys/net80211/ieee80211_scan.c | 11 +-
sys/net80211/ieee80211_scan_sta.c | 11 +-
sys/net80211/ieee80211_var.h | 9 +-
sys/net80211/ieee80211_xauth.c | 10 +-
27 files changed, 427 insertions(+), 141 deletions(-)
diffs (truncated from 1546 to 300 lines):
diff -r 4f765ee92b59 -r 381d98f3628d sys/dev/usb/if_urtwn.c
--- a/sys/dev/usb/if_urtwn.c Thu Jul 12 16:35:33 2018 +0000
+++ b/sys/dev/usb/if_urtwn.c Mon Jul 16 20:11:11 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_urtwn.c,v 1.59.2.1 2018/07/12 16:35:33 phil Exp $ */
+/* $NetBSD: if_urtwn.c,v 1.59.2.2 2018/07/16 20:11:11 phil Exp $ */
/* $OpenBSD: if_urtwn.c,v 1.42 2015/02/10 23:25:46 mpi Exp $ */
/*-
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.1 2018/07/12 16:35:33 phil Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.2 2018/07/16 20:11:11 phil Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -37,6 +37,7 @@
#include <sys/sysctl.h>
#include <sys/mbuf.h>
#include <sys/kernel.h>
+#include <sys/kmem.h>
#include <sys/socket.h>
#include <sys/systm.h>
#include <sys/module.h>
@@ -92,7 +93,8 @@
#define DBG_RF __BIT(5)
#define DBG_REG __BIT(6)
#define DBG_ALL 0xffffffffU
-u_int urtwn_debug = 0;
+/* NNN Reset urtwn_debug to 0 when done debugging. */
+u_int urtwn_debug = DBG_INIT|DBG_FN|DBG_STM;
#define DPRINTFN(n, s) \
do { if (urtwn_debug & (n)) printf s; } while (/*CONSTCOND*/0)
#else
@@ -258,7 +260,7 @@
static void urtwn_calib_to(void *);
static void urtwn_calib_to_cb(struct urtwn_softc *, void *);
static void urtwn_next_scan(void *);
-static int urtwn_newstate(struct urtwn_softc *, enum ieee80211_state,
+static int urtwn_newstate(struct ieee80211vap *, enum ieee80211_state,
int);
static void urtwn_newstate_cb(struct urtwn_softc *, void *);
static int urtwn_wme_update(struct ieee80211com *);
@@ -275,7 +277,6 @@
urtwn_get_tx_data(struct urtwn_softc *, size_t);
static void urtwn_start(struct ifnet *);
static void urtwn_watchdog(struct ifnet *);
-static int urtwn_ioctl(struct ifnet *, u_long, void *);
static int urtwn_r92c_power_on(struct urtwn_softc *);
static int urtwn_r92e_power_on(struct urtwn_softc *);
static int urtwn_r88e_power_on(struct urtwn_softc *);
@@ -306,10 +307,17 @@
static void urtwn_temp_calib(struct urtwn_softc *);
static int urtwn_init(struct ifnet *);
static void urtwn_stop(struct ifnet *, int);
-static int urtwn_reset(struct ifnet *);
+static int urtwn_reset(struct ieee80211vap *, u_long);
static void urtwn_chip_stop(struct urtwn_softc *);
static void urtwn_newassoc(struct ieee80211_node *, int);
static void urtwn_delay_ms(struct urtwn_softc *, int ms);
+static struct ieee80211vap *
+ urtwn_vap_create(struct ieee80211com *,
+ const char [IFNAMSIZ], int, enum ieee80211_opmode, int,
+ const uint8_t [IEEE80211_ADDR_LEN],
+ const uint8_t [IEEE80211_ADDR_LEN]);
+static void urtwn_vap_delete(struct ieee80211vap *);
+static int urtwn_ioctl(struct ifnet *, u_long, void *);
/* Aliases. */
#define urtwn_bb_write urtwn_write_4
@@ -339,7 +347,6 @@
{
struct urtwn_softc *sc = device_private(self);
struct ieee80211com *ic = &sc->sc_ic;
- struct ifnet *ifp = &sc->sc_if;
struct usb_attach_arg *uaa = aux;
char *devinfop;
const struct urtwn_dev *dev;
@@ -447,8 +454,7 @@
/*
* Setup the 802.11 device.
*/
- /* ic->ic_ifp = ifp; NNN need to do this later... */
- /* ic->ic_state = IEEE80211_S_INIT; NNN do this to the vap */
+ ic->ic_softc = sc;
ic->ic_phytype = IEEE80211_T_OFDM; /* Not only, but not used. */
ic->ic_opmode = IEEE80211_M_STA; /* Default to BSS mode. */
@@ -462,8 +468,11 @@
IEEE80211_C_WME | /* 802.11e */
IEEE80211_C_WPA; /* 802.11i */
+ ic->ic_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
+
/* Set supported .11b and .11g channels (1 through 14). */
- for (i = 1; i <= 14; i++) {
+ ic->ic_nchans = 14; /* NNN ? get this from somewhere? */
+ for (i = 0; i < 14; i++) {
ic->ic_channels[i].ic_freq =
ieee80211_ieee2mhz(i, IEEE80211_CHAN_2GHZ);
ic->ic_channels[i].ic_flags =
@@ -471,33 +480,34 @@
IEEE80211_CHAN_DYN | IEEE80211_CHAN_2GHZ;
}
- ifp->if_softc = sc;
- ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
- ifp->if_init = urtwn_init;
- ifp->if_ioctl = urtwn_ioctl;
- ifp->if_start = urtwn_start;
- ifp->if_watchdog = urtwn_watchdog;
- IFQ_SET_READY(&ifp->if_snd);
- memcpy(ifp->if_xname, device_xname(sc->sc_dev), IFNAMSIZ);
-
- if_attach(ifp);
+ printf ("eurtwn: Calling ieee80211_ifattach()\n");
+
ieee80211_ifattach(ic);
+ printf ("urtwn: Returned from ieee80211_ifattach().\n");
+
/* override default methods NNN Need a lot more here!!! */
ic->ic_newassoc = urtwn_newassoc;
ic->ic_wme.wme_update = urtwn_wme_update;
-
-#if 0
- /* XXX .... vap routines ... in vap_create? */
- vap->iv_reset = urtwn_reset;
-
- /* Override state transition machine. */
- sc->sc_newstate = ic->ic_newstate;
- ic->ic_newstate = urtwn_newstate;
- ieee80211_media_init(ic, urtwn_media_change, ieee80211_media_status);
-#endif
-
- bpf_attach2(ifp, DLT_IEEE802_11_RADIO,
+ ic->ic_vap_create = urtwn_vap_create;
+ ic->ic_vap_delete = urtwn_vap_delete;
+
+ /* Shouldn't do it, but call vap_create??? */
+ uint8_t bssid[IEEE80211_ADDR_LEN] = {0};
+
+ struct ieee80211vap *vap =
+ urtwn_vap_create(ic, device_xname(sc->sc_dev),
+ device_unit(sc->sc_dev), IEEE80211_M_IBSS,
+ IEEE80211_CLONE_MACADDR, bssid, ic->ic_macaddr);
+
+ if (vap == NULL) {
+ /* Didn't work ... now what! */
+ printf ("vap_create didn't work ...\n");
+ ieee80211_ifdetach(ic);
+ goto fail;
+ }
+
+ bpf_attach2(vap->iv_ifp, DLT_IEEE802_11_RADIO,
sizeof(struct ieee80211_frame) + IEEE80211_RADIOTAP_HDRLEN,
&sc->sc_drvbpf);
@@ -517,6 +527,7 @@
aprint_error_dev(self, "couldn't establish power handler\n");
SET(sc->sc_flags, URTWN_FLAG_ATTACHED);
+printf ("urtwn: Finished attach.\n");
return;
fail:
@@ -528,7 +539,6 @@
urtwn_detach(device_t self, int flags)
{
struct urtwn_softc *sc = device_private(self);
- struct ifnet *ifp = &sc->sc_if;
int s;
DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
@@ -544,12 +554,8 @@
if (ISSET(sc->sc_flags, URTWN_FLAG_ATTACHED)) {
usb_rem_task(sc->sc_udev, &sc->sc_task);
- urtwn_stop(ifp, 0);
-
- ifp->if_flags &= ~(IFF_RUNNING | IFF_OACTIVE);
- bpf_detach(ifp);
+
ieee80211_ifdetach(&sc->sc_ic);
- if_detach(ifp);
/* Close Tx/Rx pipes. Abort done by urtwn_stop. */
urtwn_close_pipes(sc);
@@ -574,18 +580,14 @@
static int
urtwn_activate(device_t self, enum devact act)
{
-#if notyet
struct urtwn_softc *sc = device_private(self);
-#endif
DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
switch (act) {
case DVACT_DEACTIVATE:
-#if notyet
- FOR_EACH(vap in sc->sc_vaps) ???
- if_deactivate(vap->iv_ifp);
-#endif
+ if_deactivate(TAILQ_FIRST(&(sc->sc_ic.ic_vaps))->iv_ifp);
+
return 0;
default:
return EOPNOTSUPP;
@@ -1832,8 +1834,9 @@
}
static __unused int
-urtwn_newstate(struct urtwn_softc *sc, enum ieee80211_state nstate, int arg)
+urtwn_newstate(struct ieee80211vap *vap, enum ieee80211_state nstate, int arg)
{
+ struct urtwn_softc *sc = vap->iv_ic->ic_softc;
struct urtwn_cmd_newstate cmd;
DPRINTFN(DBG_FN, ("%s: %s: nstate=%s(%d), arg=%d\n",
@@ -2151,7 +2154,7 @@
break;
}
- (*sc->sc_newstate)(ic, nstate, cmd->arg);
+ (*sc->sc_newstate)(vap, nstate, cmd->arg);
mutex_exit(&sc->sc_write_mtx);
splx(s);
@@ -2561,7 +2564,7 @@
{
struct urtwn_tx_data *data = priv;
struct urtwn_softc *sc = data->sc;
- struct ifnet *ifp = &sc->sc_if;
+ struct ifnet *ifp = TAILQ_FIRST(&sc->sc_ic.ic_vaps)->iv_ifp;
size_t pidx = data->pidx;
int s;
@@ -2955,10 +2958,85 @@
//NNN ieee80211_watchdog(&sc->sc_ic); Not sure what is happening!
}
+/*
+ * Create a VAP node for use with the urtwn driver.
+ */
+
+static struct ieee80211vap *
+urtwn_vap_create(struct ieee80211com *ic, const char name[IFNAMSIZ],
+ int unit, enum ieee80211_opmode opmode, int flags,
+ const uint8_t bssid[IEEE80211_ADDR_LEN],
+ const uint8_t macaddr[IEEE80211_ADDR_LEN])
+{
+ printf ("in urtwn_vap_create ... \n");
+
+ struct urtwn_softc *sc = ic->ic_softc;
+ struct ifnet *ifp;
+ struct ieee80211vap *vap;
+
+ DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
+
+ /* Allow only one VAP for the urtwn driver. */
+ if (!TAILQ_EMPTY(&ic->ic_vaps))
+ return NULL;
+
+ /* Allocate the vap and setup. */
+ vap = kmem_zalloc(sizeof(struct ieee80211vap), KM_SLEEP);
+ if (ieee80211_vap_setup(ic, vap, name, unit, opmode,
+ flags | IEEE80211_CLONE_NOBEACONS, bssid) != 0) {
+ kmem_free(vap, sizeof(struct ieee80211vap));
+ return NULL;
+ }
+
+ printf ("vap_create: after vap_setup\n");
+
+ /* Local setup */
+ vap->iv_reset = urtwn_reset;
+
+ ifp = vap->iv_ifp;
+ ifp->if_init = urtwn_init;
+ ifp->if_ioctl = urtwn_ioctl;
+ ifp->if_start = urtwn_start;
+ ifp->if_watchdog = urtwn_watchdog;
+ IFQ_SET_READY(&ifp->if_snd);
+ memcpy(ifp->if_xname, device_xname(sc->sc_dev), IFNAMSIZ);
+
+ /* NNN needed ??? */
+ /* if_attach(ifp); */
+
+ /* Override state transition machine. */
+ sc->sc_newstate = vap->iv_newstate;
+ vap->iv_newstate = urtwn_newstate;
+
+ /* Finish setup */
+ ieee80211_vap_attach(vap, urtwn_media_change,
+ ieee80211_media_status, macaddr);
+ ic->ic_opmode = opmode;
+
+ return vap;
Home |
Main Index |
Thread Index |
Old Index