158391efdSNathan Chancellor /* SPDX-License-Identifier: GPL-2.0 */
2554c0a3aSHans de Goede /******************************************************************************
3554c0a3aSHans de Goede  *
4554c0a3aSHans de Goede  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5554c0a3aSHans de Goede  *
6554c0a3aSHans de Goede  ******************************************************************************/
7554c0a3aSHans de Goede #ifndef __RTW_EEPROM_H__
8554c0a3aSHans de Goede #define __RTW_EEPROM_H__
9554c0a3aSHans de Goede 
10554c0a3aSHans de Goede 
11554c0a3aSHans de Goede #define	RTL8712_EEPROM_ID			0x8712
12554c0a3aSHans de Goede /* define	EEPROM_MAX_SIZE			256 */
13554c0a3aSHans de Goede 
14554c0a3aSHans de Goede #define	HWSET_MAX_SIZE_128		128
15554c0a3aSHans de Goede #define	HWSET_MAX_SIZE_256		256
16554c0a3aSHans de Goede #define	HWSET_MAX_SIZE_512		512
17554c0a3aSHans de Goede 
18554c0a3aSHans de Goede #define	EEPROM_MAX_SIZE			HWSET_MAX_SIZE_512
19554c0a3aSHans de Goede 
20554c0a3aSHans de Goede #define	CLOCK_RATE					50			/* 100us */
21554c0a3aSHans de Goede 
22554c0a3aSHans de Goede /*  EEPROM opcodes */
23554c0a3aSHans de Goede #define EEPROM_READ_OPCODE		06
24554c0a3aSHans de Goede #define EEPROM_WRITE_OPCODE		05
25554c0a3aSHans de Goede #define EEPROM_ERASE_OPCODE		07
26554c0a3aSHans de Goede #define EEPROM_EWEN_OPCODE		19      /*  Erase/write enable */
27554c0a3aSHans de Goede #define EEPROM_EWDS_OPCODE		16      /*  Erase/write disable */
28554c0a3aSHans de Goede 
29554c0a3aSHans de Goede /* Country codes */
30554c0a3aSHans de Goede #define USA							0x555320
31554c0a3aSHans de Goede #define EUROPE						0x1 /* temp, should be provided later */
32554c0a3aSHans de Goede #define JAPAN						0x2 /* temp, should be provided later */
33554c0a3aSHans de Goede 
34554c0a3aSHans de Goede #define eeprom_cis0_sz	17
35554c0a3aSHans de Goede #define eeprom_cis1_sz	50
36554c0a3aSHans de Goede 
37554c0a3aSHans de Goede /*  */
38554c0a3aSHans de Goede /*  Customer ID, note that: */
39554c0a3aSHans de Goede /*  This variable is initiailzed through EEPROM or registry, */
40554c0a3aSHans de Goede /*  however, its definition may be different with that in EEPROM for */
41554c0a3aSHans de Goede /*  EEPROM size consideration. So, we have to perform proper translation between them. */
42554c0a3aSHans de Goede /*  Besides, CustomerID of registry has precedence of that of EEPROM. */
43554c0a3aSHans de Goede /*  defined below. 060703, by rcnjko. */
44554c0a3aSHans de Goede /*  */
45*463cc86eSMarco Cesati enum {
46554c0a3aSHans de Goede 	RT_CID_DEFAULT = 0,
47554c0a3aSHans de Goede 	RT_CID_8187_ALPHA0 = 1,
48554c0a3aSHans de Goede 	RT_CID_8187_SERCOMM_PS = 2,
49554c0a3aSHans de Goede 	RT_CID_8187_HW_LED = 3,
50554c0a3aSHans de Goede 	RT_CID_8187_NETGEAR = 4,
51554c0a3aSHans de Goede 	RT_CID_WHQL = 5,
52554c0a3aSHans de Goede 	RT_CID_819x_CAMEO  = 6,
53554c0a3aSHans de Goede 	RT_CID_819x_RUNTOP = 7,
54554c0a3aSHans de Goede 	RT_CID_819x_Senao = 8,
55554c0a3aSHans de Goede 	RT_CID_TOSHIBA = 9,	/*  Merge by Jacken, 2008/01/31. */
56554c0a3aSHans de Goede 	RT_CID_819x_Netcore = 10,
57554c0a3aSHans de Goede 	RT_CID_Nettronix = 11,
58554c0a3aSHans de Goede 	RT_CID_DLINK = 12,
59554c0a3aSHans de Goede 	RT_CID_PRONET = 13,
60554c0a3aSHans de Goede 	RT_CID_COREGA = 14,
61554c0a3aSHans de Goede 	RT_CID_CHINA_MOBILE = 15,
62554c0a3aSHans de Goede 	RT_CID_819x_ALPHA = 16,
63554c0a3aSHans de Goede 	RT_CID_819x_Sitecom = 17,
64554c0a3aSHans de Goede 	RT_CID_CCX = 18, /*  It's set under CCX logo test and isn't demanded for CCX functions, but for test behavior like retry limit and tx report. By Bruce, 2009-02-17. */
65554c0a3aSHans de Goede 	RT_CID_819x_Lenovo = 19,
66554c0a3aSHans de Goede 	RT_CID_819x_QMI = 20,
67554c0a3aSHans de Goede 	RT_CID_819x_Edimax_Belkin = 21,
68554c0a3aSHans de Goede 	RT_CID_819x_Sercomm_Belkin = 22,
69554c0a3aSHans de Goede 	RT_CID_819x_CAMEO1 = 23,
70554c0a3aSHans de Goede 	RT_CID_819x_MSI = 24,
71554c0a3aSHans de Goede 	RT_CID_819x_Acer = 25,
72554c0a3aSHans de Goede 	RT_CID_819x_AzWave_ASUS = 26,
73554c0a3aSHans de Goede 	RT_CID_819x_AzWave = 27, /*  For AzWave in PCIe, The ID is AzWave use and not only Asus */
74554c0a3aSHans de Goede 	RT_CID_819x_HP = 28,
75554c0a3aSHans de Goede 	RT_CID_819x_WNC_COREGA = 29,
76554c0a3aSHans de Goede 	RT_CID_819x_Arcadyan_Belkin = 30,
77554c0a3aSHans de Goede 	RT_CID_819x_SAMSUNG = 31,
78554c0a3aSHans de Goede 	RT_CID_819x_CLEVO = 32,
79554c0a3aSHans de Goede 	RT_CID_819x_DELL = 33,
80554c0a3aSHans de Goede 	RT_CID_819x_PRONETS = 34,
81554c0a3aSHans de Goede 	RT_CID_819x_Edimax_ASUS = 35,
82554c0a3aSHans de Goede 	RT_CID_NETGEAR = 36,
83554c0a3aSHans de Goede 	RT_CID_PLANEX = 37,
84554c0a3aSHans de Goede 	RT_CID_CC_C = 38,
85554c0a3aSHans de Goede 	RT_CID_819x_Xavi = 39,
86554c0a3aSHans de Goede 	RT_CID_LENOVO_CHINA = 40,
87554c0a3aSHans de Goede 	RT_CID_INTEL_CHINA = 41,
88554c0a3aSHans de Goede 	RT_CID_TPLINK_HPWR = 42,
89554c0a3aSHans de Goede 	RT_CID_819x_Sercomm_Netgear = 43,
90554c0a3aSHans de Goede 	RT_CID_819x_ALPHA_Dlink = 44,/* add by ylb 20121012 for customer led for alpha */
91554c0a3aSHans de Goede 	RT_CID_WNC_NEC = 45,/* add by page for NEC */
92554c0a3aSHans de Goede 	RT_CID_DNI_BUFFALO = 46,/* add by page for NEC */
93e1d700a5SMarco Cesati };
94554c0a3aSHans de Goede 
95b311b98dSFox Chen struct eeprom_priv {
96554c0a3aSHans de Goede 	u8 bautoload_fail_flag;
97554c0a3aSHans de Goede 	u8 bloadfile_fail_flag;
98554c0a3aSHans de Goede 	u8 bloadmac_fail_flag;
99554c0a3aSHans de Goede 	u8 EepromOrEfuse;
100554c0a3aSHans de Goede 
101554c0a3aSHans de Goede 	u8 mac_addr[6];	/* PermanentAddress */
102554c0a3aSHans de Goede 
103554c0a3aSHans de Goede 	u16 	channel_plan;
104554c0a3aSHans de Goede 	u16 	CustomerID;
105554c0a3aSHans de Goede 
106554c0a3aSHans de Goede 	u8 efuse_eeprom_data[EEPROM_MAX_SIZE]; /* 92C:256bytes, 88E:512bytes, we use union set (512bytes) */
107554c0a3aSHans de Goede 	u8 adjuseVoltageVal;
108554c0a3aSHans de Goede 
109554c0a3aSHans de Goede 	u8 EEPROMRFGainOffset;
110554c0a3aSHans de Goede 	u8 EEPROMRFGainVal;
111554c0a3aSHans de Goede 
112554c0a3aSHans de Goede 	u8 sdio_setting;
113554c0a3aSHans de Goede 	u32 	ocr;
114554c0a3aSHans de Goede 	u8 cis0[eeprom_cis0_sz];
115554c0a3aSHans de Goede 	u8 cis1[eeprom_cis1_sz];
116554c0a3aSHans de Goede };
117554c0a3aSHans de Goede 
118554c0a3aSHans de Goede #endif  /* __RTL871X_EEPROM_H__ */
119