summaryrefslogtreecommitdiff
path: root/sys/dev/ic
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2005-06-13 13:37:52 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2005-06-13 13:37:52 +0000
commitfd3f4a26819cd788a8d84d230dbdbef89b9e2dd1 (patch)
treed9ceaa7af685c94c1173e4f506d0a280253d3d6b /sys/dev/ic
parent11c6024a5a3022b2e4b178ebce35f64cd7ccc455 (diff)
Move a bunch of small functions that only get called once into
their calling functions.
Diffstat (limited to 'sys/dev/ic')
-rw-r--r--sys/dev/ic/rtw.c165
1 files changed, 67 insertions, 98 deletions
diff --git a/sys/dev/ic/rtw.c b/sys/dev/ic/rtw.c
index 2d49a0120b8..5689876de73 100644
--- a/sys/dev/ic/rtw.c
+++ b/sys/dev/ic/rtw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rtw.c,v 1.32 2005/05/29 06:03:11 reyk Exp $ */
+/* $OpenBSD: rtw.c,v 1.33 2005/06/13 13:37:51 jsg Exp $ */
/* $NetBSD: rtw.c,v 1.29 2004/12/27 19:49:16 dyoung Exp $ */
/*-
@@ -89,12 +89,9 @@ int rtw_rxbufs_limit = RTW_RXQLEN;
#endif /* RTW_DEBUG */
void rtw_start(struct ifnet *);
-void rtw_srom_defaults(struct rtw_srom *, u_int32_t *, u_int8_t *,
- enum rtw_rfchipid *, u_int32_t *);
void rtw_txdesc_blk_init_all(struct rtw_txdesc_blk *);
void rtw_txsoft_blk_init_all(struct rtw_txsoft_blk *);
void rtw_txdescs_sync(struct rtw_txdesc_blk *, u_int, u_int, int);
-void rtw_txdescs_sync_all(struct rtw_txdesc_blk *);
void rtw_rxbufs_release(bus_dma_tag_t, struct rtw_rxsoft *);
void rtw_rxdesc_init(struct rtw_rxdesc_blk *, struct rtw_rxsoft *, int, int);
void rtw_io_enable(struct rtw_regs *, u_int8_t, int);
@@ -166,7 +163,6 @@ int rtw_txdesc_dmamaps_create(bus_dma_tag_t, struct rtw_txsoft *, u_int);
int rtw_rxdesc_dmamaps_create(bus_dma_tag_t, struct rtw_rxsoft *, u_int);
void rtw_rxdesc_dmamaps_destroy(bus_dma_tag_t, struct rtw_rxsoft *, u_int);
void rtw_txdesc_dmamaps_destroy(bus_dma_tag_t, struct rtw_txsoft *, u_int);
-void rtw_srom_free(struct rtw_srom *);
void rtw_init_channels(enum rtw_locale, struct ieee80211_channel (*)[],
const char*);
void rtw_identify_country(struct rtw_regs *, enum rtw_locale *, const char *);
@@ -183,9 +179,6 @@ void rtw_enable_interrupts(struct rtw_softc *);
int rtw_dequeue(struct ifnet *, struct rtw_txsoft_blk **,
struct rtw_txdesc_blk **, struct mbuf **,
struct ieee80211_node **);
-void rtw_setifprops(struct ifnet *, const char *, void *);
-void rtw_set80211props(struct ieee80211com *);
-void rtw_set80211methods(struct rtw_mtbl *, struct ieee80211com *);
void rtw_establish_hooks(struct rtw_hooks *, const char *, void *);
void rtw_disestablish_hooks(struct rtw_hooks *, const char *, void *);
int rtw_txsoft_blk_setup(struct rtw_txsoft_blk *, u_int);
@@ -553,26 +546,6 @@ rtw_txdesc_dmamaps_destroy(bus_dma_tag_t dmat, struct rtw_txsoft *descs,
}
}
-void
-rtw_srom_free(struct rtw_srom *sr)
-{
- sr->sr_size = 0;
- if (sr->sr_content == NULL)
- return;
- free(sr->sr_content, M_DEVBUF);
- sr->sr_content = NULL;
-}
-
-void
-rtw_srom_defaults(struct rtw_srom *sr, u_int32_t *flags, u_int8_t *cs_threshold,
- enum rtw_rfchipid *rfchipid, u_int32_t *rcr)
-{
- *flags |= (RTW_F_DIGPHY|RTW_F_ANTDIV);
- *cs_threshold = RTW_SR_ENERGYDETTHR_DEFAULT;
- *rcr |= RTW_RCR_ENCS1;
- *rfchipid = RTW_RFCHIPID_PHILIPS;
-}
-
int
rtw_srom_parse(struct rtw_softc *sc)
{
@@ -598,7 +571,10 @@ rtw_srom_parse(struct rtw_softc *sc)
if (version <= 0x0101) {
printf(" is not understood, limping along with defaults ");
- rtw_srom_defaults(sr, flags, cs_threshold, rfchipid, rcr);
+ *flags |= (RTW_F_DIGPHY|RTW_F_ANTDIV);
+ *cs_threshold = RTW_SR_ENERGYDETTHR_DEFAULT;
+ *rcr |= RTW_RCR_ENCS1;
+ *rfchipid = RTW_RFCHIPID_PHILIPS;
return 0;
}
@@ -998,16 +974,6 @@ rtw_txdescs_sync(struct rtw_txdesc_blk *tdb, u_int desc0, u_int nsync, int ops)
}
void
-rtw_txdescs_sync_all(struct rtw_txdesc_blk *tdb)
-{
- int pri;
- for (pri = 0; pri < RTW_NTXPRI; pri++) {
- rtw_txdescs_sync(&tdb[pri], 0, tdb[pri].tdb_ndesc,
- BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
- }
-}
-
-void
rtw_rxbufs_release(bus_dma_tag_t dmat, struct rtw_rxsoft *desc)
{
int i;
@@ -1596,8 +1562,9 @@ rtw_hwring_setup(struct rtw_softc *sc)
int
rtw_swring_setup(struct rtw_softc *sc)
{
- int rc;
+ int rc, pri;
struct rtw_rxdesc_blk *rdb;
+ struct rtw_txdesc_blk *tdb;
rtw_txdesc_blk_init_all(&sc->sc_txdesc_blk[0]);
@@ -1617,7 +1584,11 @@ rtw_swring_setup(struct rtw_softc *sc)
BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE);
rtw_rxdesc_init_all(rdb, sc->sc_rxsoft, 1);
- rtw_txdescs_sync_all(&sc->sc_txdesc_blk[0]);
+ tdb = &sc->sc_txdesc_blk[0];
+ for (pri = 0; pri < RTW_NTXPRI; pri++) {
+ rtw_txdescs_sync(&tdb[pri], 0, tdb[pri].tdb_ndesc,
+ BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
+ }
return 0;
}
@@ -2068,7 +2039,8 @@ int
rtw_tune(struct rtw_softc *sc)
{
struct ieee80211com *ic = &sc->sc_ic;
- u_int chan;
+ u_int chan, idx;
+ u_int8_t txpower;
int rc;
int antdiv = sc->sc_flags & RTW_F_ANTDIV,
dflantb = sc->sc_flags & RTW_F_DFLANTB;
@@ -2093,6 +2065,13 @@ rtw_tune(struct rtw_softc *sc)
KASSERT((sc->sc_flags & RTW_F_ENABLED) != 0);
+ idx = RTW_SR_TXPOWER1 +
+ ieee80211_chan2ieee(ic, ic->ic_bss->ni_chan) - 1;
+ KASSERT2(idx >= RTW_SR_TXPOWER1 && idx <= RTW_SR_TXPOWER14,
+ ("%s: channel %d out of range", __func__,
+ idx - RTW_SR_TXPOWER1 + 1));
+ txpower = RTW_SR_GET(&sc->sc_srom, idx);
+
if ((rc = rtw_phy_init(&sc->sc_regs, sc->sc_rf,
rtw_chan2txpower(&sc->sc_srom, ic, ic->ic_bss->ni_chan),
sc->sc_csthr, ic->ic_bss->ni_chan->ic_freq, antdiv,
@@ -2220,9 +2199,6 @@ rtw_set_nettype(struct rtw_softc *sc, enum ieee80211_opmode opmode)
rtw_set_access(&sc->sc_regs, RTW_ACCESS_NONE);
}
-#define rtw_calchash(addr) \
- (ether_crc32_be((addr), IEEE80211_ADDR_LEN) >> 26)
-
void
rtw_pktfilt_load(struct rtw_softc *sc)
{
@@ -2282,7 +2258,8 @@ allmulti:
ETHER_ADDR_LEN) != 0)
goto allmulti;
- hash = rtw_calchash(enm->enm_addrlo);
+ hash = ether_crc32_be((enm->enm_addrlo),
+ IEEE80211_ADDR_LEN) >> 26;
hashes[hash >> 5] |= (1 << (hash & 0x1f));
sc->sc_rcr |= RTW_RCR_AM;
ETHER_NEXT_MULTI(step, enm);
@@ -3378,53 +3355,6 @@ rtw_shutdown(void *arg)
}
void
-rtw_setifprops(struct ifnet *ifp, const char *dvname, void *softc)
-{
- bcopy(dvname, ifp->if_xname, IFNAMSIZ);
- ifp->if_softc = softc;
- ifp->if_flags = IFF_SIMPLEX | IFF_BROADCAST | IFF_MULTICAST |
- IFF_NOTRAILERS;
- ifp->if_ioctl = rtw_ioctl;
- ifp->if_start = rtw_start;
- ifp->if_watchdog = rtw_watchdog;
-}
-
-void
-rtw_set80211props(struct ieee80211com *ic)
-{
- int nrate;
- ic->ic_phytype = IEEE80211_T_DS;
- ic->ic_opmode = IEEE80211_M_STA;
- ic->ic_caps = IEEE80211_C_PMGT | IEEE80211_C_IBSS |
- IEEE80211_C_HOSTAP | IEEE80211_C_MONITOR | IEEE80211_C_WEP;
-
- nrate = 0;
- ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] =
- IEEE80211_RATE_BASIC | 2;
- ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] =
- IEEE80211_RATE_BASIC | 4;
- ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] = 11;
- ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] = 22;
- ic->ic_sup_rates[IEEE80211_MODE_11B].rs_nrates = nrate;
-}
-
-void
-rtw_set80211methods(struct rtw_mtbl *mtbl, struct ieee80211com *ic)
-{
- mtbl->mt_newstate = ic->ic_newstate;
- ic->ic_newstate = rtw_newstate;
-
- mtbl->mt_recv_mgmt = ic->ic_recv_mgmt;
- ic->ic_recv_mgmt = rtw_recv_mgmt;
-
- mtbl->mt_node_free = ic->ic_node_free;
- ic->ic_node_free = rtw_node_free;
-
- mtbl->mt_node_alloc = ic->ic_node_alloc;
- ic->ic_node_alloc = rtw_node_alloc;
-}
-
-void
rtw_establish_hooks(struct rtw_hooks *hooks, const char *dvname,
void *arg)
{
@@ -3614,10 +3544,13 @@ rtw_check_phydelay(struct rtw_regs *regs, u_int32_t rcr0)
void
rtw_attach(struct rtw_softc *sc)
{
+ struct ieee80211com *ic = &sc->sc_ic;
struct rtw_txsoft_blk *tsb;
+ struct rtw_mtbl *mtbl;
const char *vername;
+ struct ifnet *ifp;
char scratch[sizeof("unknown 0xXXXXXXXX")];
- int pri, rc;
+ int pri, rc, nrate;
NEXT_ATTACH_STATE(sc, DETACHED);
@@ -3782,11 +3715,30 @@ rtw_attach(struct rtw_softc *sc)
goto err;
NEXT_ATTACH_STATE(sc, FINISH_ID_STA);
- rtw_setifprops(&sc->sc_if, sc->sc_dev.dv_xname, (void*)sc);
+ ifp = &sc->sc_if;
+ (void)memcpy(ifp->if_xname, sc->sc_dev.dv_xname, IFNAMSIZ);
+ ifp->if_softc = sc;
+ ifp->if_flags = IFF_SIMPLEX | IFF_BROADCAST | IFF_MULTICAST |
+ IFF_NOTRAILERS;
+ ifp->if_ioctl = rtw_ioctl;
+ ifp->if_start = rtw_start;
+ ifp->if_watchdog = rtw_watchdog;
IFQ_SET_READY(&sc->sc_if.if_snd);
- rtw_set80211props(&sc->sc_ic);
+ ic->ic_phytype = IEEE80211_T_DS;
+ ic->ic_opmode = IEEE80211_M_STA;
+ ic->ic_caps = IEEE80211_C_PMGT | IEEE80211_C_IBSS |
+ IEEE80211_C_HOSTAP | IEEE80211_C_MONITOR | IEEE80211_C_WEP;
+
+ nrate = 0;
+ ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] =
+ IEEE80211_RATE_BASIC | 2;
+ ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] =
+ IEEE80211_RATE_BASIC | 4;
+ ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] = 11;
+ ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates[nrate++] = 22;
+ ic->ic_sup_rates[IEEE80211_MODE_11B].rs_nrates = nrate;
rtw_led_attach(&sc->sc_led_state, (void *)sc);
@@ -3796,7 +3748,18 @@ rtw_attach(struct rtw_softc *sc)
if_attach(&sc->sc_if);
ieee80211_ifattach(&sc->sc_if);
- rtw_set80211methods(&sc->sc_mtbl, &sc->sc_ic);
+ mtbl = &sc->sc_mtbl;
+ mtbl->mt_newstate = ic->ic_newstate;
+ ic->ic_newstate = rtw_newstate;
+
+ mtbl->mt_recv_mgmt = ic->ic_recv_mgmt;
+ ic->ic_recv_mgmt = rtw_recv_mgmt;
+
+ mtbl->mt_node_free = ic->ic_node_free;
+ ic->ic_node_free = rtw_node_free;
+
+ mtbl->mt_node_alloc = ic->ic_node_alloc;
+ ic->ic_node_alloc = rtw_node_alloc;
/* possibly we should fill in our own sc_send_prresp, since
* the RTL8180 is probably sending probe responses in ad hoc
@@ -3834,6 +3797,7 @@ int
rtw_detach(struct rtw_softc *sc)
{
int pri;
+ struct rtw_srom *sr;
sc->sc_flags |= RTW_F_INVALID;
@@ -3854,7 +3818,12 @@ rtw_detach(struct rtw_softc *sc)
/*FALLTHROUGH*/
case FINISH_PARSE_SROM:
case FINISH_READ_SROM:
- rtw_srom_free(&sc->sc_srom);
+ sr = &sc->sc_srom;
+ sr->sr_size = 0;
+ if (sr->sr_content != NULL) {
+ free(sr->sr_content, M_DEVBUF);
+ sr->sr_content = NULL;
+ }
/*FALLTHROUGH*/
case FINISH_RESET:
case FINISH_RXMAPS_CREATE: