diff options
-rw-r--r-- | sys/dev/ic/rtw.c | 140 | ||||
-rw-r--r-- | sys/dev/ic/rtwreg.h | 3 |
2 files changed, 134 insertions, 9 deletions
diff --git a/sys/dev/ic/rtw.c b/sys/dev/ic/rtw.c index bf3705e0cb6..8ac6208f753 100644 --- a/sys/dev/ic/rtw.c +++ b/sys/dev/ic/rtw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rtw.c,v 1.49 2005/11/05 02:31:29 jsg Exp $ */ +/* $OpenBSD: rtw.c,v 1.50 2005/11/20 09:49:05 jsg Exp $ */ /* $NetBSD: rtw.c,v 1.29 2004/12/27 19:49:16 dyoung Exp $ */ /*- @@ -227,6 +227,11 @@ int rtw_rtl8255_init(struct rtw_softc *, u_int, u_int8_t, enum rtw_pwrstate); int rtw_rtl8255_txpower(struct rtw_softc *, u_int8_t); int rtw_rtl8255_tune(struct rtw_softc *, u_int); +int rtw_grf5101_pwrstate(struct rtw_softc *, enum rtw_pwrstate); +int rtw_grf5101_init(struct rtw_softc *, u_int, u_int8_t, + enum rtw_pwrstate); +int rtw_grf5101_txpower(struct rtw_softc *, u_int8_t); +int rtw_grf5101_tune(struct rtw_softc *, u_int); int rtw_rf_hostwrite(struct rtw_softc *, u_int, u_int32_t); int rtw_rf_macwrite(struct rtw_softc *, u_int, u_int32_t); u_int8_t rtw_bbp_read(struct rtw_regs *, u_int); @@ -3507,7 +3512,24 @@ rtw_rf_attach(struct rtw_softc *sc, int rfchipid) case RTW_RFCHIPID_GCT: /* this combo seen in the wild */ rfname = "GRF5101"; paname = "WS9901"; - notsup = 1; + /* XXX magic */ + bb->bb_antatten = RTW_BBP_ANTATTEN_GCT_MAGIC; + bb->bb_chestlim = 0x00; + bb->bb_chsqlim = 0xa0; + bb->bb_ifagcdet = 0x64; + bb->bb_ifagcini = 0x90; + bb->bb_ifagclimit = 0x1e; + bb->bb_lnadet = 0xc0; + bb->bb_sys1 = 0xa8; + bb->bb_sys2 = 0x47; + bb->bb_sys3 = 0x9b; + bb->bb_trl = 0x88; + bb->bb_txagc = 0x08; + sc->sc_pwrstate_cb = rtw_maxim_pwrstate; + sc->sc_rf_init = rtw_grf5101_init; + sc->sc_rf_pwrstate = rtw_grf5101_pwrstate; + sc->sc_rf_tune = rtw_grf5101_tune; + sc->sc_rf_txpower = rtw_grf5101_txpower; break; case RTW_RFCHIPID_INTERSIL: rfname = "HFA3873"; /* guess */ @@ -4227,6 +4249,106 @@ rtw_max2820_pwrstate(struct rtw_softc *sc, enum rtw_pwrstate power) } int +rtw_grf5101_init(struct rtw_softc *sc, u_int freq, u_int8_t opaque_txpower, + enum rtw_pwrstate power) +{ + int rc; + + /* + * These values have been derived from the rtl8180-sa2400 Linux driver. + * It is unknown what they all do, GCT refuse to release any documentation + * so these are more than likely sub optimal settings + */ + + rtw_rf_macwrite(sc, 0x01, 0x1a23); + rtw_rf_macwrite(sc, 0x02, 0x4971); + rtw_rf_macwrite(sc, 0x03, 0x41de); + rtw_rf_macwrite(sc, 0x04, 0x2d80); + + rtw_rf_macwrite(sc, 0x05, 0x61ff); + + rtw_rf_macwrite(sc, 0x06, 0x0); + + rtw_rf_macwrite(sc, 0x08, 0x7533); + rtw_rf_macwrite(sc, 0x09, 0xc401); + rtw_rf_macwrite(sc, 0x0a, 0x0); + rtw_rf_macwrite(sc, 0x0c, 0x1c7); + rtw_rf_macwrite(sc, 0x0d, 0x29d3); + rtw_rf_macwrite(sc, 0x0e, 0x2e8); + rtw_rf_macwrite(sc, 0x10, 0x192); + rtw_rf_macwrite(sc, 0x11, 0x248); + rtw_rf_macwrite(sc, 0x12, 0x0); + rtw_rf_macwrite(sc, 0x13, 0x20c4); + rtw_rf_macwrite(sc, 0x14, 0xf4fc); + rtw_rf_macwrite(sc, 0x15, 0x0); + rtw_rf_macwrite(sc, 0x16, 0x1500); + + if ((rc = rtw_grf5101_txpower(sc, opaque_txpower)) != 0) + return rc; + + if ((rc = rtw_grf5101_tune(sc, freq)) != 0) + return rc; + + return (0); +} + +int +rtw_grf5101_tune(struct rtw_softc *sc, u_int freq) +{ + struct ieee80211com *ic = &sc->sc_ic; + u_int channel = ieee80211_chan2ieee(ic, ic->ic_bss->ni_chan); + + /* set channel */ + rtw_rf_macwrite(sc, 0x07, 0); + rtw_rf_macwrite(sc, 0x0b, channel - 1); + rtw_rf_macwrite(sc, 0x07, 0x1000); + + return (0); +} + +int +rtw_grf5101_txpower(struct rtw_softc *sc, u_int8_t opaque_txpower) +{ + rtw_rf_macwrite(sc, 0x15, 0); + rtw_rf_macwrite(sc, 0x06, opaque_txpower); + rtw_rf_macwrite(sc, 0x15, 0x10); + rtw_rf_macwrite(sc, 0x15, 0x00); + + return (0); +} + +int +rtw_grf5101_pwrstate(struct rtw_softc *sc, enum rtw_pwrstate power) +{ + switch (power) { + case RTW_OFF: + case RTW_SLEEP: + rtw_rf_macwrite(sc, 0x07, 0x0000); + rtw_rf_macwrite(sc, 0x1f, 0x0045); + rtw_rf_macwrite(sc, 0x1f, 0x0005); + rtw_rf_macwrite(sc, 0x00, 0x08e4); + default: + break; + case RTW_ON: + rtw_rf_macwrite(sc, 0x1f, 0x0001); + DELAY(10); + rtw_rf_macwrite(sc, 0x1f, 0x0001); + DELAY(10); + rtw_rf_macwrite(sc, 0x1f, 0x0041); + DELAY(10); + rtw_rf_macwrite(sc, 0x1f, 0x0061); + DELAY(10); + rtw_rf_macwrite(sc, 0x00, 0x0ae4); + DELAY(10); + rtw_rf_macwrite(sc, 0x07, 0x1000); + DELAY(100); + break; + } + + return 0; +} + +int rtw_rtl8225_pwrstate(struct rtw_softc *sc, enum rtw_pwrstate power) { return (0); @@ -4580,15 +4702,17 @@ rtw_rf_hostwrite(struct rtw_softc *sc, u_int addr, u_int32_t val) lo_to_hi = 1; break; case RTW_RFCHIPID_GCT: + KASSERT((addr & ~PRESHIFT(SI4126_TWI_ADDR_MASK)) == 0); + KASSERT((val & ~PRESHIFT(SI4126_TWI_DATA_MASK)) == 0); + bits = rtw_grf5101_host_crypt(addr, val); + nbits = 21; + lo_to_hi = 1; + break; case RTW_RFCHIPID_RFMD2948: KASSERT((addr & ~PRESHIFT(SI4126_TWI_ADDR_MASK)) == 0); KASSERT((val & ~PRESHIFT(SI4126_TWI_DATA_MASK)) == 0); - if (sc->sc_rfchipid == RTW_RFCHIPID_GCT) - bits = rtw_grf5101_host_crypt(addr, val); - else { - bits = LSHIFT(val, SI4126_TWI_DATA_MASK) | - LSHIFT(addr, SI4126_TWI_ADDR_MASK); - } + bits = LSHIFT(val, SI4126_TWI_DATA_MASK) | + LSHIFT(addr, SI4126_TWI_ADDR_MASK); nbits = 22; lo_to_hi = 0; break; diff --git a/sys/dev/ic/rtwreg.h b/sys/dev/ic/rtwreg.h index 67b61754bb6..bf1b3b9d187 100644 --- a/sys/dev/ic/rtwreg.h +++ b/sys/dev/ic/rtwreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rtwreg.h,v 1.10 2005/10/24 02:41:58 reyk Exp $ */ +/* $OpenBSD: rtwreg.h,v 1.11 2005/11/20 09:49:06 jsg Exp $ */ /* $NetBSD: rtwreg.h,v 1.12 2005/01/16 11:50:43 dyoung Exp $ */ /*- * Copyright (c) 2004, 2005 David Young. All rights reserved. @@ -1220,6 +1220,7 @@ struct rtw_rxdesc { #define RTW_BBP_ANTATTEN_PHILIPS_MAGIC 0x91 #define RTW_BBP_ANTATTEN_INTERSIL_MAGIC 0x92 #define RTW_BBP_ANTATTEN_RFMD_MAGIC 0x93 +#define RTW_BBP_ANTATTEN_GCT_MAGIC 0xa3 #define RTW_BBP_ANTATTEN_MAXIM_MAGIC 0xb3 #define RTW_BBP_ANTATTEN_DFLANTB 0x40 #define RTW_BBP_ANTATTEN_CHAN14 0x0c |