summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/ic/atw.c8
-rw-r--r--sys/dev/ic/atwreg.h91
-rw-r--r--sys/dev/ic/atwvar.h6
3 files changed, 85 insertions, 20 deletions
diff --git a/sys/dev/ic/atw.c b/sys/dev/ic/atw.c
index 9410f639984..49255bb253e 100644
--- a/sys/dev/ic/atw.c
+++ b/sys/dev/ic/atw.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: atw.c,v 1.23 2004/07/25 00:03:52 millert Exp $ */
-/* $NetBSD: atw.c,v 1.66 2004/07/16 23:13:27 dyoung Exp $ */
+/* $OpenBSD: atw.c,v 1.24 2004/07/25 00:16:35 millert Exp $ */
+/* $NetBSD: atw.c,v 1.67 2004/07/23 23:13:27 dyoung Exp $ */
/*-
* Copyright (c) 1998, 1999, 2000, 2002, 2003, 2004 The NetBSD Foundation, Inc.
@@ -43,7 +43,7 @@
#include <sys/cdefs.h>
#if defined(__NetBSD__)
-__KERNEL_RCSID(0, "$NetBSD: atw.c,v 1.66 2004/07/16 23:13:27 dyoung Exp $");
+__KERNEL_RCSID(0, "$NetBSD: atw.c,v 1.67 2004/07/23 23:13:27 dyoung Exp $");
#endif
#include "bpfilter.h"
@@ -2028,7 +2028,7 @@ atw_write_sram(struct atw_softc *sc, u_int ofs, u_int8_t *buf, u_int buflen)
KASSERT(ofs % 2 == 0 && buflen % 2 == 0);
- KASSERT(buflen + ofs <= ATW_SRAM_SIZE);
+ KASSERT(buflen + ofs <= ATW_SRAM_A_SIZE);
ptr = &sc->sc_sram[ofs];
diff --git a/sys/dev/ic/atwreg.h b/sys/dev/ic/atwreg.h
index fb25bac3c4e..bccb451415f 100644
--- a/sys/dev/ic/atwreg.h
+++ b/sys/dev/ic/atwreg.h
@@ -1,5 +1,5 @@
-/* $OpenBSD: atwreg.h,v 1.3 2004/07/15 16:09:20 millert Exp $ */
-/* $NetBSD: atwreg.h,v 1.8 2004/05/31 11:40:56 dyoung Exp $ */
+/* $OpenBSD: atwreg.h,v 1.4 2004/07/25 00:16:35 millert Exp $ */
+/* $NetBSD: atwreg.h,v 1.10 2004/07/23 05:01:29 dyoung Exp $ */
/*
* Copyright (c) 2003 The NetBSD Foundation, Inc. All rights reserved.
@@ -392,10 +392,14 @@
#define ATW_TEST1_TXWP_TDBP LSHIFT(0x3, ATW_TEST1_TXWP_MASK)
#define ATW_TEST1_RSVD0_MASK BITS(24,6) /* reserved */
#define ATW_TEST1_TESTMODE_MASK BITS(5,4)
-#define ATW_TEST1_TESTMODE_NORMAL LSHIFT(0x0, ) /* normal operation */
-#define ATW_TEST1_TESTMODE_MACONLY LSHIFT(0x1, ) /* MAC-only mode */
-#define ATW_TEST1_TESTMODE_NORMAL2 LSHIFT(0x2, ) /* normal operation */
-#define ATW_TEST1_TESTMODE_MONITOR LSHIFT(0x3, ) /* monitor mode */
+/* normal operation */
+#define ATW_TEST1_TESTMODE_NORMAL LSHIFT(0x0, ATW_TEST1_TESTMODE_MASK)
+/* MAC-only mode */
+#define ATW_TEST1_TESTMODE_MACONLY LSHIFT(0x1, ATW_TEST1_TESTMODE_MASK)
+/* normal operation */
+#define ATW_TEST1_TESTMODE_NORMAL2 LSHIFT(0x2, ATW_TEST1_TESTMODE_MASK)
+/* monitor mode */
+#define ATW_TEST1_TESTMODE_MONITOR LSHIFT(0x3, ATW_TEST1_TESTMODE_MASK)
#define ATW_TEST1_DUMP_MASK BITS(3,0) /* select dump signal
* from dxfer (huh?)
@@ -551,14 +555,68 @@
*/
#define ATW_PLCPHD_PMBL BIT(15) /* 0: long preamble, 1: short */
-#define ATW_MMIWADDR_INTERSIL 0x100E0C0A
-#define ATW_MMIWADDR_RFMD 0x00009101
+#define ATW_MMIWADDR_LENLO_MASK BITS(31,24) /* tx: written 4th */
+#define ATW_MMIWADDR_LENHI_MASK BITS(23,16) /* tx: written 3rd */
+#define ATW_MMIWADDR_GAIN_MASK BITS(15,8) /* tx: written 2nd */
+#define ATW_MMIWADDR_RATE_MASK BITS(7,0) /* tx: written 1st */
-#define ATW_MMIRADDR1_INTERSIL 0x00007c7e
-#define ATW_MMIRADDR1_RFMD 0x00000301
+/* was magic 0x100E0C0A */
+#define ATW_MMIWADDR_INTERSIL \
+ (LSHIFT(0x0c, ATW_MMIWADDR_GAIN_MASK) | \
+ LSHIFT(0x0a, ATW_MMIWADDR_RATE_MASK) | \
+ LSHIFT(0x0e, ATW_MMIWADDR_LENHI_MASK) | \
+ LSHIFT(0x10, ATW_MMIWADDR_LENLO_MASK))
-#define ATW_MMIRADDR2_INTERSIL 0x00100000
-#define ATW_MMIRADDR2_RFMD 0x7e100000
+/* was magic 0x00009101
+ *
+ * ADMtek sets the AI bit on the ATW_MMIWADDR_GAIN_MASK address to
+ * put the RF3000 into auto-increment mode so that it can write Tx gain,
+ * Tx length (high) and Tx length (low) registers back-to-back.
+ */
+#define ATW_MMIWADDR_RFMD \
+ (LSHIFT(RF3000_TWI_AI|RF3000_GAINCTL, ATW_MMIWADDR_GAIN_MASK) | \
+ LSHIFT(RF3000_CTL, ATW_MMIWADDR_RATE_MASK))
+
+#define ATW_MMIRADDR1_RSVD_MASK BITS(31, 24)
+#define ATW_MMIRADDR1_PWRLVL_MASK BITS(23, 16)
+#define ATW_MMIRADDR1_RSSI_MASK BITS(15, 8)
+#define ATW_MMIRADDR1_RXSTAT_MASK BITS(7, 0)
+
+/* was magic 0x00007c7e
+ *
+ * TBD document registers for Intersil 3861 baseband
+ */
+#define ATW_MMIRADDR1_INTERSIL \
+ (LSHIFT(0x7c, ATW_MMIRADDR1_RSSI_MASK) | \
+ LSHIFT(0x7e, ATW_MMIRADDR1_RXSTAT_MASK))
+
+/* was magic 0x00000301 */
+#define ATW_MMIRADDR1_RFMD \
+ (LSHIFT(RF3000_RSSI, ATW_MMIRADDR1_RSSI_MASK) | \
+ LSHIFT(RF3000_RXSTAT, ATW_MMIRADDR1_RXSTAT_MASK))
+
+/* was magic 0x00100000 */
+#define ATW_MMIRADDR2_INTERSIL \
+ (LSHIFT(0x0, ATW_MMIRADDR2_ID_MASK) | \
+ LSHIFT(0x10, ATW_MMIRADDR2_RXPECNT_MASK))
+
+/* was magic 0x7e100000 */
+#define ATW_MMIRADDR2_RFMD \
+ (LSHIFT(0x7e, ATW_MMIRADDR2_ID_MASK) | \
+ LSHIFT(0x10, ATW_MMIRADDR2_RXPECNT_MASK))
+
+#define ATW_MMIRADDR2_ID_MASK BITS(31, 24) /* 1st element ID in WEP table
+ * for Probe Response (huh?)
+ */
+/* RXPE is re-asserted after RXPECNT * 22MHz. */
+#define ATW_MMIRADDR2_RXPECNT_MASK BITS(23, 16)
+#define ATW_MMIRADDR2_PROREXT BIT(15) /* Probe Response
+ * 11Mb/s length
+ * extension.
+ */
+#define ATW_MMIRADDR2_PRORLEN_MASK BITS(14, 0) /* Probe Response
+ * microsecond length
+ */
#define ATW_TXBR_ALCUPDATE_MASK BIT(31) /* auto-update BBP with ALCSET */
#define ATW_TXBR_TBCNT_MASK BITS(16, 20) /* transmit burst count */
@@ -849,6 +907,8 @@
/* Serial EEPROM offsets */
#define ATW_SR_CLASS_CODE (0x00/2)
#define ATW_SR_FORMAT_VERSION (0x02/2)
+#define ATW_SR_MAJOR_MASK BITS(7, 0)
+#define ATW_SR_MINOR_MASK BITS(15,8)
#define ATW_SR_MAC00 (0x08/2) /* CSR21 */
#define ATW_SR_MAC01 (0x0A/2) /* CSR21/22 */
#define ATW_SR_MAC10 (0x0C/2) /* CSR22 */
@@ -859,6 +919,8 @@
#define ATW_SR_RFTYPE_MASK BITS(5, 3)
#define ATW_SR_BBPTYPE_MASK BITS(2, 0)
#define ATW_SR_CR28_CR03 (0x18/2)
+#define ATW_SR_CR28_MASK BITS(15,8)
+#define ATW_SR_CR03_MASK BITS(7, 0)
#define ATW_SR_CTRY_CR29 (0x1A/2)
#define ATW_SR_CTRY_MASK BITS(15,8) /* country code */
#define COUNTRY_FCC 0
@@ -868,6 +930,7 @@
#define COUNTRY_FRANCE 4
#define COUNTRY_MMK 5
#define COUNTRY_MMK2 6
+#define ATW_SR_CR29_MASK BITS(7, 0)
#define ATW_SR_PCI_DEVICE (0x20/2) /* CR0 */
#define ATW_SR_PCI_VENDOR (0x22/2) /* CR0 */
#define ATW_SR_SUB_DEVICE (0x24/2) /* CR11 */
@@ -971,5 +1034,7 @@ struct atw_rxdesc {
#define ATW_SRAM_ADDR_SHARED_KEY (0x160 * 2)
#define ATW_SRAM_ADDR_SSID (0x180 * 2)
#define ATW_SRAM_ADDR_SUPRATES (0x191 * 2)
-#define ATW_SRAM_SIZE (0x200 * 2)
+#define ATW_SRAM_MAXSIZE (0x200 * 2)
+#define ATW_SRAM_A_SIZE ATW_SRAM_MAXSIZE
+#define ATW_SRAM_B_SIZE (0x1c0 * 2)
diff --git a/sys/dev/ic/atwvar.h b/sys/dev/ic/atwvar.h
index a80e46e9f8e..4e5a31998ea 100644
--- a/sys/dev/ic/atwvar.h
+++ b/sys/dev/ic/atwvar.h
@@ -1,5 +1,5 @@
-/* $OpenBSD: atwvar.h,v 1.5 2004/07/15 16:14:14 millert Exp $ */
-/* $NetBSD: atwvar.h,v 1.11 2004/07/15 06:13:44 dyoung Exp $ */
+/* $OpenBSD: atwvar.h,v 1.6 2004/07/25 00:16:35 millert Exp $ */
+/* $NetBSD: atwvar.h,v 1.12 2004/07/23 05:06:26 dyoung Exp $ */
/*
* Copyright (c) 2003, 2004 The NetBSD Foundation, Inc. All rights reserved.
@@ -267,7 +267,7 @@ struct atw_softc {
int, u_int32_t);
/* ADM8211 state variables. */
- u_int8_t sc_sram[ATW_SRAM_SIZE];
+ u_int8_t sc_sram[ATW_SRAM_MAXSIZE];
u_int8_t sc_bssid[IEEE80211_ADDR_LEN];
struct timeval sc_last_beacon;