diff options
author | Damien Bergamini <damien@cvs.openbsd.org> | 2008-12-29 13:27:28 +0000 |
---|---|---|
committer | Damien Bergamini <damien@cvs.openbsd.org> | 2008-12-29 13:27:28 +0000 |
commit | 8267a6e17f31147b827f5e7d68974ccc56d5b35d (patch) | |
tree | bc16238e1908db8fe51db6f8de6c64489994b06a /sys | |
parent | 321e1a96e83c3a2e467573deb017d217f969d59a (diff) |
move the 802.11 header out of the TXWI structure.
add some definitions for RT2870/RT3070.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/ic/rt2860.c | 109 | ||||
-rw-r--r-- | sys/dev/ic/rt2860reg.h | 165 | ||||
-rw-r--r-- | sys/dev/ic/rt2860var.h | 6 |
3 files changed, 230 insertions, 50 deletions
diff --git a/sys/dev/ic/rt2860.c b/sys/dev/ic/rt2860.c index 7cf1ca39e3f..b457a7fe165 100644 --- a/sys/dev/ic/rt2860.c +++ b/sys/dev/ic/rt2860.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2860.c,v 1.29 2008/12/22 18:20:47 damien Exp $ */ +/* $OpenBSD: rt2860.c,v 1.30 2008/12/29 13:27:27 damien Exp $ */ /*- * Copyright (c) 2007, 2008 @@ -133,7 +133,9 @@ int rt2860_set_key(struct ieee80211com *, struct ieee80211_node *, struct ieee80211_key *); void rt2860_delete_key(struct ieee80211com *, struct ieee80211_node *, struct ieee80211_key *); +#if NBPFILTER > 0 int8_t rt2860_rssi2dbm(struct rt2860_softc *, uint8_t, uint8_t); +#endif const char * rt2860_get_rf(uint8_t); int rt2860_read_eeprom(struct rt2860_softc *); int rt2860_bbp_init(struct rt2860_softc *); @@ -470,9 +472,11 @@ rt2860_free_tx_ring(struct rt2860_softc *sc, struct rt2860_tx_ring *ring) int rt2860_alloc_tx_pool(struct rt2860_softc *sc) { + caddr_t vaddr; + bus_addr_t paddr; int i, nsegs, size, error; - size = RT2860_TX_POOL_COUNT * sizeof (struct rt2860_txwi); + size = RT2860_TX_POOL_COUNT * RT2860_TXWI_DMASZ; /* init data_pool early in case of failure.. */ SLIST_INIT(&sc->data_pool); @@ -493,23 +497,25 @@ rt2860_alloc_tx_pool(struct rt2860_softc *sc) } error = bus_dmamem_map(sc->sc_dmat, &sc->txwi_seg, nsegs, size, - (caddr_t *)&sc->txwi, BUS_DMA_NOWAIT); + &sc->txwi_vaddr, BUS_DMA_NOWAIT); if (error != 0) { printf("%s: could not map DMA memory\n", sc->sc_dev.dv_xname); goto fail; } - error = bus_dmamap_load(sc->sc_dmat, sc->txwi_map, sc->txwi, size, - NULL, BUS_DMA_NOWAIT); + error = bus_dmamap_load(sc->sc_dmat, sc->txwi_map, sc->txwi_vaddr, + size, NULL, BUS_DMA_NOWAIT); if (error != 0) { printf("%s: could not load DMA map\n", sc->sc_dev.dv_xname); goto fail; } - memset(sc->txwi, 0, size); + memset(sc->txwi_vaddr, 0, size); bus_dmamap_sync(sc->sc_dmat, sc->txwi_map, 0, size, BUS_DMASYNC_PREWRITE); + vaddr = sc->txwi_vaddr; + paddr = sc->txwi_map->dm_segs[0].ds_addr; for (i = 0; i < RT2860_TX_POOL_COUNT; i++) { struct rt2860_tx_data *data = &sc->data[i]; @@ -521,10 +527,10 @@ rt2860_alloc_tx_pool(struct rt2860_softc *sc) sc->sc_dev.dv_xname); goto fail; } - - data->txwi = &sc->txwi[i]; - data->paddr = sc->txwi_map->dm_segs[0].ds_addr + - i * sizeof (struct rt2860_txwi); + data->txwi = (struct rt2860_txwi *)vaddr; + data->paddr = paddr; + vaddr += RT2860_TXWI_DMASZ; + paddr += RT2860_TXWI_DMASZ; SLIST_INSERT_HEAD(&sc->data_pool, data, next); } @@ -538,12 +544,12 @@ fail: rt2860_free_tx_pool(sc); void rt2860_free_tx_pool(struct rt2860_softc *sc) { - if (sc->txwi != NULL) { + if (sc->txwi_vaddr != NULL) { bus_dmamap_sync(sc->sc_dmat, sc->txwi_map, 0, sc->txwi_map->dm_mapsize, BUS_DMASYNC_POSTWRITE); bus_dmamap_unload(sc->sc_dmat, sc->txwi_map); - bus_dmamem_unmap(sc->sc_dmat, (caddr_t)sc->txwi, - RT2860_TX_POOL_COUNT * sizeof (struct rt2860_txwi)); + bus_dmamem_unmap(sc->sc_dmat, sc->txwi_vaddr, + RT2860_TX_POOL_COUNT * RT2860_TXWI_DMASZ); bus_dmamem_free(sc->sc_dmat, &sc->txwi_seg, 1); } if (sc->txwi_map != NULL) @@ -1478,7 +1484,7 @@ rt2860_tx(struct rt2860_softc *sc, struct mbuf *m, struct ieee80211_node *ni) #endif /* copy and trim 802.11 header */ - memcpy(&txwi->wh, wh, hdrlen); + memcpy(txwi + 1, wh, hdrlen); m_adj(m, hdrlen); error = bus_dmamap_load_mbuf(sc->sc_dmat, data->map, m, @@ -1544,7 +1550,7 @@ rt2860_tx(struct rt2860_softc *sc, struct mbuf *m, struct ieee80211_node *ni) /* first segment is TXWI + 802.11 header */ txd = &ring->txd[ring->cur]; txd->sdp0 = htole32(data->paddr); - txd->sdl0 = htole16(16 + hdrlen); + txd->sdl0 = htole16(sizeof (struct rt2860_txwi) + hdrlen); txd->flags = qsel; /* setup payload segments */ @@ -1577,7 +1583,7 @@ rt2860_tx(struct rt2860_softc *sc, struct mbuf *m, struct ieee80211_node *ni) ring->data[ring->cur] = data; bus_dmamap_sync(sc->sc_dmat, sc->txwi_map, - (caddr_t)txwi - (caddr_t)sc->txwi, sizeof (struct rt2860_txwi), + (caddr_t)txwi - sc->txwi_vaddr, RT2860_TXWI_DMASZ, BUS_DMASYNC_PREWRITE); bus_dmamap_sync(sc->sc_dmat, data->map, 0, data->map->dm_mapsize, BUS_DMASYNC_PREWRITE); @@ -1921,7 +1927,25 @@ rt2860_select_chan_group(struct rt2860_softc *sc, int group) rt2860_mcu_bbp_write(sc, 62, 0x37 - sc->lna[group]); rt2860_mcu_bbp_write(sc, 63, 0x37 - sc->lna[group]); rt2860_mcu_bbp_write(sc, 64, 0x37 - sc->lna[group]); - rt2860_mcu_bbp_write(sc, 82, (group == 0) ? 0x62 : 0xf2); + rt2860_mcu_bbp_write(sc, 86, 0x00); + + if (group == 0) { + if (sc->ext_2ghz_lna) { + rt2860_mcu_bbp_write(sc, 82, 0x62); + rt2860_mcu_bbp_write(sc, 75, 0x46); + } else { + rt2860_mcu_bbp_write(sc, 82, 0x84); + rt2860_mcu_bbp_write(sc, 75, 0x50); + } + } else { + if (sc->ext_5ghz_lna) { + rt2860_mcu_bbp_write(sc, 82, 0xf2); + rt2860_mcu_bbp_write(sc, 75, 0x46); + } else { + rt2860_mcu_bbp_write(sc, 82, 0xf2); + rt2860_mcu_bbp_write(sc, 75, 0x50); + } + } tmp = RAL_READ(sc, RT2860_TX_BAND_CFG); tmp &= ~(RT2860_5G_BAND_SEL_N | RT2860_5G_BAND_SEL_P); @@ -1945,7 +1969,11 @@ rt2860_select_chan_group(struct rt2860_softc *sc, int group) } RAL_WRITE(sc, RT2860_TX_PIN_CFG, tmp); - rt2860_mcu_bbp_write(sc, 66, 0x2e + sc->lna[group]); + /* set initial AGC value */ + if (group == 0) + rt2860_mcu_bbp_write(sc, 66, 0x2e + sc->lna[0]); + else + rt2860_mcu_bbp_write(sc, 66, 0x32 + (sc->lna[group] * 5) / 3); } void @@ -1976,30 +2004,36 @@ rt2860_set_chan(struct rt2860_softc *sc, struct ieee80211_channel *c) txpow1 = sc->txpow1[i]; txpow2 = sc->txpow2[i]; if (IEEE80211_IS_CHAN_5GHZ(c)) { - txpow1 = txpow1 << 1 | 1; - txpow2 = txpow2 << 1 | 1; + if (txpow1 >= 0) + txpow1 = txpow1 << 1; + else + txpow1 = (7 + txpow1) << 1 | 1; + if (txpow2 >= 0) + txpow2 = txpow2 << 1; + else + txpow2 = (7 + txpow2) << 1 | 1; } r3 = rfprog[i].r3 | txpow1 << 7; r4 = rfprog[i].r4 | sc->freq << 13 | txpow2 << 4; - rt2860_rf_write(sc, RAL_RF1, rfprog[i].r1); - rt2860_rf_write(sc, RAL_RF2, r2); - rt2860_rf_write(sc, RAL_RF3, r3); - rt2860_rf_write(sc, RAL_RF4, r4); + rt2860_rf_write(sc, RT2860_RF1, rfprog[i].r1); + rt2860_rf_write(sc, RT2860_RF2, r2); + rt2860_rf_write(sc, RT2860_RF3, r3); + rt2860_rf_write(sc, RT2860_RF4, r4); DELAY(200); - rt2860_rf_write(sc, RAL_RF1, rfprog[i].r1); - rt2860_rf_write(sc, RAL_RF2, r2); - rt2860_rf_write(sc, RAL_RF3, r3 | 1); - rt2860_rf_write(sc, RAL_RF4, r4); + rt2860_rf_write(sc, RT2860_RF1, rfprog[i].r1); + rt2860_rf_write(sc, RT2860_RF2, r2); + rt2860_rf_write(sc, RT2860_RF3, r3 | 1); + rt2860_rf_write(sc, RT2860_RF4, r4); DELAY(200); - rt2860_rf_write(sc, RAL_RF1, rfprog[i].r1); - rt2860_rf_write(sc, RAL_RF2, r2); - rt2860_rf_write(sc, RAL_RF3, r3); - rt2860_rf_write(sc, RAL_RF4, r4); + rt2860_rf_write(sc, RT2860_RF1, rfprog[i].r1); + rt2860_rf_write(sc, RT2860_RF2, r2); + rt2860_rf_write(sc, RT2860_RF3, r3); + rt2860_rf_write(sc, RT2860_RF4, r4); /* 802.11a uses a 16 microseconds short interframe space */ sc->sifs = IEEE80211_IS_CHAN_5GHZ(c) ? 16 : 10; @@ -2267,6 +2301,7 @@ rt2860_delete_key(struct ieee80211com *ic, struct ieee80211_node *ni, } } +#if NBPFILTER > 0 int8_t rt2860_rssi2dbm(struct rt2860_softc *sc, uint8_t rssi, uint8_t rxchain) { @@ -2290,6 +2325,7 @@ rt2860_rssi2dbm(struct rt2860_softc *sc, uint8_t rssi, uint8_t rxchain) return -12 - delta - rssi; } +#endif /* * Add `delta' (signed) to each 4-bit sub-word of a 32-bit word. @@ -2398,8 +2434,11 @@ rt2860_read_eeprom(struct rt2860_softc *sc) /* check if RF supports automatic Tx access gain control */ val = rt2860_eeprom_read(sc, RT2860_EEPROM_CONFIG); DPRINTF(("EEPROM CFG 0x%04x\n", val)); - if ((val & 0xff) != 0xff) + if ((val & 0xff) != 0xff) { + sc->ext_5ghz_lna = (val >> 3) & 1; + sc->ext_2ghz_lna = (val >> 2) & 1; sc->calib_2ghz = sc->calib_5ghz = 0; /* XXX (val >> 1) & 1 */; + } if (sc->sc_flags & RT2860_ADVANCED_PS) { /* read PCIe power save level */ @@ -3055,8 +3094,8 @@ rt2860_setup_beacon(struct rt2860_softc *sc) txwi.flags = RT2860_TX_TS; RAL_WRITE_REGION_1(sc, RT2860_BCN_BASE(0), - (uint8_t *)&txwi, 16); - RAL_WRITE_REGION_1(sc, RT2860_BCN_BASE(0) + 16, + (uint8_t *)&txwi, sizeof txwi); + RAL_WRITE_REGION_1(sc, RT2860_BCN_BASE(0) + sizeof txwi, mtod(m, uint8_t *), m->m_pkthdr.len); m_freem(m); diff --git a/sys/dev/ic/rt2860reg.h b/sys/dev/ic/rt2860reg.h index 3b505f32fff..701006a83cb 100644 --- a/sys/dev/ic/rt2860reg.h +++ b/sys/dev/ic/rt2860reg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2860reg.h,v 1.13 2008/12/14 18:41:57 damien Exp $ */ +/* $OpenBSD: rt2860reg.h,v 1.14 2008/12/29 13:27:27 damien Exp $ */ /*- * Copyright (c) 2007 @@ -24,6 +24,8 @@ #define RT2860_PCI_SYSCTRL 0x000c #define RT2860_PCIE_JTAG 0x0010 +#define RT3070_OPT_14 0x0114 + /* SCH/DMA registers */ #define RT2860_INT_STATUS 0x0200 #define RT2860_INT_MASK 0x0204 @@ -45,6 +47,7 @@ #define RT2860_RX_MAX_CNT 0x0294 #define RT2860_RX_CALC_IDX 0x0298 #define RT2860_FS_DRX_IDX 0x029c +#define RT2860_USB_DMA_CFG 0x02a0 /* RT2870 only */ #define RT2860_US_CYC_CNT 0x02a4 /* PBF registers */ @@ -64,6 +67,16 @@ #define RT2860_PBF_DBG 0x043c #define RT2860_CAP_CTRL 0x0440 +/* RT3070 registers */ +#define RT3070_RF_CSR_CFG 0x0500 +#define RT3070_EFUSE_CTRL 0x0580 +#define RT3070_EFUSE_DATA0 0x0590 +#define RT3070_EFUSE_DATA1 0x0594 +#define RT3070_EFUSE_DATA2 0x0598 +#define RT3070_EFUSE_DATA3 0x059c +#define RT3070_LDO_CFG0 0x05d4 +#define RT3070_GPIO_SWITCH 0x05dc + /* MAC registers */ #define RT2860_ASIC_VER_ID 0x1000 #define RT2860_MAC_SYS_CTRL 0x1004 @@ -164,6 +177,7 @@ #define RT2860_WCID_ENTRY(wcid) (0x1800 + (wcid) * 8) #define RT2860_FW_BASE 0x2000 +#define RT2870_FW_BASE 0x3000 /* Pair-wise key table */ #define RT2860_PKEY(wcid) (0x4000 + (wcid) * 32) @@ -185,6 +199,8 @@ /* Shared Memory between MCU and host */ #define RT2860_H2M_MAILBOX 0x7010 +#define RT2860_H2M_MAILBOX_CID 0x7014 +#define RT2860_H2M_MAILBOX_STATUS 0x701c #define RT2860_H2M_BBPAGENT 0x7028 #define RT2860_BCN_BASE(vap) (0x7800 + (vap) * 512) @@ -243,6 +259,20 @@ #define RT2860_GPIO_D_SHIFT 8 #define RT2860_GPIO_O_SHIFT 0 +/* possible flags for register USB_DMA_CFG */ +#define RT2860_USB_TX_BUSY (1 << 31) +#define RT2860_USB_RX_BUSY (1 << 30) +#define RT2860_USB_EPOUT_VLD_SHIFT 24 +#define RT2860_USB_TX_EN (1 << 23) +#define RT2860_USB_RX_EN (1 << 22) +#define RT2860_USB_RX_AGG_EN (1 << 21) +#define RT2860_USB_TXOP_HALT (1 << 20) +#define RT2860_USB_TX_CLEAR (1 << 19) +#define RT2860_USB_PHY_WD_EN (1 << 16) +#define RT2860_USB_PHY_MAN_RST (1 << 15) +#define RT2860_USB_RX_AGG_LMT_SHIFT 8 +#define RT2860_USB_RX_AGG_TO_SHIFT 0 + /* possible flags for register US_CYC_CNT */ #define RT2860_TEST_EN (1 << 24) #define RT2860_TEST_SEL_SHIFT 16 @@ -329,6 +359,17 @@ #define RT2860_TRIG_OFFSET_SHIFT 16 #define RT2860_START_ADDR_SHIFT 0 +/* possible flags for register RF_CSR_CFG */ +#define RT3070_RF_KICK (1 << 17) +#define RT3070_RF_WRITE (1 << 16) + +/* possible flags for register EFUSE_CTRL */ +#define RT3070_SEL_EFUSE (1 << 31) +#define RT3070_EFSROM_KICK (1 << 30) +#define RT3070_EFSROM_AIN_SHIFT 16 +#define RT3070_EFSROM_MODE_MASK (3 << 6) +#define RT3070_EFUSE_AOUT_MASK 0x0000003f + /* possible flags for register MAC_SYS_CTRL */ #define RT2860_RX_TS_EN (1 << 7) #define RT2860_WLAN_HALT_EN (1 << 6) @@ -627,7 +668,7 @@ #define RT2860_LED_LINK_5GHZ (1 << 15) -/* TX descriptor */ +/* RT2860 TX descriptor */ struct rt2860_txd { uint32_t sdp0; /* Segment Data Pointer 0 */ uint16_t sdl1; /* Segment Data Length 1 */ @@ -648,6 +689,13 @@ struct rt2860_txd { #define RT2860_TX_WIV (1 << 0) } __packed; +/* RT2870 TX descriptor */ +struct rt2870_txd { + uint16_t len; + uint8_t pad; + uint8_t flags; +} __packed; + /* TX Wireless Information */ struct rt2860_txwi { uint8_t flags; @@ -686,12 +734,9 @@ struct rt2860_txwi { uint32_t iv; uint32_t eiv; - - struct ieee80211_htframe wh; - uint16_t pad; } __packed; -/* RX descriptor */ +/* RT2860 RX descriptor */ struct rt2860_rxd { uint32_t sdp0; uint16_t sdl1; /* unused */ @@ -720,6 +765,12 @@ struct rt2860_rxd { #define RT2860_RX_BA (1 << 0) } __packed; +/* RT2870 RX descriptor */ +struct rt2870_rxd { + /* single 32-bit field */ + uint32_t flags; +} __packed; + /* RX Wireless Information */ struct rt2860_rxwi { uint8_t wcid; @@ -738,15 +789,33 @@ struct rt2860_rxwi { uint16_t reserved2; } __packed; -#define RAL_RF1 0 -#define RAL_RF2 2 -#define RAL_RF3 1 -#define RAL_RF4 3 + +/* first DMA segment contains TXWI + 802.11 header + 32-bit padding */ +#define RT2860_TXWI_DMASZ \ + (sizeof (struct rt2860_txwi) + \ + sizeof (struct ieee80211_htframe) + \ + sizeof (uint16_t)) + +#define RT2860_RF1 0 +#define RT2860_RF2 2 +#define RT2860_RF3 1 +#define RT2860_RF4 3 #define RT2860_RF_2820 1 /* 2T3R */ #define RT2860_RF_2850 2 /* dual-band 2T3R */ #define RT2860_RF_2720 3 /* 1T2R */ #define RT2860_RF_2750 4 /* dual-band 1T2R */ +#define RT3070_RF_3020 5 /* 1T1R */ +#define RT3070_RF_2020 6 /* b/g */ +#define RT3070_RF_3021 7 /* 1T2R */ +#define RT3070_RF_3022 8 /* 2T2R */ + +/* USB commands for RT2870 only */ +#define RT2870_RESET 1 +#define RT2870_WRITE_2 2 +#define RT2870_WRITE_REGION_1 6 +#define RT2870_READ_REGION_1 7 +#define RT2870_EEPROM_READ 9 #define RT2860_EEPROM_DELAY 1 /* minimum hold time (microsecond) */ @@ -879,6 +948,39 @@ static const struct rt2860_rate { { RT2860_XIFS_TIME_CFG, 0x33a41010 }, \ { RT2860_PWR_PIN_CFG, 0x00000003 } +/* XXX only a few registers differ from above, try to merge? */ +#define RT2870_DEF_MAC \ + { RT2860_BCN_OFFSET0, 0xf8f0e8e0 }, \ + { RT2860_LEGACY_BASIC_RATE, 0x0000013f }, \ + { RT2860_HT_BASIC_RATE, 0x00008003 }, \ + { RT2860_MAC_SYS_CTRL, 0x00000000 }, \ + { RT2860_BKOFF_SLOT_CFG, 0x00000209 }, \ + { RT2860_TX_SW_CFG0, 0x00000000 }, \ + { RT2860_TX_SW_CFG1, 0x00080606 }, \ + { RT2860_TX_LINK_CFG, 0x00001020 }, \ + { RT2860_TX_TIMEOUT_CFG, 0x000a2090 }, \ + { RT2860_LED_CFG, 0x7f031e46 }, \ + { RT2860_WMM_AIFSN_CFG, 0x00002273 }, \ + { RT2860_WMM_CWMIN_CFG, 0x00002344 }, \ + { RT2860_WMM_CWMAX_CFG, 0x000034aa }, \ + { RT2860_MAX_PCNT, 0x1f3fbf9f }, \ + { RT2860_TX_RTY_CFG, 0x47d01f0f }, \ + { RT2860_AUTO_RSP_CFG, 0x00000013 }, \ + { RT2860_CCK_PROT_CFG, 0x05740003 }, \ + { RT2860_OFDM_PROT_CFG, 0x05740003 }, \ + { RT2860_PBF_CFG, 0x00f40006 }, \ + { RT2860_WPDMA_GLO_CFG, 0x00000030 }, \ + { RT2860_GF20_PROT_CFG, 0x01744004 }, \ + { RT2860_GF40_PROT_CFG, 0x03f44084 }, \ + { RT2860_MM20_PROT_CFG, 0x01744004 }, \ + { RT2860_MM40_PROT_CFG, 0x03f44084 }, \ + { RT2860_TXOP_CTRL_CFG, 0x0000583f }, \ + { RT2860_TXOP_HLDR_ET, 0x00000002 }, \ + { RT2860_TX_RTS_CFG, 0x00092b20 }, \ + { RT2860_EXP_ACK_TIME, 0x002400ca }, \ + { RT2860_XIFS_TIME_CFG, 0x33a41010 }, \ + { RT2860_PWR_PIN_CFG, 0x00000003 } + /* * Default values for BBP registers; values taken from the reference driver. */ @@ -929,9 +1031,9 @@ static const struct rt2860_rate { { 62, 0x100bb2, 0x1301a4, 0x056014, 0x001404 }, \ { 64, 0x100bb2, 0x1301a4, 0x056014, 0x001408 }, \ { 100, 0x100bb2, 0x1301ac, 0x05e014, 0x001400 }, \ - { 102, 0x100bb2, 0x1301ac, 0x05e014, 0x001404 }, \ - { 104, 0x100bb2, 0x1301ac, 0x05e014, 0x001408 }, \ - { 108, 0x100bb3, 0x13028c, 0x05e014, 0x001404 }, \ + { 102, 0x100bb2, 0x1701ac, 0x15e014, 0x001404 }, \ + { 104, 0x100bb2, 0x1701ac, 0x15e014, 0x001408 }, \ + { 108, 0x100bb3, 0x17028c, 0x15e014, 0x001404 }, \ { 110, 0x100bb3, 0x13028d, 0x05e014, 0x001400 }, \ { 112, 0x100bb3, 0x13028d, 0x05e014, 0x001406 }, \ { 116, 0x100bb3, 0x13028e, 0x05e014, 0x001408 }, \ @@ -951,3 +1053,40 @@ static const struct rt2860_rate { { 159, 0x100bb1, 0x1300e3, 0x05e014, 0x001409 }, \ { 161, 0x100bb1, 0x1300e4, 0x05e014, 0x001401 }, \ { 165, 0x100bb1, 0x1300e4, 0x05e014, 0x001405 } + +#define RT3070_RF3020 \ + { 241, 2, 2 }, \ + { 241, 2, 7 }, \ + { 242, 2, 2 }, \ + { 242, 2, 7 }, \ + { 243, 2, 2 }, \ + { 243, 2, 7 }, \ + { 244, 2, 2 }, \ + { 244, 2, 7 }, \ + { 245, 2, 2 }, \ + { 245, 2, 7 }, \ + { 246, 2, 2 }, \ + { 246, 2, 7 }, \ + { 247, 2, 2 }, \ + { 248, 2, 4 } + +#define RT3070_DEF_RF \ + { 4, 0x40 }, \ + { 5, 0x03 }, \ + { 6, 0x02 }, \ + { 7, 0x70 }, \ + { 9, 0x0f }, \ + { 10, 0x41 }, \ + { 11, 0x21 }, \ + { 12, 0x7b }, \ + { 14, 0x90 }, \ + { 15, 0x58 }, \ + { 16, 0xb3 }, \ + { 17, 0x92 }, \ + { 18, 0x2c }, \ + { 19, 0x02 }, \ + { 20, 0xba }, \ + { 21, 0xdb }, \ + { 24, 0x16 }, \ + { 25, 0x01 }, \ + { 29, 0x1f } diff --git a/sys/dev/ic/rt2860var.h b/sys/dev/ic/rt2860var.h index 1b011fa4591..8c780364fcb 100644 --- a/sys/dev/ic/rt2860var.h +++ b/sys/dev/ic/rt2860var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2860var.h,v 1.10 2008/12/13 14:35:19 damien Exp $ */ +/* $OpenBSD: rt2860var.h,v 1.11 2008/12/29 13:27:27 damien Exp $ */ /*- * Copyright (c) 2007 @@ -132,7 +132,7 @@ struct rt2860_softc { struct rt2860_tx_data data[RT2860_TX_POOL_COUNT]; bus_dmamap_t txwi_map; bus_dma_segment_t txwi_seg; - struct rt2860_txwi *txwi; + caddr_t txwi_vaddr; int sc_tx_timer; int mgtqid; @@ -150,6 +150,8 @@ struct rt2860_softc { int8_t rssi_2ghz[3]; int8_t rssi_5ghz[3]; uint8_t lna[4]; + uint8_t ext_2ghz_lna; + uint8_t ext_5ghz_lna; uint8_t calib_2ghz; uint8_t calib_5ghz; uint8_t tssi_2ghz[9]; |