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