xref: /freebsd/sys/dev/rtwn/rtl8192c/r92c_rom_defs.h (revision 2ff63af9b88c7413b7d71715b5532625752a248e)
1*7453645fSAndriy Voskoboinyk /*-
2*7453645fSAndriy Voskoboinyk  * Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
3*7453645fSAndriy Voskoboinyk  * Copyright (c) 2016 Andriy Voskoboinyk <avos@FreeBSD.org>
4*7453645fSAndriy Voskoboinyk  *
5*7453645fSAndriy Voskoboinyk  * Permission to use, copy, modify, and distribute this software for any
6*7453645fSAndriy Voskoboinyk  * purpose with or without fee is hereby granted, provided that the above
7*7453645fSAndriy Voskoboinyk  * copyright notice and this permission notice appear in all copies.
8*7453645fSAndriy Voskoboinyk  *
9*7453645fSAndriy Voskoboinyk  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10*7453645fSAndriy Voskoboinyk  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11*7453645fSAndriy Voskoboinyk  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12*7453645fSAndriy Voskoboinyk  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13*7453645fSAndriy Voskoboinyk  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14*7453645fSAndriy Voskoboinyk  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15*7453645fSAndriy Voskoboinyk  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16*7453645fSAndriy Voskoboinyk  *
17*7453645fSAndriy Voskoboinyk  * $OpenBSD: if_urtwnreg.h,v 1.3 2010/11/16 18:02:59 damien Exp $
18*7453645fSAndriy Voskoboinyk  */
19*7453645fSAndriy Voskoboinyk 
20*7453645fSAndriy Voskoboinyk #ifndef R92C_ROM_DEFS_H
21*7453645fSAndriy Voskoboinyk #define R92C_ROM_DEFS_H
22*7453645fSAndriy Voskoboinyk 
23*7453645fSAndriy Voskoboinyk #define R92C_MAX_CHAINS			2
24*7453645fSAndriy Voskoboinyk #define R92C_GROUP_2G			3
25*7453645fSAndriy Voskoboinyk 
26*7453645fSAndriy Voskoboinyk #define R92C_EFUSE_MAX_LEN		512
27*7453645fSAndriy Voskoboinyk #define R92C_EFUSE_MAP_LEN		128
28*7453645fSAndriy Voskoboinyk 
29*7453645fSAndriy Voskoboinyk /*
30*7453645fSAndriy Voskoboinyk  * Some generic rom parsing macros.
31*7453645fSAndriy Voskoboinyk  */
32*7453645fSAndriy Voskoboinyk #define RTWN_GET_ROM_VAR(var, def)	(((var) != 0xff) ? (var) : (def))
33*7453645fSAndriy Voskoboinyk #define RTWN_SIGN4TO8(val)		(((val) & 0x08) ? (val) | 0xf0 : (val))
34*7453645fSAndriy Voskoboinyk 
35*7453645fSAndriy Voskoboinyk #define LOW_PART_M	0x0f
36*7453645fSAndriy Voskoboinyk #define LOW_PART_S	0
37*7453645fSAndriy Voskoboinyk #define HIGH_PART_M	0xf0
38*7453645fSAndriy Voskoboinyk #define HIGH_PART_S	4
39*7453645fSAndriy Voskoboinyk 
40*7453645fSAndriy Voskoboinyk /* Bits for rf_board_opt (rf_opt1) field. */
41*7453645fSAndriy Voskoboinyk #define R92C_ROM_RF1_REGULATORY_M	0x07
42*7453645fSAndriy Voskoboinyk #define R92C_ROM_RF1_REGULATORY_S	0
43*7453645fSAndriy Voskoboinyk #define R92C_ROM_RF1_BOARD_TYPE_M	0xe0
44*7453645fSAndriy Voskoboinyk #define R92C_ROM_RF1_BOARD_TYPE_S	5
45*7453645fSAndriy Voskoboinyk 
46*7453645fSAndriy Voskoboinyk /* Generic board types. */
47*7453645fSAndriy Voskoboinyk #define R92C_BOARD_TYPE_DONGLE		0
48*7453645fSAndriy Voskoboinyk #define R92C_BOARD_TYPE_HIGHPA		1
49*7453645fSAndriy Voskoboinyk #define R92C_BOARD_TYPE_MINICARD	2
50*7453645fSAndriy Voskoboinyk #define R92C_BOARD_TYPE_SOLO		3
51*7453645fSAndriy Voskoboinyk #define R92C_BOARD_TYPE_COMBO		4
52*7453645fSAndriy Voskoboinyk 
53*7453645fSAndriy Voskoboinyk /* Bits for channel_plan field. */
54*7453645fSAndriy Voskoboinyk #define R92C_CHANNEL_PLAN_BY_HW		0x80
55*7453645fSAndriy Voskoboinyk 
56*7453645fSAndriy Voskoboinyk #endif	/* R92C_ROM_DEFS_H */
57