summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/usb/if_urtw.c70
-rw-r--r--sys/dev/usb/if_urtwreg.h34
2 files changed, 60 insertions, 44 deletions
diff --git a/sys/dev/usb/if_urtw.c b/sys/dev/usb/if_urtw.c
index a5dfd31892d..10f087312d4 100644
--- a/sys/dev/usb/if_urtw.c
+++ b/sys/dev/usb/if_urtw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_urtw.c,v 1.18 2009/06/04 21:52:10 martynas Exp $ */
+/* $OpenBSD: if_urtw.c,v 1.19 2009/06/04 23:42:02 martynas Exp $ */
/*-
* Copyright (c) 2008 Weongyo Jeong <weongyo@FreeBSD.org>
@@ -433,12 +433,12 @@ usbd_status urtw_8225_write_c(struct urtw_softc *, uint8_t, uint16_t);
usbd_status urtw_8225_write_s16(struct urtw_softc *, uint8_t, int,
uint16_t *);
usbd_status urtw_8225_read(struct urtw_softc *, uint8_t, uint32_t *);
-usbd_status urtw_8225_rf_init(struct urtw_softc *);
-usbd_status urtw_8225_rf_set_chan(struct urtw_softc *, int);
-usbd_status urtw_8225_rf_set_sens(struct urtw_softc *, int);
+usbd_status urtw_8225_rf_init(struct urtw_rf *);
+usbd_status urtw_8225_rf_set_chan(struct urtw_rf *, int);
+usbd_status urtw_8225_rf_set_sens(struct urtw_rf *);
usbd_status urtw_8225_set_txpwrlvl(struct urtw_softc *, int);
-usbd_status urtw_8225v2_rf_init(struct urtw_softc *);
-usbd_status urtw_8225v2_rf_set_chan(struct urtw_softc *, int);
+usbd_status urtw_8225v2_rf_init(struct urtw_rf *);
+usbd_status urtw_8225v2_rf_set_chan(struct urtw_rf *, int);
usbd_status urtw_8225v2_set_txpwrlvl(struct urtw_softc *, int);
usbd_status urtw_8225v2_setgain(struct urtw_softc *, int16_t);
usbd_status urtw_8225_isv2(struct urtw_softc *, int *);
@@ -1133,10 +1133,13 @@ fail:
usbd_status
urtw_get_rfchip(struct urtw_softc *sc)
{
+ struct urtw_rf *rf = &sc->sc_rf;
int ret;
uint32_t data;
usbd_status error;
+ rf->rf_sc = sc;
+
error = urtw_eprom_read32(sc, URTW_EPROM_RFCHIPID, &data);
if (error != 0)
goto fail;
@@ -1146,15 +1149,16 @@ urtw_get_rfchip(struct urtw_softc *sc)
if (error != 0)
goto fail;
if (ret == 0) {
- sc->sc_rf_init = urtw_8225_rf_init;
- sc->sc_rf_set_sens = urtw_8225_rf_set_sens;
- sc->sc_rf_set_chan = urtw_8225_rf_set_chan;
+ rf->init = urtw_8225_rf_init;
+ rf->set_sens = urtw_8225_rf_set_sens;
+ rf->set_chan = urtw_8225_rf_set_chan;
} else {
- sc->sc_rf_init = urtw_8225v2_rf_init;
- sc->sc_rf_set_chan = urtw_8225v2_rf_set_chan;
+ rf->init = urtw_8225v2_rf_init;
+ rf->set_chan = urtw_8225v2_rf_set_chan;
+ rf->set_sens = NULL;
}
- sc->sc_max_sens = URTW_8225_RF_MAX_SENS;
- sc->sc_sens = URTW_8225_RF_DEF_SENS;
+ rf->max_sens = URTW_8225_RF_MAX_SENS;
+ rf->sens = URTW_8225_RF_DEF_SENS;
break;
default:
panic("unsupported RF chip %d\n", data & 0xff);
@@ -2065,6 +2069,7 @@ int
urtw_init(struct ifnet *ifp)
{
struct urtw_softc *sc = ifp->if_softc;
+ struct urtw_rf *rf = &sc->sc_rf;
struct ieee80211com *ic = &sc->sc_ic;
usbd_status error;
int ret;
@@ -2107,11 +2112,11 @@ urtw_init(struct ifnet *ifp)
if (error != 0)
goto fail;
- error = sc->sc_rf_init(sc);
+ error = rf->init(rf);
if (error != 0)
goto fail;
- if (sc->sc_rf_set_sens != NULL)
- sc->sc_rf_set_sens(sc, sc->sc_sens);
+ if (rf->set_sens != NULL)
+ rf->set_sens(rf);
urtw_write16_m(sc, 0x5e, 1);
urtw_write16_m(sc, 0xfe, 0x10);
@@ -2701,8 +2706,9 @@ fail:
}
usbd_status
-urtw_8225_rf_init(struct urtw_softc *sc)
+urtw_8225_rf_init(struct urtw_rf *rf)
{
+ struct urtw_softc *sc = rf->rf_sc;
int i;
uint16_t data;
usbd_status error;
@@ -2791,14 +2797,15 @@ urtw_8225_rf_init(struct urtw_softc *sc)
goto fail;
urtw_write32_m(sc, 0x94, 0x3dc00002);
- error = urtw_8225_rf_set_chan(sc, 1);
+ error = urtw_8225_rf_set_chan(rf, 1);
fail:
return (error);
}
usbd_status
-urtw_8225_rf_set_chan(struct urtw_softc *sc, int chan)
+urtw_8225_rf_set_chan(struct urtw_rf *rf, int chan)
{
+ struct urtw_softc *sc = rf->rf_sc;
struct ieee80211com *ic = &sc->sc_ic;
struct ieee80211_channel *c = ic->ic_ibss_chan;
usbd_status error;
@@ -2832,24 +2839,25 @@ fail:
}
usbd_status
-urtw_8225_rf_set_sens(struct urtw_softc *sc, int sens)
+urtw_8225_rf_set_sens(struct urtw_rf *rf)
{
+ struct urtw_softc *sc = rf->rf_sc;
usbd_status error;
- if (sens < 0 || sens > 6)
+ if (rf->sens < 0 || rf->sens > 6)
return (-1);
- if (sens > 4)
+ if (rf->sens > 4)
urtw_8225_write(sc, 0x0c, 0x850);
else
urtw_8225_write(sc, 0x0c, 0x50);
- sens = 6 - sens;
- error = urtw_8225_setgain(sc, sens);
+ rf->sens = 6 - rf->sens;
+ error = urtw_8225_setgain(sc, rf->sens);
if (error)
goto fail;
- urtw_8187_write_phy_cck(sc, 0x41, urtw_8225_threshold[sens]);
+ urtw_8187_write_phy_cck(sc, 0x41, urtw_8225_threshold[rf->sens]);
fail:
return (error);
@@ -2876,7 +2884,6 @@ urtw_stop(struct ifnet *ifp, int disable)
int
urtw_isbmode(uint16_t rate)
{
-
rate = urtw_rtl2rate(rate);
return (((rate <= 22 && rate != 12 && rate != 18) ||
@@ -3072,8 +3079,9 @@ fail:
}
usbd_status
-urtw_8225v2_rf_init(struct urtw_softc *sc)
+urtw_8225v2_rf_init(struct urtw_rf *rf)
{
+ struct urtw_softc *sc = rf->rf_sc;
int i;
uint16_t data;
uint32_t data32;
@@ -3183,14 +3191,15 @@ urtw_8225v2_rf_init(struct urtw_softc *sc)
goto fail;
urtw_write32_m(sc, 0x94, 0x3dc00002);
- error = urtw_8225_rf_set_chan(sc, 1);
+ error = urtw_8225_rf_set_chan(rf, 1);
fail:
return (error);
}
usbd_status
-urtw_8225v2_rf_set_chan(struct urtw_softc *sc, int chan)
+urtw_8225v2_rf_set_chan(struct urtw_rf *rf, int chan)
{
+ struct urtw_softc *sc = rf->rf_sc;
struct ieee80211com *ic = &sc->sc_ic;
struct ieee80211_channel *c = ic->ic_ibss_chan;
usbd_status error;
@@ -3227,6 +3236,7 @@ fail:
void
urtw_set_chan(struct urtw_softc *sc, struct ieee80211_channel *c)
{
+ struct urtw_rf *rf = &sc->sc_rf;
struct ieee80211com *ic = &sc->sc_ic;
usbd_status error = 0;
uint32_t data;
@@ -3242,7 +3252,7 @@ urtw_set_chan(struct urtw_softc *sc, struct ieee80211_channel *c)
urtw_read32_m(sc, URTW_TX_CONF, &data);
data &= ~URTW_TX_LOOPBACK_MASK;
urtw_write32_m(sc, URTW_TX_CONF, data | URTW_TX_LOOPBACK_MAC);
- error = sc->sc_rf_set_chan(sc, chan);
+ error = rf->set_chan(rf, chan);
if (error != 0) {
printf("%s could not change the channel\n",
sc->sc_dev.dv_xname);
diff --git a/sys/dev/usb/if_urtwreg.h b/sys/dev/usb/if_urtwreg.h
index b613c10f406..3e06d205eff 100644
--- a/sys/dev/usb/if_urtwreg.h
+++ b/sys/dev/usb/if_urtwreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_urtwreg.h,v 1.9 2009/06/04 21:52:10 martynas Exp $ */
+/* $OpenBSD: if_urtwreg.h,v 1.10 2009/06/04 23:42:02 martynas Exp $ */
/*-
* Copyright (c) 2008 Weongyo Jeong <weongyo@FreeBSD.org>
@@ -119,7 +119,7 @@
#define URTW_EPROM_WRITEBIT (0x2)
#define URTW_EPROM_CK (0x4)
#define URTW_EPROM_CS (0x8)
-#define URTW_CONFIG2 0x0053
+#define URTW_CONFIG2 0x0053 /* 1 byte */
#define URTW_ANAPARAM 0x0054 /* 4 byte */
#define URTW_8187_8225_ANAPARAM_ON (0xa0000a59)
#define URTW_MSR 0x0058 /* 1 byte */
@@ -272,36 +272,42 @@ struct urtw_tx_radiotap_header {
((1 << IEEE80211_RADIOTAP_FLAGS) | \
(1 << IEEE80211_RADIOTAP_CHANNEL))
+struct urtw_rf {
+ /* RF methods */
+ usbd_status (*init)(struct urtw_rf *);
+ usbd_status (*set_chan)(struct urtw_rf *, int);
+ usbd_status (*set_sens)(struct urtw_rf *);
+
+ /* RF attributes */
+ struct urtw_softc *rf_sc;
+ uint32_t max_sens;
+ uint32_t sens;
+};
+
struct urtw_softc {
struct device sc_dev;
struct ieee80211com sc_ic;
int (*sc_newstate)(struct ieee80211com *,
enum ieee80211_state, int);
+ struct urtw_rf sc_rf;
+
+ struct usb_task sc_task;
usbd_device_handle sc_udev;
usbd_interface_handle sc_iface;
+ enum ieee80211_state sc_state;
+ int sc_arg;
int sc_if_flags;
+
uint8_t sc_hwrev;
int sc_flags;
#define URTW_INIT_ONCE (1 << 1)
- struct usb_task sc_task;
-#define URTW_SET_CHANNEL 1
- enum ieee80211_state sc_state;
- int sc_arg;
int sc_epromtype;
#define URTW_EEPROM_93C46 0
#define URTW_EEPROM_93C56 1
uint8_t sc_crcmon;
uint8_t sc_bssid[IEEE80211_ADDR_LEN];
- /* for RF */
- usbd_status (*sc_rf_init)(struct urtw_softc *);
- usbd_status (*sc_rf_set_chan)(struct urtw_softc *,
- int);
- usbd_status (*sc_rf_set_sens)(struct urtw_softc *,
- int);
- uint32_t sc_max_sens;
- uint32_t sc_sens;
/* for LED */
struct timeout sc_led_ch;
struct usb_task sc_ledtask;