summaryrefslogtreecommitdiffstats
path: root/freebsd/sys/dev/rtwn/rtl8188e/r88e_reg.h
blob: 94b9a66053a117f3035fe6e869885ffb91fbfcc5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/*-
 * Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
 * Copyright (c) 2015-2016 Andriy Voskoboinyk <avos@FreeBSD.org>
 *
 * Permission to use, copy, modify, and distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 *
 * $OpenBSD: if_urtwnreg.h,v 1.3 2010/11/16 18:02:59 damien Exp $
 * $FreeBSD$
 */

#ifndef R88E_REG_H
#define R88E_REG_H

#include <dev/rtwn/rtl8192c/r92c_reg.h>

/*
 * MAC registers.
 */
/* System Configuration. */
#define R88E_BB_PAD_CTRL		0x064
#define R88E_HIMR			0x0b0
#define R88E_HISR			0x0b4
#define R88E_HIMRE			0x0b8
#define R88E_HISRE			0x0bc
#define R88E_XCK_OUT_CTRL	0x07c
/* MAC General Configuration. */
#define R88E_32K_CTRL			0x194
#define R88E_HMEBOX_EXT(idx)		(0x1f0 + (idx) * 4)
/* Protocol Configuration. */
#define R88E_TXPKTBUF_BCNQ1_BDNY	0x457
#define R88E_MACID_NO_LINK		0x484
#define R88E_TX_RPT_CTRL		0x4ec
#define R88E_TX_RPT_MACID_MAX		0x4ed
#define R88E_TX_RPT_TIME		0x4f0
#define R88E_SCH_TXCMD			0x5f8


/* Bits for R88E_HIMR. */
#define R88E_HIMR_ROK		0x00000001	/* receive DMA OK */
#define R88E_HIMR_RDU		0x00000002	/* Rx descriptor unavailable */
#define R88E_HIMR_VODOK		0x00000004	/* AC_VO DMA OK */
#define R88E_HIMR_VIDOK		0x00000008	/* AC_VI DMA OK */
#define R88E_HIMR_BEDOK		0x00000010	/* AC_BE DMA OK */
#define R88E_HIMR_BKDOK		0x00000020	/* AC_BK DMA OK */
#define R88E_HIMR_MGNTDOK	0x00000040	/* management queue DMA OK */
#define R88E_HIMR_HIGHDOK	0x00000080	/* high queue DMA OK */
#define R88E_HIMR_CPWM		0x00000100	/* CPU power mode intr 1 */
#define R88E_HIMR_CPWM2		0x00000200	/* CPU power mode intr 2 */
#define R88E_HIMR_C2HCMD	0x00000400	/* C2H command interrupt */
#define R88E_HIMR_HISR		0x00000800	/* (HISR & HIMR) != 0 */
#define R88E_HIMR_ATIMEND	0x00001000	/* ATIM window end interrupt */
#define R88E_HIMR_HSISR		0x00008000	/* (HSIMR & HSISR) != 0 */
#define R88E_HIMR_BCNDERR	0x00010000	/* beacon queue DMA error */
#define R88E_HIMR_BCNINT	0x00100000	/* beacon DMA interrupt 0 */
#define R88E_HIMR_TSF32		0x01000000	/* TSF 32 bit interrupt */
#define R88E_HIMR_TBDOK		0x02000000	/* beacon transmit OK */
#define R88E_HIMR_TBDER		0x04000000	/* beacon transmit error */
#define R88E_HIMR_GTIMER3	0x08000000	/* GTIMER3 interrupt */
#define R88E_HIMR_GTIMER4	0x10000000	/* GTIMER4 interrupt */
#define R88E_HIMR_PSTIMEOUT	0x20000000	/* powersave timeout */
#define R88E_HIMR_TXRPT		0x40000000	/* Tx report interrupt */

/* Bits for R88E_HIMRE.*/
#define R88E_HIMRE_RXFOVW	0x00000100	/* receive FIFO overflow */
#define R88E_HIMRE_TXFOVW	0x00000200	/* transmit FIFO overflow */
#define R88E_HIMRE_RXERR	0x00000400	/* receive error */
#define R88E_HIMRE_TXERR	0x00000800	/* transmit error */
#define R88E_HIMRE_BCNDOK1	0x00004000	/* beacon queue DMA OK (1) */
#define R88E_HIMRE_BCNDOK2	0x00008000	/* beacon queue DMA OK (2) */
#define R88E_HIMRE_BCNDOK3	0x00010000	/* beacon queue DMA OK (3) */
#define R88E_HIMRE_BCNDOK4	0x00020000	/* beacon queue DMA OK (4) */
#define R88E_HIMRE_BCNDOK5	0x00040000	/* beacon queue DMA OK (5) */
#define R88E_HIMRE_BCNDOK6	0x00080000	/* beacon queue DMA OK (6) */
#define R88E_HIMRE_BCNDOK7	0x00100000	/* beacon queue DMA OK (7) */
#define R88E_HIMRE_BCNDMAINT1	0x00200000	/* beacon DMA interrupt 1 */
#define R88E_HIMRE_BCNDMAINT2	0x00400000	/* beacon DMA interrupt 2 */
#define R88E_HIMRE_BCNDMAINT3	0x00800000	/* beacon DMA interrupt 3 */
#define R88E_HIMRE_BCNDMAINT4	0x01000000	/* beacon DMA interrupt 4 */
#define R88E_HIMRE_BCNDMAINT5	0x02000000	/* beacon DMA interrupt 5 */
#define R88E_HIMRE_BCNDMAINT6	0x04000000	/* beacon DMA interrupt 6 */
#define R88E_HIMRE_BCNDMAINT7	0x08000000	/* beacon DMA interrupt 7 */

/* Bits for R88E_TX_RPT_CTRL. */
#define R88E_TX_RPT1_ENA		0x01
#define R88E_TX_RPT2_ENA		0x02

/* Bits for R92C_MBID_NUM. */
#define R88E_MBID_TXBCN_RPT(id)		(0x08 << (id))

/* Bits for R92C_SECCFG. */
#define R88E_SECCFG_CHK_KEYID	0x0100


/*
 * Baseband registers.
 */
/* Bits for R92C_LSSI_PARAM(i). */
#define R88E_LSSI_PARAM_ADDR_M	0x0ff00000
#define R88E_LSSI_PARAM_ADDR_S	20


/*
 * RF (6052) registers.
 */
#define R88E_RF_T_METER		0x42
#define R88E_RF_WE_LUT		0xef

/* Bits for R92C_RF_CHNLBW. */
#define R88E_RF_CHNLBW_BW20	0x00c00

/* Bits for R88E_RF_T_METER. */
#define R88E_RF_T_METER_VAL_M	0x0fc00
#define R88E_RF_T_METER_VAL_S	10
#define R88E_RF_T_METER_START	0x30000

/* Bits for R88E_XCK_OUT_CTRL. */
#define R88E_XCK_OUT_CTRL_EN	1

#endif	/* R88E_REG_H */