Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src-draft/trunk]: src/sys/dev/pci ipw(4) fucnctions for vap creation/deletio...
details: https://anonhg.NetBSD.org/src-all/rev/0a554e6ed125
branches: trunk
changeset: 375217:0a554e6ed125
user: Nathanial Sloss <nat%netbsd.org@localhost>
date: Sun Mar 06 03:14:09 2022 +1100
description:
ipw(4) fucnctions for vap creation/deletion and ipw_parent added.
diffstat:
sys/dev/pci/if_ipw.c | 89 ++++++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 83 insertions(+), 6 deletions(-)
diffs (136 lines):
diff -r 67c31699153e -r 0a554e6ed125 sys/dev/pci/if_ipw.c
--- a/sys/dev/pci/if_ipw.c Tue Mar 01 23:07:22 2022 +1100
+++ b/sys/dev/pci/if_ipw.c Sun Mar 06 03:14:09 2022 +1100
@@ -100,7 +100,7 @@ static int ipw_detach(device_t, int);
static void ipw_parent(struct ieee80211com *);
static int ipw_media_change(struct ifnet *);
static void ipw_media_status(struct ifnet *, struct ifmediareq *);
-static int ipw_newstate(struct ieee80211com *, enum ieee80211_state, int);
+static int ipw_newstate(struct ieee80211vap *, enum ieee80211_state, int);
static uint16_t ipw_read_prom_word(struct ipw_softc *, uint8_t);
static void ipw_command_intr(struct ipw_softc *, struct ipw_soft_buf *);
static void ipw_newstate_intr(struct ipw_softc *, struct ipw_soft_buf *);
@@ -135,6 +135,17 @@ static void ipw_read_mem_1(struct ipw_so
static void ipw_write_mem_1(struct ipw_softc *, bus_size_t, uint8_t *,
bus_size_t);
+static struct ieee80211vap *
+ipw_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]);
+static void
+ipw_vap_delete(struct ieee80211vap *vap);
+static void
+ipw_get_radiocaps(struct ieee80211com *ic,
+ int maxchans, int *nchans, struct ieee80211_channel chans[]);
+
static inline uint8_t
MEM_READ_1(struct ipw_softc *sc, uint32_t addr)
{
@@ -152,6 +163,15 @@ MEM_READ_4(struct ipw_softc *sc, uint32_
CFATTACH_DECL_NEW(ipw, sizeof (struct ipw_softc), ipw_match, ipw_attach,
ipw_detach, NULL);
+/*
+ * We ovveride the VAP's newstate method, so need to save the old
+ * function pointer for each VAP.
+ */
+struct ipw_vap {
+ struct ieee80211vap vap;
+ int (*newstate)(struct ieee80211vap *, enum ieee80211_state, int);
+};
+
static int
ipw_match(device_t parent, cfdata_t match, void *aux)
{
@@ -370,6 +390,62 @@ ipw_detach(device_t self, int flags)
return 0;
}
+static struct ieee80211vap *
+ipw_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])
+{
+ struct ipw_vap *vap;
+
+ /* Allocate the vap and setup. */
+ vap = kmem_zalloc(sizeof(*vap), KM_SLEEP);
+ if (ieee80211_vap_setup(ic, &vap->vap, name, unit, opmode,
+ flags | IEEE80211_CLONE_NOBEACONS, bssid) != 0) {
+ kmem_free(vap, sizeof(*vap));
+ return NULL;
+ }
+
+ /* Local overrides... */
+ vap->newstate = vap->vap.iv_newstate;
+ vap->vap.iv_newstate = ipw_newstate;
+
+ /* Use common softint-based if_input */
+ vap->vap.iv_ifp->if_percpuq = if_percpuq_create(vap->vap.iv_ifp);
+
+ /* Finish setup */
+ ieee80211_vap_attach(&vap->vap, ieee80211_media_change,
+ ieee80211_media_status, macaddr);
+
+ ic->ic_opmode = opmode;
+
+ return &vap->vap;
+}
+
+static void
+rtwn_vap_delete(struct ieee80211vap *arg)
+{
+ struct ifnet *ifp = arg->iv_ifp;
+ struct ipw_vap *vap = (struct ipw_vap *)arg;
+
+ bpf_detach(ifp);
+ ieee80211_vap_detach(arg);
+ kmem_free(vap, sizeof(*vap));
+}
+
+static void
+rtwn_get_radiocaps(struct ieee80211com *ic,
+ int maxchans, int *nchans, struct ieee80211_channel chans[])
+{
+ uint8_t bands[IEEE80211_MODE_BYTES];
+
+ memset(bands, 0, sizeof(bands));
+ setbit(bands, IEEE80211_MODE_11B);
+ setbit(bands, IEEE80211_MODE_11G);
+// setbit(bands, IEEE80211_MODE_11NG);
+ ieee80211_add_channels_default_2ghz(chans, maxchans, nchans, bands, 0);
+}
+
static int
ipw_dma_alloc(struct ipw_softc *sc)
{
@@ -788,11 +864,13 @@ ipw_media_status(struct ifnet *ifp, stru
}
static int
-ipw_newstate(struct ieee80211com *ic, enum ieee80211_state nstate,
+ipw_newstate(struct ieee80211vap *vap, enum ieee80211_state nstate,
int arg)
{
- struct ifnet *ifp = ic->ic_ifp;
- struct ipw_softc *sc = ifp->if_softc;
+ struct ipw_vap *myvap = (struct ipw_vap *)vap;
+ struct ieee80211_com *ic = vap->iv_ic
+ struct ifnet *ifp = vap->iv_ifp;
+ struct ipw_softc *sc = ic->ic_softc;
struct ieee80211_node *ni;
uint8_t macaddr[IEEE80211_ADDR_LEN];
uint32_t len;
@@ -838,8 +916,7 @@ ipw_newstate(struct ieee80211com *ic, en
break;
}
- ic->ic_state = nstate;
- return 0;
+ return (*my_vap->newstate)(vap, nstate, arg);
}
static void
Home |
Main Index |
Thread Index |
Old Index