cregit-Linux how code gets into the kernel

Release 4.7 drivers/staging/rtl8723au/include/rtw_eeprom.h

/******************************************************************************
 *
 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
 * more details.
 *
 ******************************************************************************/
#ifndef __RTW_EEPROM_H__

#define __RTW_EEPROM_H__

#include <osdep_service.h>
#include <drv_types.h>


#define	RTL8712_EEPROM_ID			0x8712
/* define       EEPROM_MAX_SIZE                 256 */


#define	HWSET_MAX_SIZE_512		512

#define	EEPROM_MAX_SIZE			HWSET_MAX_SIZE_512


#define	CLOCK_RATE					50			
/* 100us */

/*  EEPROM opcodes */

#define EEPROM_READ_OPCODE		06

#define EEPROM_WRITE_OPCODE		05

#define EEPROM_ERASE_OPCODE		07

#define EEPROM_EWEN_OPCODE		19      
/*  Erase/write enable */

#define EEPROM_EWDS_OPCODE		16      
/*  Erase/write disable */

/* Country codes */

#define USA							0x555320

#define EUROPE						0x1 
/* temp, should be provided later */

#define JAPAN						0x2 
/* temp, should be provided later */


#define	EEPROM_CID_DEFAULT			0x0

#define	EEPROM_CID_ALPHA				0x1

#define	EEPROM_CID_Senao				0x3

#define	EEPROM_CID_NetCore				0x5

#define	EEPROM_CID_CAMEO				0X8

#define	EEPROM_CID_SITECOM				0x9

#define	EEPROM_CID_COREGA				0xB

#define	EEPROM_CID_EDIMAX_BELKIN		0xC

#define	EEPROM_CID_SERCOMM_BELKIN		0xE

#define	EEPROM_CID_CAMEO1				0xF

#define	EEPROM_CID_WNC_COREGA		0x12

#define	EEPROM_CID_CLEVO				0x13

#define	EEPROM_CID_WHQL				0xFE 
/*  added by chiyoko for dtm, 20090108 */

/*  */
/*  Customer ID, note that: */
/*  This variable is initiailzed through EEPROM or registry, */
/*  however, its definition may be different with that in EEPROM for */
/*  EEPROM size consideration. So, we have to perform proper translation between them. */
/*  Besides, CustomerID of registry has precedence of that of EEPROM. */
/*  defined below. 060703, by rcnjko. */
/*  */

enum rt_customer_id
{
	
RT_CID_DEFAULT = 0,
	
RT_CID_8187_ALPHA0 = 1,
	
RT_CID_8187_SERCOMM_PS = 2,
	
RT_CID_8187_HW_LED = 3,
	
RT_CID_8187_NETGEAR = 4,
	
RT_CID_WHQL = 5,
	
RT_CID_819x_CAMEO  = 6,
	
RT_CID_819x_RUNTOP = 7,
	
RT_CID_819x_Senao = 8,
	
RT_CID_TOSHIBA = 9,	/*  Merge by Jacken, 2008/01/31. */
	
RT_CID_819x_Netcore = 10,
	
RT_CID_Nettronix = 11,
	
RT_CID_DLINK = 12,
	
RT_CID_PRONET = 13,
	
RT_CID_COREGA = 14,
	
RT_CID_CHINA_MOBILE = 15,
	
RT_CID_819x_ALPHA = 16,
	
RT_CID_819x_Sitecom = 17,
	
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. */
	
RT_CID_819x_Lenovo = 19,
	
RT_CID_819x_QMI = 20,
	
RT_CID_819x_Edimax_Belkin = 21,
	
RT_CID_819x_Sercomm_Belkin = 22,
	
RT_CID_819x_CAMEO1 = 23,
	
RT_CID_819x_MSI = 24,
	
RT_CID_819x_Acer = 25,
	
RT_CID_819x_AzWave_ASUS = 26,
	
RT_CID_819x_AzWave = 27, /*  For AzWave in PCIe, The ID is AzWave use and not only Asus */
	
RT_CID_819x_HP = 28,
	
RT_CID_819x_WNC_COREGA = 29,
	
RT_CID_819x_Arcadyan_Belkin = 30,
	
RT_CID_819x_SAMSUNG = 31,
	
RT_CID_819x_CLEVO = 32,
	
RT_CID_819x_DELL = 33,
	
RT_CID_819x_PRONETS = 34,
	
RT_CID_819x_Edimax_ASUS = 35,
	
RT_CID_819x_CAMEO_NETGEAR = 36,
	
RT_CID_PLANEX = 37,
	
RT_CID_CC_C = 38,
	
RT_CID_819x_Xavi = 39,
	
RT_CID_819x_FUNAI_TV = 40,
	
RT_CID_819x_ALPHA_WD=41,
};


struct eeprom_priv {
	
u8		mac_addr[6];	/* PermanentAddress */
	
u8		bautoload_fail_flag;
	
u8		bloadfile_fail_flag;
	
u8		bloadmac_fail_flag;
	/* u8           bempty; */
	/* u8           sys_config; */
	/* u8           config0; */
	
u16		channel_plan;
	/* u8           country_string[3]; */
	/* u8           tx_power_b[15]; */
	/* u8           tx_power_g[15]; */
	/* u8           tx_power_a[201]; */

	
u8		EepromOrEfuse;

	
u8		efuse_eeprom_data[HWSET_MAX_SIZE_512]; /* 92C:256bytes, 88E:512bytes, we use union set (512bytes) */
};

void eeprom_write16(struct rtw_adapter *padapter, u16 reg, u16 data);
u16 eeprom_read16(struct rtw_adapter *padapter, u16 reg);
void read_eeprom_content(struct rtw_adapter *padapter);
void eeprom_read_sz(struct rtw_adapter *padapter, u16 reg, u8 *data, u32 sz);

void read_eeprom_content_by_attrib(struct rtw_adapter *padapter);

#endif  /* __RTL871X_EEPROM_H__ */

Overall Contributors

PersonTokensPropCommitsCommitProp
larry fingerlarry finger40698.31%150.00%
jes sorensenjes sorensen71.69%150.00%
Total413100.00%2100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}