]> CyberLeo.Net >> Repos - FreeBSD/releng/10.0.git/blob - tools/tools/ath/common/dumpregs_5210.c
- Copy stable/10 (r259064) to releng/10.0 as part of the
[FreeBSD/releng/10.0.git] / tools / tools / ath / common / dumpregs_5210.c
1 /*-
2  * Copyright (c) 2002-2008 Sam Leffler, Errno Consulting
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer,
10  *    without modification.
11  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
12  *    similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any
13  *    redistribution must be conditioned upon including a substantially
14  *    similar Disclaimer requirement for further binary redistribution.
15  *
16  * NO WARRANTY
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19  * LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY
20  * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
21  * THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY,
22  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
25  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
27  * THE POSSIBILITY OF SUCH DAMAGES.
28  *
29  * $FreeBSD$
30  */
31 #include "diag.h"
32
33 #include "ah.h"
34 #include "ah_internal.h"
35 #include "ar5210/ar5210reg.h"
36 #include "ar5210/ar5210phy.h"
37
38 #include "dumpregs.h"
39
40 #define N(a)    (sizeof(a) / sizeof(a[0]))
41
42 static struct dumpreg ar5210regs[] = {
43     DEFBASIC(AR_TXDP0,          "TXDP0"),
44     DEFBASIC(AR_TXDP1,          "TXDP1"),
45     DEFBASICfmt(AR_CR,          "CR",           AR_CR_BITS),
46     DEFBASIC(AR_RXDP,           "RXDP"),
47     DEFBASICfmt(AR_CFG,         "CFG",          AR_CFG_BITS),
48     /* NB: read clears pending interrupts */
49     DEFVOIDfmt(AR_ISR,          "ISR",          AR_ISR_BITS),
50     DEFBASICfmt(AR_IMR,         "IMR",          AR_IMR_BITS),
51     DEFBASICfmt(AR_IER,         "IER",          AR_IER_BITS),
52     DEFBASICfmt(AR_BCR,         "BCR",          AR_BCR_BITS),
53     DEFBASICfmt(AR_BSR,         "BSR",          AR_BSR_BITS),
54     DEFBASICfmt(AR_TXCFG,       "TXCFG",        AR_TXCFG_BITS),
55     DEFBASIC(AR_RXCFG,          "RXCFG"),
56     DEFBASIC(AR_MIBC,           "MIBC"),
57     DEFBASIC(AR_TOPS,           "TOPS"),
58     DEFBASIC(AR_RXNOFRM,        "RXNOFR"),
59     DEFBASIC(AR_TXNOFRM,        "TXNOFR"),
60     DEFBASIC(AR_RPGTO,          "RPGTO"),
61     DEFBASIC(AR_RFCNT,          "RFCNT"),
62     DEFBASIC(AR_MISC,           "MISC"),
63     DEFBASICfmt(AR_RC,          "RC",           AR_RC_BITS),
64     DEFBASICfmt(AR_SCR,         "SCR",          AR_SCR_BITS),
65     DEFBASICfmt(AR_INTPEND,     "INTPEND",      AR_INTPEND_BITS),
66     DEFBASIC(AR_SFR,            "SFR"),
67     DEFBASICfmt(AR_PCICFG,      "PCICFG",       AR_PCICFG_BITS),
68     DEFBASIC(AR_GPIOCR,         "GPIOCR"),
69     DEFVOID(AR_GPIODO,          "GPIODO"),
70     DEFVOID(AR_GPIODI,          "GPIODI"),
71     DEFBASIC(AR_SREV,           "SREV"),
72     DEFBASIC(AR_STA_ID0,        "STA_ID0"),
73     DEFBASICfmt(AR_STA_ID1,     "STA_ID1",      AR_STA_ID1_BITS),
74     DEFBASIC(AR_BSS_ID0,        "BSS_ID0"),
75     DEFBASIC(AR_BSS_ID1,        "BSS_ID1"),
76     DEFBASIC(AR_SLOT_TIME,      "SLOTTIME"),
77     DEFBASIC(AR_TIME_OUT,       "TIME_OUT"),
78     DEFBASIC(AR_RSSI_THR,       "RSSI_THR"),
79     DEFBASIC(AR_RETRY_LMT,      "RETRY_LM"),
80     DEFBASIC(AR_USEC,           "USEC"),
81     DEFBASICfmt(AR_BEACON,              "BEACON",       AR_BEACON_BITS),
82     DEFBASIC(AR_CFP_PERIOD,     "CFP_PER"),
83     DEFBASIC(AR_TIMER0,         "TIMER0"),
84     DEFBASIC(AR_TIMER1,         "TIMER1"),
85     DEFBASIC(AR_TIMER2,         "TIMER2"),
86     DEFBASIC(AR_TIMER3,         "TIMER3"),
87     DEFBASIC(AR_IFS0,           "IFS0"),
88     DEFBASIC(AR_IFS1,           "IFS1"  ),
89     DEFBASIC(AR_CFP_DUR,        "CFP_DUR"),
90     DEFBASICfmt(AR_RX_FILTER,   "RXFILTER",     AR_BEACON_BITS),
91     DEFBASIC(AR_MCAST_FIL0,     "MCAST_0"),
92     DEFBASIC(AR_MCAST_FIL1,     "MCAST_1"),
93     DEFBASIC(AR_TX_MASK0,       "TX_MASK0"),
94     DEFBASIC(AR_TX_MASK1,       "TX_MASK1"),
95     DEFVOID(AR_CLR_TMASK,       "CLR_TMASK"),
96     DEFBASIC(AR_TRIG_LEV,       "TRIG_LEV"),
97     DEFBASICfmt(AR_DIAG_SW,     "DIAG_SW",      AR_DIAG_SW_BITS),
98     DEFBASIC(AR_TSF_L32,        "TSF_L32"),
99     DEFBASIC(AR_TSF_U32,        "TSF_U32"),
100     DEFBASIC(AR_LAST_TSTP,      "LAST_TST"),
101     DEFBASIC(AR_RETRY_CNT,      "RETRYCNT"),
102     DEFBASIC(AR_BACKOFF,        "BACKOFF"),
103     DEFBASIC(AR_NAV,            "NAV"),
104     DEFBASIC(AR_RTS_OK,         "RTS_OK"),
105     DEFBASIC(AR_RTS_FAIL,       "RTS_FAIL"),
106     DEFBASIC(AR_ACK_FAIL,       "ACK_FAIL"),
107     DEFBASIC(AR_FCS_FAIL,       "FCS_FAIL"),
108     DEFBASIC(AR_BEACON_CNT,     "BEAC_CNT"),
109
110     DEFVOIDfmt(AR_PHY_FRCTL,    "PHY_FRCTL",    AR_PHY_FRCTL_BITS),
111     DEFVOIDfmt(AR_PHY_AGC,      "PHY_AGC",      AR_PHY_AGC_BITS),
112     DEFVOID(AR_PHY_CHIPID,      "PHY_CHIPID"),
113     DEFVOIDfmt(AR_PHY_ACTIVE,   "PHY_ACTIVE",   AR_PHY_ACTIVE_BITS),
114     DEFVOIDfmt(AR_PHY_AGCCTL,   "PHY_AGCCTL",   AR_PHY_AGCCTL_BITS),
115 };
116
117 static __constructor void
118 ar5210_ctor(void)
119 {
120 #define MAC5210 SREV(1,0), SREV(2,0)
121         register_regs(ar5210regs, N(ar5210regs), MAC5210, PHYANY);
122         register_keycache(64, MAC5210, PHYANY);
123
124         register_range(0x9800, 0x9840, DUMP_BASEBAND, MAC5210, PHYANY);
125 }