xref: /freebsd/tools/tools/ath/athalq/ar5416_ds.c (revision 1d386b48)
1d8a32b73SAdrian Chadd /*
2d8a32b73SAdrian Chadd  * Copyright (c) 2012 Adrian Chadd <adrian@FreeBSD.org>
3d8a32b73SAdrian Chadd  * All Rights Reserved.
4d8a32b73SAdrian Chadd  *
5d8a32b73SAdrian Chadd  * Permission to use, copy, modify, and/or distribute this software for any
6d8a32b73SAdrian Chadd  * purpose with or without fee is hereby granted, provided that the above
7d8a32b73SAdrian Chadd  * copyright notice and this permission notice appear in all copies.
8d8a32b73SAdrian Chadd  *
9d8a32b73SAdrian Chadd  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10d8a32b73SAdrian Chadd  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11d8a32b73SAdrian Chadd  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12d8a32b73SAdrian Chadd  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13d8a32b73SAdrian Chadd  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14d8a32b73SAdrian Chadd  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15d8a32b73SAdrian Chadd  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16d8a32b73SAdrian Chadd  */
17d8a32b73SAdrian Chadd 
18d8a32b73SAdrian Chadd #include <sys/cdefs.h>
19d8a32b73SAdrian Chadd #include <stdio.h>
20d8a32b73SAdrian Chadd #include <stdlib.h>
21d8a32b73SAdrian Chadd #include <unistd.h>
22d8a32b73SAdrian Chadd #include <fcntl.h>
23d8a32b73SAdrian Chadd #include <errno.h>
24d8a32b73SAdrian Chadd #include <string.h>
25d8a32b73SAdrian Chadd 
26d8a32b73SAdrian Chadd #include <sys/types.h>
27d8a32b73SAdrian Chadd #include <sys/alq.h>
28d8a32b73SAdrian Chadd #include <sys/endian.h>
29d8a32b73SAdrian Chadd 
30d8a32b73SAdrian Chadd #include <dev/ath/if_ath_alq.h>
31d8a32b73SAdrian Chadd #include <dev/ath/ath_hal/ar5416/ar5416desc.h>
32d8a32b73SAdrian Chadd 
33d8a32b73SAdrian Chadd #include "ar5416_ds.h"
34d8a32b73SAdrian Chadd 
35d8a32b73SAdrian Chadd #define	MS(_v, _f)	( ((_v) & (_f)) >> _f##_S )
36d8a32b73SAdrian Chadd #define	MF(_v, _f) ( !! ((_v) & (_f)))
37d8a32b73SAdrian Chadd 
38d8a32b73SAdrian Chadd static void
ar5416_decode_txstatus(struct if_ath_alq_payload * a)39d8a32b73SAdrian Chadd ar5416_decode_txstatus(struct if_ath_alq_payload *a)
40d8a32b73SAdrian Chadd {
41d8a32b73SAdrian Chadd 	struct ar5416_desc txs;
42d8a32b73SAdrian Chadd 
43d8a32b73SAdrian Chadd 	/* XXX assumes txs is smaller than PAYLOAD_LEN! */
44d8a32b73SAdrian Chadd 	memcpy(&txs, &a->payload, sizeof(struct ar5416_desc));
45d8a32b73SAdrian Chadd 
46fec3d03dSAdrian Chadd 	printf("[%u.%06u] [%llu] TXSTATUS: TxDone=%d, FrmOk=%d, filt=%d, TS=0x%08x\n",
470a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_sec),
480a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_usec),
493301ff56SAdrian Chadd 	    (unsigned long long) be64toh(a->hdr.threadid),
503301ff56SAdrian Chadd 	    MF(txs.u.tx.status[9], AR_TxDone),
51fec3d03dSAdrian Chadd 	    MF(txs.u.tx.status[1], AR_FrmXmitOK),
52fec3d03dSAdrian Chadd 	    MF(txs.u.tx.status[1], AR_Filtered),
533301ff56SAdrian Chadd 	    txs.u.tx.status[2]);
54d8a32b73SAdrian Chadd 
55d8a32b73SAdrian Chadd 	/* ds_txstatus0 */
56fec3d03dSAdrian Chadd 	printf("    RX RSSI 0 [%d %d %d]",
57d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[0], AR_TxRSSIAnt00),
58d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[0], AR_TxRSSIAnt01),
59d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[0], AR_TxRSSIAnt02));
60fec3d03dSAdrian Chadd 
61fec3d03dSAdrian Chadd 	/* ds_txstatus5 */
62fec3d03dSAdrian Chadd 	printf(" RX RSSI 1 [%d %d %d] Comb=%d\n",
63fec3d03dSAdrian Chadd 	    MS(txs.u.tx.status[5], AR_TxRSSIAnt10),
64fec3d03dSAdrian Chadd 	    MS(txs.u.tx.status[5], AR_TxRSSIAnt11),
65fec3d03dSAdrian Chadd 	    MS(txs.u.tx.status[5], AR_TxRSSIAnt12),
66fec3d03dSAdrian Chadd 	    MS(txs.u.tx.status[5], AR_TxRSSICombined));
67fec3d03dSAdrian Chadd 
68fec3d03dSAdrian Chadd 	/* ds_txstatus0 */
69fec3d03dSAdrian Chadd 	printf("    BA Valid=%d",
70d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[0], AR_TxBaStatus));
71d8a32b73SAdrian Chadd 
72d8a32b73SAdrian Chadd 	/* ds_txstatus1 */
73fec3d03dSAdrian Chadd 	printf(", Frmok=%d, xretries=%d, fifounderrun=%d, filt=%d\n",
74d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_FrmXmitOK),
75d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_ExcessiveRetries),
76d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_FIFOUnderrun),
77d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_Filtered));
78d8a32b73SAdrian Chadd 	printf("    DelimUnderrun=%d, DataUnderun=%d, DescCfgErr=%d,"
79d8a32b73SAdrian Chadd 	    " TxTimerExceeded=%d\n",
80d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_TxDelimUnderrun),
81d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_TxDataUnderrun),
82d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_DescCfgErr),
83d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[1], AR_TxTimerExpired));
84d8a32b73SAdrian Chadd 
85d8a32b73SAdrian Chadd 	printf("    RTScnt=%d, FailCnt=%d, VRetryCnt=%d\n",
86d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[1], AR_RTSFailCnt),
87d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[1], AR_DataFailCnt),
88d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[1], AR_VirtRetryCnt));
89d8a32b73SAdrian Chadd 
90d8a32b73SAdrian Chadd 	/* ds_txstatus2 */
91fec3d03dSAdrian Chadd 	printf("    TxTimestamp=0x%08x", txs.u.tx.status[2]);
92d8a32b73SAdrian Chadd 
93d8a32b73SAdrian Chadd 	/* ds_txstatus3 */
94d8a32b73SAdrian Chadd 	/* ds_txstatus4 */
95fec3d03dSAdrian Chadd 	printf(", BALow=0x%08x", txs.u.tx.status[3]);
96fec3d03dSAdrian Chadd 	printf(", BAHigh=0x%08x\n", txs.u.tx.status[4]);
97d8a32b73SAdrian Chadd 
98d8a32b73SAdrian Chadd 
99d8a32b73SAdrian Chadd 	/* ds_txstatus6 */
100d8a32b73SAdrian Chadd 	/* ds_txstatus7 */
101d8a32b73SAdrian Chadd 	/* ds_txstatus8 */
102d8a32b73SAdrian Chadd 	printf("    TxEVM[0]=0x%08x, TxEVM[1]=0x%08x, TxEVM[2]=0x%08x\n",
103d8a32b73SAdrian Chadd 	    txs.u.tx.status[6],
104d8a32b73SAdrian Chadd 	    txs.u.tx.status[7],
105d8a32b73SAdrian Chadd 	    txs.u.tx.status[8]);
106d8a32b73SAdrian Chadd 
107d8a32b73SAdrian Chadd 	/* ds_txstatus9 */
108d8a32b73SAdrian Chadd 	printf("    TxDone=%d, SeqNum=0x%04x, TxOpExceeded=%d, FinalTsIdx=%d\n",
109d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[9], AR_TxDone),
110d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[9], AR_SeqNum),
111d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[9], AR_TxOpExceeded),
112d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[9], AR_FinalTxIdx));
113d8a32b73SAdrian Chadd 	printf("    PowerMgmt=%d, TxTid=%d\n",
114d8a32b73SAdrian Chadd 	    MF(txs.u.tx.status[9], AR_PowerMgmt),
115d8a32b73SAdrian Chadd 	    MS(txs.u.tx.status[9], AR_TxTid));
116d8a32b73SAdrian Chadd 
117d8a32b73SAdrian Chadd 	printf("\n ------\n");
118d8a32b73SAdrian Chadd }
119d8a32b73SAdrian Chadd 
120d8a32b73SAdrian Chadd static void
ar5416_decode_txdesc(struct if_ath_alq_payload * a)121d8a32b73SAdrian Chadd ar5416_decode_txdesc(struct if_ath_alq_payload *a)
122d8a32b73SAdrian Chadd {
123d8a32b73SAdrian Chadd 	struct ar5416_desc txc;
124d8a32b73SAdrian Chadd 
125d8a32b73SAdrian Chadd 	/* XXX assumes txs is smaller than PAYLOAD_LEN! */
126d8a32b73SAdrian Chadd 	memcpy(&txc, &a->payload, sizeof(struct ar5416_desc));
127d8a32b73SAdrian Chadd 
1280a83adddSAdrian Chadd 	printf("[%u.%06u] [%llu] TXD\n",
1290a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_sec),
1300a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_usec),
131d8a32b73SAdrian Chadd 	    (unsigned long long) be64toh(a->hdr.threadid));
132d8a32b73SAdrian Chadd 
133d8a32b73SAdrian Chadd 	printf("  link=0x%08x, data=0x%08x\n",
134d8a32b73SAdrian Chadd 	    txc.ds_link,
135d8a32b73SAdrian Chadd 	    txc.ds_data);
136d8a32b73SAdrian Chadd 
137d8a32b73SAdrian Chadd 	/* ds_ctl0 */
138d8a32b73SAdrian Chadd 	printf("    Frame Len=%d, VMF=%d\n",
139d8a32b73SAdrian Chadd 	     txc.ds_ctl0 & AR_FrameLen,
140d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_VirtMoreFrag));
141d8a32b73SAdrian Chadd 	printf("    TX power0=%d, RtsEna=%d, Veol=%d, ClrDstMask=%d\n",
142d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl0, AR_XmitPower),
143d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_RTSEnable),
144d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_VEOL),
145d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_ClrDestMask));
146d8a32b73SAdrian Chadd 	printf("    TxIntrReq=%d, DestIdxValid=%d, CtsEnable=%d\n",
147d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_TxIntrReq),
148d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_DestIdxValid),
149d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl0, AR_CTSEnable));
150d8a32b73SAdrian Chadd 
151d8a32b73SAdrian Chadd 	/* ds_ctl1 */
152d8a32b73SAdrian Chadd 	printf("    BufLen=%d, TxMore=%d, DestIdx=%d,"
153d8a32b73SAdrian Chadd 	    " FrType=0x%x\n",
154d8a32b73SAdrian Chadd 	    txc.ds_ctl1 & AR_BufLen,
155d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_TxMore),
156d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl1, AR_DestIdx),
157d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl1, AR_FrameType));
158d8a32b73SAdrian Chadd 	printf("    NoAck=%d, InsertTs=%d, CorruptFcs=%d, ExtOnly=%d,"
159d8a32b73SAdrian Chadd 	    " ExtAndCtl=%d\n",
160d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_NoAck),
161d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_InsertTS),
162d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_CorruptFCS),
163d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_ExtOnly),
164d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_ExtAndCtl));
165d8a32b73SAdrian Chadd 	printf("    MoreAggr=%d, IsAggr=%d, MoreRifs=%d\n",
166d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_MoreAggr),
167d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_IsAggr),
168d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl1, AR_MoreRifs));
169d8a32b73SAdrian Chadd 
170d8a32b73SAdrian Chadd 	/* ds_ctl2 */
171d8a32b73SAdrian Chadd 	printf("    DurUpEna=%d, Burstdur=0x%04x\n",
172d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl2, AR_DurUpdateEn),
173d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl2, AR_BurstDur));
174d8a32b73SAdrian Chadd 	printf("    Try0=%d, Try1=%d, Try2=%d, Try3=%d\n",
175d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl2, AR_XmitDataTries0),
176d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl2, AR_XmitDataTries1),
177d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl2, AR_XmitDataTries2),
178d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl2, AR_XmitDataTries3));
179d8a32b73SAdrian Chadd 
180fec3d03dSAdrian Chadd 	/* ds_ctl3, 4 */
181fec3d03dSAdrian Chadd 	printf("    try 0: Rate=0x%02x, PktDur=%d, RTS/CTS ena=%d\n",
182d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl3, AR_XmitRate0),
183d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl4, AR_PacketDur0),
184d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl4, AR_RTSCTSQual0));
185fec3d03dSAdrian Chadd 	printf("    try 1: Rate=0x%02x, PktDur=%d, RTS/CTS ena=%d\n",
186fec3d03dSAdrian Chadd 	    MS(txc.ds_ctl3, AR_XmitRate1),
187d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl4, AR_PacketDur1),
188d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl4, AR_RTSCTSQual1));
189d8a32b73SAdrian Chadd 
190fec3d03dSAdrian Chadd 	/* ds_ctl3, 5 */
191fec3d03dSAdrian Chadd 	printf("    try 2: Rate=0x%02x, PktDur=%d, RTS/CTS ena=%d\n",
192fec3d03dSAdrian Chadd 	    MS(txc.ds_ctl3, AR_XmitRate2),
193d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl5, AR_PacketDur2),
194d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl5, AR_RTSCTSQual2));
195fec3d03dSAdrian Chadd 	printf("    try 3: Rate=0x%02x, PktDur=%d, RTS/CTS ena=%d\n",
196fec3d03dSAdrian Chadd 	    MS(txc.ds_ctl3, AR_XmitRate3),
197d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl5, AR_PacketDur3),
198d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl5, AR_RTSCTSQual3));
199d8a32b73SAdrian Chadd 
200d8a32b73SAdrian Chadd 	/* ds_ctl6 */
201d8a32b73SAdrian Chadd 	printf("    AggrLen=%d, PadDelim=%d, EncrType=%d\n",
202d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl6, AR_AggrLen),
203d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl6, AR_PadDelim),
204d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl6, AR_EncrType));
205d8a32b73SAdrian Chadd 
206d8a32b73SAdrian Chadd 	/* ds_ctl7 */
207d8a32b73SAdrian Chadd 	printf("    try 0: chainMask=0x%x, GI=%d, 2040=%d, STBC=%d\n",
208d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl7, AR_ChainSel0),
209d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_GI0),
210d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_2040_0),
211d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_STBC0));
212d8a32b73SAdrian Chadd 	printf("    try 1: chainMask=0x%x, GI=%d, 2040=%d, STBC=%d\n",
213d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl7, AR_ChainSel1),
214d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_GI1),
215d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_2040_1),
216d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_STBC1));
217d8a32b73SAdrian Chadd 	printf("    try 2: chainMask=0x%x, GI=%d, 2040=%d, STBC=%d\n",
218d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl7, AR_ChainSel2),
219d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_GI2),
220d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_2040_2),
221d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_STBC2));
222d8a32b73SAdrian Chadd 	printf("    try 3: chainMask=0x%x, GI=%d, 2040=%d, STBC=%d\n",
223d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl7, AR_ChainSel3),
224d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_GI3),
225d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_2040_3),
226d8a32b73SAdrian Chadd 	    MF(txc.ds_ctl7, AR_STBC3));
227d8a32b73SAdrian Chadd 
228b5a44455SAdrian Chadd 	printf("    RTSCtsRate=0x%02x\n", MS(txc.ds_ctl7, AR_RTSCTSRate));
229b5a44455SAdrian Chadd 
230d8a32b73SAdrian Chadd 	/* ds_ctl8 */
231d8a32b73SAdrian Chadd 	printf("    try 0: ant=0x%08x\n", txc.ds_ctl8 &  AR_AntCtl0);
232d8a32b73SAdrian Chadd 
233d8a32b73SAdrian Chadd 	/* ds_ctl9 */
234d8a32b73SAdrian Chadd 	printf("    try 1: TxPower=%d, ant=0x%08x\n",
235d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl9, AR_XmitPower1),
236d8a32b73SAdrian Chadd 	    txc.ds_ctl9 & AR_AntCtl1);
237d8a32b73SAdrian Chadd 
238d8a32b73SAdrian Chadd 	/* ds_ctl10 */
239d8a32b73SAdrian Chadd 	printf("    try 2: TxPower=%d, ant=0x%08x\n",
240d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl10, AR_XmitPower2),
241d8a32b73SAdrian Chadd 	    txc.ds_ctl10 & AR_AntCtl2);
242d8a32b73SAdrian Chadd 
243d8a32b73SAdrian Chadd 	/* ds_ctl11 */
244d8a32b73SAdrian Chadd 	printf("    try 3: TxPower=%d, ant=0x%08x\n",
245d8a32b73SAdrian Chadd 	    MS(txc.ds_ctl11, AR_XmitPower3),
246d8a32b73SAdrian Chadd 	    txc.ds_ctl11 & AR_AntCtl3);
247d8a32b73SAdrian Chadd 
248d8a32b73SAdrian Chadd 	printf("\n ------ \n");
249d8a32b73SAdrian Chadd }
250d8a32b73SAdrian Chadd 
251d8a32b73SAdrian Chadd static void
ar5416_decode_rxstatus(struct if_ath_alq_payload * a)252d8a32b73SAdrian Chadd ar5416_decode_rxstatus(struct if_ath_alq_payload *a)
253d8a32b73SAdrian Chadd {
254d8a32b73SAdrian Chadd 	struct ar5416_desc rxs;
255d8a32b73SAdrian Chadd 
256d8a32b73SAdrian Chadd 	/* XXX assumes rxs is smaller than PAYLOAD_LEN! */
257d8a32b73SAdrian Chadd 	memcpy(&rxs, &a->payload, sizeof(struct ar5416_desc));
258d8a32b73SAdrian Chadd 
259fec3d03dSAdrian Chadd 	printf("[%u.%06u] [%llu] RXSTATUS: RxDone=%d, RxRate=0x%02x, TS=0x%08x\n",
2600a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_sec),
2610a83adddSAdrian Chadd 	    (unsigned int) be32toh(a->hdr.tstamp_usec),
2623301ff56SAdrian Chadd 	    (unsigned long long) be64toh(a->hdr.threadid),
2633301ff56SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxDone),
264fec3d03dSAdrian Chadd 	    MS(rxs.ds_rxstatus0, AR_RxRate),
2653301ff56SAdrian Chadd 	    rxs.ds_rxstatus2);
266d8a32b73SAdrian Chadd 
267d8a32b73SAdrian Chadd 	printf("  link=0x%08x, data=0x%08x, ctl0=0x%08x, ctl2=0x%08x\n",
268d8a32b73SAdrian Chadd 	    rxs.ds_link,
269d8a32b73SAdrian Chadd 	    rxs.ds_data,
270d8a32b73SAdrian Chadd 	    rxs.ds_ctl0,
271d8a32b73SAdrian Chadd 	    rxs.ds_ctl1);
272d8a32b73SAdrian Chadd 
273d8a32b73SAdrian Chadd 	/* status0 */
274d8a32b73SAdrian Chadd 	/*
275d8a32b73SAdrian Chadd 	 * XXX TODO: For AR9285, the chain 1 and chain 2 RSSI values
276d8a32b73SAdrian Chadd 	 * acutally contain the RX mixer configuration
277d8a32b73SAdrian Chadd 	 */
278d8a32b73SAdrian Chadd 	printf("  RSSICtl[0]=%d, RSSICtl[1]=%d, RSSICtl[2]=%d\n",
279d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus0, AR_RxRSSIAnt00),
280d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus0, AR_RxRSSIAnt01),
281d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus0, AR_RxRSSIAnt02));
282d8a32b73SAdrian Chadd 
283fec3d03dSAdrian Chadd 	/* status4 */
284fec3d03dSAdrian Chadd 	printf("  RSSIExt[0]=%d, RSSIExt[1]=%d, RSSIExt[2]=%d, RSSIComb=%d\n",
285fec3d03dSAdrian Chadd 	    MS(rxs.ds_rxstatus4, AR_RxRSSIAnt10),
286fec3d03dSAdrian Chadd 	    MS(rxs.ds_rxstatus4, AR_RxRSSIAnt11),
287fec3d03dSAdrian Chadd 	    MS(rxs.ds_rxstatus4, AR_RxRSSIAnt12),
288fec3d03dSAdrian Chadd 	    MS(rxs.ds_rxstatus4, AR_RxRSSICombined));
289fec3d03dSAdrian Chadd 
290fec3d03dSAdrian Chadd 	/* status2 */
291fec3d03dSAdrian Chadd 	printf("  RxTimestamp=0x%08x,", rxs.ds_rxstatus2);
292fec3d03dSAdrian Chadd 
293d8a32b73SAdrian Chadd 	/* status1 */
294d8a32b73SAdrian Chadd 	printf(" DataLen=%d, RxMore=%d, NumDelim=%d\n",
295d8a32b73SAdrian Chadd 	    rxs.ds_rxstatus1 & AR_DataLen,
296d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus1, AR_RxMore),
297d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus1, AR_NumDelim));
298d8a32b73SAdrian Chadd 
299d8a32b73SAdrian Chadd 	/* status3 - RxRate however is for Owl 2.0 */
300d8a32b73SAdrian Chadd 	printf("  GI=%d, 2040=%d, RxRate=0x%02x, DupFrame=%d, RxAnt=0x%08x\n",
301d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus3, AR_GI),
302d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus3, AR_2040),
303d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus0, AR_RxRate),
304d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus3, AR_DupFrame),
305d8a32b73SAdrian Chadd 	    MS(rxs.ds_rxstatus3, AR_RxAntenna));
306d8a32b73SAdrian Chadd 
307d8a32b73SAdrian Chadd 	/* status5 */
308d8a32b73SAdrian Chadd 	/* status6 */
309d8a32b73SAdrian Chadd 	/* status7 */
310d8a32b73SAdrian Chadd 	printf("  RxEvm0=0x%08x, RxEvm1=0x%08x, RxEvm2=0x%08x\n",
311d8a32b73SAdrian Chadd 	    rxs.ds_rxstatus5,
312d8a32b73SAdrian Chadd 	    rxs.ds_rxstatus6,
313d8a32b73SAdrian Chadd 	    rxs.ds_rxstatus7);
314d8a32b73SAdrian Chadd 
315d8a32b73SAdrian Chadd 	/* status8 */
316d8a32b73SAdrian Chadd 	printf("  RxDone=%d, RxFrameOk=%d, CrcErr=%d, DecryptCrcErr=%d\n",
317d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxDone),
318d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxFrameOK),
319d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_CRCErr),
320d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_DecryptCRCErr));
321d8a32b73SAdrian Chadd 	printf("  PhyErr=%d, MichaelErr=%d, PreDelimCRCErr=%d, KeyIdxValid=%d\n",
322d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_PHYErr),
323d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_MichaelErr),
324d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_PreDelimCRCErr),
325d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxKeyIdxValid));
326d8a32b73SAdrian Chadd 
327d8a32b73SAdrian Chadd 	printf("  RxMoreAggr=%d, RxAggr=%d, PostDelimCRCErr=%d, HiRxChain=%d\n",
328d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxMoreAggr),
329d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_RxAggr),
330d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_PostDelimCRCErr),
331d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_HiRxChain));
332fec3d03dSAdrian Chadd 
333fec3d03dSAdrian Chadd 	/* If PHY error, print that out. Otherwise, the key index */
334fec3d03dSAdrian Chadd 	if (MF(rxs.ds_rxstatus8, AR_PHYErr))
335fec3d03dSAdrian Chadd 		printf("  PhyErrCode=0x%02x",
336fec3d03dSAdrian Chadd 		    MS(rxs.ds_rxstatus8, AR_PHYErrCode));
337fec3d03dSAdrian Chadd 	else
338fec3d03dSAdrian Chadd 		printf("  KeyIdx=0x%02x",
339fec3d03dSAdrian Chadd 		    MS(rxs.ds_rxstatus8, AR_KeyIdx));
340fec3d03dSAdrian Chadd 	printf(", KeyMiss=%d\n",
341d8a32b73SAdrian Chadd 	    MF(rxs.ds_rxstatus8, AR_KeyMiss));
342d8a32b73SAdrian Chadd 
343d8a32b73SAdrian Chadd 	printf("\n ------\n");
344d8a32b73SAdrian Chadd }
345d8a32b73SAdrian Chadd 
346d8a32b73SAdrian Chadd void
ar5416_alq_payload(struct if_ath_alq_payload * a)347d8a32b73SAdrian Chadd ar5416_alq_payload(struct if_ath_alq_payload *a)
348d8a32b73SAdrian Chadd {
349d8a32b73SAdrian Chadd 
350d8a32b73SAdrian Chadd 		switch (be16toh(a->hdr.op)) {
351d8a32b73SAdrian Chadd 			case ATH_ALQ_EDMA_TXSTATUS:	/* TXSTATUS */
352d8a32b73SAdrian Chadd 				ar5416_decode_txstatus(a);
353d8a32b73SAdrian Chadd 				break;
354d8a32b73SAdrian Chadd 			case ATH_ALQ_EDMA_RXSTATUS:	/* RXSTATUS */
355d8a32b73SAdrian Chadd 				ar5416_decode_rxstatus(a);
356d8a32b73SAdrian Chadd 				break;
357d8a32b73SAdrian Chadd 			case ATH_ALQ_EDMA_TXDESC:	/* TXDESC */
358d8a32b73SAdrian Chadd 				ar5416_decode_txdesc(a);
359d8a32b73SAdrian Chadd 				break;
360d8a32b73SAdrian Chadd 			default:
3610a83adddSAdrian Chadd 				printf("[%d.%06d] [%lld] op: %d; len %d\n",
3620a83adddSAdrian Chadd 				    be32toh(a->hdr.tstamp_sec),
3630a83adddSAdrian Chadd 				    be32toh(a->hdr.tstamp_usec),
364d8a32b73SAdrian Chadd 				    be64toh(a->hdr.threadid),
365d8a32b73SAdrian Chadd 				    be16toh(a->hdr.op), be16toh(a->hdr.len));
366d8a32b73SAdrian Chadd 		}
367d8a32b73SAdrian Chadd }
368