GNU Linux-libre 4.9.304-gnu1
[releases.git] / drivers / staging / rtl8188eu / include / rtw_eeprom.h
1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms of version 2 of the GNU General Public License as
7  * published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12  * more details.
13  *
14  ******************************************************************************/
15 #ifndef __RTW_EEPROM_H__
16 #define __RTW_EEPROM_H__
17
18 #include <osdep_service.h>
19 #include <drv_types.h>
20
21 #define RTL8712_EEPROM_ID               0x8712
22
23 #define HWSET_MAX_SIZE_512              512
24 #define EEPROM_MAX_SIZE                 HWSET_MAX_SIZE_512
25
26 #define CLOCK_RATE                      50      /* 100us */
27
28 /*  EEPROM opcodes */
29 #define EEPROM_READ_OPCODE              06
30 #define EEPROM_WRITE_OPCODE             05
31 #define EEPROM_ERASE_OPCODE             07
32 #define EEPROM_EWEN_OPCODE              19      /*  Erase/write enable */
33 #define EEPROM_EWDS_OPCODE              16      /*  Erase/write disable */
34
35 /* Country codes */
36 #define USA                             0x555320
37 #define EUROPE                          0x1 /* temp, should be provided later */
38 #define JAPAN                           0x2 /* temp, should be provided later */
39
40 #define EEPROM_CID_DEFAULT              0x0
41 #define EEPROM_CID_ALPHA                0x1
42 #define EEPROM_CID_Senao                0x3
43 #define EEPROM_CID_NetCore              0x5
44 #define EEPROM_CID_CAMEO                0X8
45 #define EEPROM_CID_SITECOM              0x9
46 #define EEPROM_CID_COREGA               0xB
47 #define EEPROM_CID_EDIMAX_BELK          0xC
48 #define EEPROM_CID_SERCOMM_BELK         0xE
49 #define EEPROM_CID_CAMEO1               0xF
50 #define EEPROM_CID_WNC_COREGA           0x12
51 #define EEPROM_CID_CLEVO                0x13
52 #define EEPROM_CID_WHQL                 0xFE
53
54 /*  Customer ID, note that: */
55 /*  This variable is initiailzed through EEPROM or registry, */
56 /*  however, its definition may be different with that in EEPROM for */
57 /*  EEPROM size consideration. So, we have to perform proper translation
58  *  between them. */
59 /*  Besides, CustomerID of registry has precedence of that of EEPROM. */
60 /*  defined below. 060703, by rcnjko. */
61 enum RT_CUSTOMER_ID {
62         RT_CID_DEFAULT = 0,
63         RT_CID_8187_ALPHA0 = 1,
64         RT_CID_8187_SERCOMM_PS = 2,
65         RT_CID_8187_HW_LED = 3,
66         RT_CID_8187_NETGEAR = 4,
67         RT_CID_WHQL = 5,
68         RT_CID_819x_CAMEO  = 6,
69         RT_CID_819x_RUNTOP = 7,
70         RT_CID_819x_Senao = 8,
71         RT_CID_TOSHIBA = 9,     /*  Merge by Jacken, 2008/01/31. */
72         RT_CID_819x_Netcore = 10,
73         RT_CID_Nettronix = 11,
74         RT_CID_DLINK = 12,
75         RT_CID_PRONET = 13,
76         RT_CID_COREGA = 14,
77         RT_CID_CHINA_MOBILE = 15,
78         RT_CID_819x_ALPHA = 16,
79         RT_CID_819x_Sitecom = 17,
80         RT_CID_CCX = 18, /*  It's set under CCX logo test and isn't demanded
81                           * for CCX functions, but for test behavior like retry
82                           * limit and tx report. By Bruce, 2009-02-17. */
83         RT_CID_819x_Lenovo = 19,
84         RT_CID_819x_QMI = 20,
85         RT_CID_819x_Edimax_Belkin = 21,
86         RT_CID_819x_Sercomm_Belkin = 22,
87         RT_CID_819x_CAMEO1 = 23,
88         RT_CID_819x_MSI = 24,
89         RT_CID_819x_Acer = 25,
90         RT_CID_819x_AzWave_ASUS = 26,
91         RT_CID_819x_AzWave = 27, /*  For AzWave in PCIe,i
92                                   * The ID is AzWave use and not only Asus */
93         RT_CID_819x_HP = 28,
94         RT_CID_819x_WNC_COREGA = 29,
95         RT_CID_819x_Arcadyan_Belkin = 30,
96         RT_CID_819x_SAMSUNG = 31,
97         RT_CID_819x_CLEVO = 32,
98         RT_CID_819x_DELL = 33,
99         RT_CID_819x_PRONETS = 34,
100         RT_CID_819x_Edimax_ASUS = 35,
101         RT_CID_819x_CAMEO_NETGEAR = 36,
102         RT_CID_PLANEX = 37,
103         RT_CID_CC_C = 38,
104         RT_CID_819x_Xavi = 39,
105         RT_CID_819x_FUNAI_TV = 40,
106         RT_CID_819x_ALPHA_WD = 41,
107 };
108
109 struct eeprom_priv {
110         u8              bautoload_fail_flag;
111         u8              bloadfile_fail_flag;
112         u8              bloadmac_fail_flag;
113         u8              mac_addr[6];    /* PermanentAddress */
114         u16             channel_plan;
115         u8              EepromOrEfuse;
116         u8              efuse_eeprom_data[HWSET_MAX_SIZE_512];
117 };
118
119 void eeprom_write16(struct adapter *padapter, u16 reg, u16 data);
120 u16 eeprom_read16(struct adapter *padapter, u16 reg);
121 void read_eeprom_content(struct adapter *padapter);
122 void eeprom_read_sz(struct adapter *adapt, u16 reg, u8 *data, u32 sz);
123 void read_eeprom_content_by_attrib(struct adapter *padapter);
124
125 #endif  /* __RTL871X_EEPROM_H__ */