Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/phil-wifi]: src/sys/net80211 State save:



details:   https://anonhg.NetBSD.org/src/rev/b343031fdc9d
branches:  phil-wifi
changeset: 1025112:b343031fdc9d
user:      phil <phil%NetBSD.org@localhost>
date:      Fri Jul 20 20:33:05 2018 +0000

description:
State save:
  urtwn: ifp->if_softc points to a vap, not the urtwn softc, fix code for this.
         add missing routines, need to get them filled out correctly.
  80211: Add back some NetBSD ioctls, start working on the sysctl tree.

diffstat:

 sys/dev/usb/if_urtwn.c            |  134 ++++++++++++++++++++++++++++++-------
 sys/net80211/ieee80211.c          |   33 ++++-----
 sys/net80211/ieee80211_amrr.c     |   10 +-
 sys/net80211/ieee80211_ioctl.c    |   75 +++++++++++++++++++-
 sys/net80211/ieee80211_ioctl.h    |    4 +-
 sys/net80211/ieee80211_netbsd.c   |  129 ++++++++++++++++++++++++++++++++++--
 sys/net80211/ieee80211_netbsd.h   |    9 ++-
 sys/net80211/ieee80211_proto.c    |   12 ++-
 sys/net80211/ieee80211_rssadapt.c |   10 +-
 sys/net80211/ieee80211_scan_sw.c  |    9 ++-
 sys/net80211/ieee80211_var.h      |    6 +-
 11 files changed, 359 insertions(+), 72 deletions(-)

diffs (truncated from 955 to 300 lines):

diff -r da4a5adcd72d -r b343031fdc9d sys/dev/usb/if_urtwn.c
--- a/sys/dev/usb/if_urtwn.c    Mon Jul 16 20:11:11 2018 +0000
+++ b/sys/dev/usb/if_urtwn.c    Fri Jul 20 20:33:05 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_urtwn.c,v 1.59.2.2 2018/07/16 20:11:11 phil Exp $   */
+/*     $NetBSD: if_urtwn.c,v 1.59.2.3 2018/07/20 20:33:05 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.2 2018/07/16 20:11:11 phil Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.3 2018/07/20 20:33:05 phil Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -311,6 +311,7 @@
 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);
+/* Functions for wifi refresh */
 static struct ieee80211vap *
                urtwn_vap_create(struct ieee80211com *,
                    const char [IFNAMSIZ], int, enum ieee80211_opmode, int,
@@ -318,6 +319,14 @@
                    const uint8_t [IEEE80211_ADDR_LEN]);
 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_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_raw_xmit(struct ieee80211_node *, struct mbuf *,
+                   const struct ieee80211_bpf_params *);
+
 
 /* Aliases. */
 #define        urtwn_bb_write  urtwn_write_4
@@ -357,6 +366,9 @@
        sc->sc_dev = self;
        sc->sc_udev = uaa->uaa_device;
 
+       /* Name the ic. */
+       ic->ic_name = "urtwn";
+
        sc->chip = 0;
        dev = urtwn_lookup(urtwn_devs, uaa->uaa_vendor, uaa->uaa_product);
        if (dev != NULL && ISSET(dev->flags, FLAG_RTL8188E))
@@ -491,6 +503,13 @@
        ic->ic_wme.wme_update = urtwn_wme_update;
        ic->ic_vap_create = urtwn_vap_create;
        ic->ic_vap_delete = urtwn_vap_delete;
+       ic->ic_parent = urtwn_parent;
+       ic->ic_scan_start = urtwn_scan_start;
+       ic->ic_scan_end = urtwn_scan_end;
+       ic->ic_set_channel = urtwn_set_channel;
+       ic->ic_transmit = urtwn_transmit;
+       ic->ic_raw_xmit = urtwn_raw_xmit;
+       
 
        /* Shouldn't do it, but call vap_create??? */
        uint8_t bssid[IEEE80211_ADDR_LEN] = {0};
@@ -507,6 +526,9 @@
                goto fail;
        }
 
+       /* Debug all! NNN */
+       vap->iv_debug = IEEE80211_MSG_ANY;
+
        bpf_attach2(vap->iv_ifp, DLT_IEEE802_11_RADIO,
            sizeof(struct ieee80211_frame) + IEEE80211_RADIOTAP_HDRLEN,
            &sc->sc_drvbpf);
@@ -1489,7 +1511,8 @@
 urtwn_media_change(struct ifnet *ifp)
 {
 #ifdef URTWN_DEBUG
-       struct urtwn_softc *sc = ifp->if_softc;
+       struct ieee80211vap *vap = ifp->if_softc;
+       struct urtwn_softc *sc = vap->iv_ic->ic_softc;
 #endif
        int error;
 
@@ -1808,6 +1831,7 @@
 static void
 urtwn_next_scan(void *arg)
 {
+       printf ("urtwn_next_scan called....\n");
 #ifdef notyet
        struct urtwn_softc *sc = arg;
        int s;
@@ -1942,6 +1966,7 @@
        case IEEE80211_S_CAC:
        case IEEE80211_S_CSA:
        case IEEE80211_S_SLEEP:
+               printf ("URTWN UNKNOWN oSTATE: %d\n", ostate);
                /* NNN what do we do in these states? XXX */
                break;
        }
@@ -2151,6 +2176,7 @@
        case IEEE80211_S_CSA:
        case IEEE80211_S_SLEEP:
                /* NNN what do we do in these states? XXX */
+               printf ("URTWN UNKNOWN nSTATE: %d\n", nstate);
                break;
        }
 
@@ -2824,12 +2850,12 @@
 static void
 urtwn_start(struct ifnet *ifp)
 {
-       struct urtwn_softc *sc = ifp->if_softc;
-       struct ieee80211com *ic = &sc->sc_ic;
+       struct ieee80211vap *vap = ifp->if_softc;
+       struct ieee80211com *ic = vap->iv_ic;
+       struct urtwn_softc *sc = ic->ic_softc;
        struct urtwn_tx_data *data;
        struct ether_header *eh;
        struct ieee80211_node *ni;
-       struct ieee80211vap *vap;
        struct mbuf *m;
 
        DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
@@ -2837,15 +2863,6 @@
        if ((ifp->if_flags & (IFF_RUNNING | IFF_OACTIVE)) != IFF_RUNNING)
                return;
 
-       /* Find the associated vap. NEED A BETTER WAY! */
-       vap = TAILQ_FIRST(&ic->ic_vaps);
-       while (vap != NULL) {
-               if (vap->iv_ifp == ifp)
-                       break;
-               vap = TAILQ_NEXT(vap, iv_next);
-       }
-       KASSERT(vap != NULL);
-
        data = NULL;
        for (;;) {
                /* Send pending management frames first. */
@@ -2939,7 +2956,8 @@
 static void
 urtwn_watchdog(struct ifnet *ifp)
 {
-       struct urtwn_softc *sc = ifp->if_softc;
+       struct ieee80211vap *vap = ifp->if_softc;
+       struct urtwn_softc *sc = vap->iv_ic->ic_softc;
 
        DPRINTFN(DBG_FN, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
 
@@ -2955,7 +2973,7 @@
                }
                ifp->if_timer = 1;
        }
-//NNN  ieee80211_watchdog(&sc->sc_ic);  Not sure what is happening!
+       //  ieee80211_watchdog(&sc->sc_ic); 
 }
 
 /*
@@ -2998,12 +3016,10 @@
        ifp->if_ioctl = urtwn_ioctl;
        ifp->if_start = urtwn_start;
        ifp->if_watchdog = urtwn_watchdog;
+       ifp->if_extflags |= IFEF_MPSAFE;
        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;
@@ -3031,6 +3047,69 @@
        kmem_free(vap, sizeof(struct ieee80211vap));
 }
 
+static void
+urtwn_parent(struct ieee80211com *ic)
+{
+       struct urtwn_softc *sc __unused = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       /* Not sure what to do here yet. */
+} 
+
+static void
+urtwn_scan_start(struct ieee80211com *ic)
+{
+       struct urtwn_softc *sc __unused = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       /* Not sure what to do here yet. */
+} 
+
+static void
+urtwn_scan_end(struct ieee80211com *ic)
+{
+       struct urtwn_softc *sc __unused = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       /* Not sure what to do here yet. */
+} 
+
+static void
+urtwn_set_channel(struct ieee80211com *ic)
+{
+       struct urtwn_softc *sc = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       urtwn_set_chan(sc, ic->ic_curchan, IEEE80211_HTINFO_2NDCHAN_NONE);
+} 
+
+static int
+urtwn_transmit(struct ieee80211com *ic, struct mbuf *m)
+{
+       struct urtwn_softc *sc = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       return EIO;
+}
+
+static int
+urtwn_raw_xmit(struct ieee80211_node *ni , struct mbuf *m,
+    const struct ieee80211_bpf_params *bpfp)
+{
+       struct ieee80211com *ic = ni->ni_ic;
+       struct urtwn_softc *sc = ic->ic_softc;
+
+       DPRINTFN(DBG_FN, ("%s: %s\n",device_xname(sc->sc_dev), __func__));
+
+       return EIO;
+}
+
+
 static int
 urtwn_ioctl(struct ifnet *ifp, u_long cmd, void *data)
 {
@@ -3050,11 +3129,14 @@
                        break;
                switch (ifp->if_flags & (IFF_UP | IFF_RUNNING)) {
                case IFF_UP | IFF_RUNNING:
+                       printf (" up and running...\n");
                        break;
                case IFF_UP:
+                       printf (" just up ... will start\n");
                        urtwn_init(ifp);
                        break;
                case IFF_RUNNING:
+                       printf (" just running .. will stop\n");
                        urtwn_stop(ifp, 1);
                        break;
                case 0:
@@ -4765,9 +4847,9 @@
 static int
 urtwn_init(struct ifnet *ifp)
 {
-       struct urtwn_softc *sc = ifp->if_softc;
-       struct ieee80211com *ic = &sc->sc_ic;
-       struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
+       struct ieee80211vap *vap = ifp->if_softc;
+       struct ieee80211com *ic = vap->iv_ic;
+       struct urtwn_softc *sc = ic->ic_softc;
        struct urtwn_rx_data *data;
        uint32_t reg;
        size_t i;
@@ -5036,9 +5118,9 @@
 static void
 urtwn_stop(struct ifnet *ifp, int disable)
 {
-       struct urtwn_softc *sc = ifp->if_softc;
-       struct ieee80211com *ic = &sc->sc_ic;
-       struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
+       struct ieee80211vap *vap = ifp->if_softc;
+       struct ieee80211com *ic = vap->iv_ic;
+       struct urtwn_softc *sc = ic->ic_softc;
        size_t i;
        int s;
 
diff -r da4a5adcd72d -r b343031fdc9d sys/net80211/ieee80211.c
--- a/sys/net80211/ieee80211.c  Mon Jul 16 20:11:11 2018 +0000
+++ b/sys/net80211/ieee80211.c  Fri Jul 20 20:33:05 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ieee80211.c,v 1.56.18.3 2018/07/16 20:11:11 phil Exp $ */
+/*     $NetBSD: ieee80211.c,v 1.56.18.4 2018/07/20 20:33:05 phil Exp $ */
 
 /*-
  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
@@ -48,6 +48,7 @@
 #ifdef __FreeBSD__
 #include <machine/stdarg.h>
 #elif __NetBSD__
+#include <sys/once.h>
 #include <sys/stdarg.h>



Home | Main Index | Thread Index | Old Index