mirror of
https://github.com/gnab/rtl8812au
synced 2025-01-08 17:46:23 +00:00
145 lines
4.4 KiB
C
145 lines
4.4 KiB
C
/******************************************************************************
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
|
*
|
|
*
|
|
******************************************************************************/
|
|
#ifndef __RTL8192C_SPEC_H__
|
|
#define __RTL8192C_SPEC_H__
|
|
|
|
#include <drv_conf.h>
|
|
|
|
//============================================================
|
|
// 8192C Regsiter offset definition
|
|
//============================================================
|
|
|
|
|
|
//============================================================
|
|
//
|
|
//============================================================
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0000h ~ 0x00FFh System Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
#define REG_HMEBOX_EXT_0 0x0088
|
|
#define REG_HMEBOX_EXT_1 0x008A
|
|
#define REG_HMEBOX_EXT_2 0x008C
|
|
#define REG_HMEBOX_EXT_3 0x008E
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0100h ~ 0x01FFh MACTOP General Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0200h ~ 0x027Fh TXDMA Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0280h ~ 0x02FFh RXDMA Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0300h ~ 0x03FFh PCIe
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0400h ~ 0x047Fh Protocol Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0500h ~ 0x05FFh EDCA Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// 0x0600h ~ 0x07FFh WMAC Configuration
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
|
|
//-----------------------------------------------------
|
|
//
|
|
// Redifine register definition for compatibility
|
|
//
|
|
//-----------------------------------------------------
|
|
|
|
// TODO: use these definition when using REG_xxx naming rule.
|
|
// NOTE: DO NOT Remove these definition. Use later.
|
|
|
|
#ifdef CONFIG_PCI_HCI
|
|
#define IMR_RX_MASK (IMR_ROK|IMR_RDU|IMR_RXFOVW)
|
|
#define IMR_TX_MASK (IMR_VODOK|IMR_VIDOK|IMR_BEDOK|IMR_BKDOK|IMR_MGNTDOK|IMR_HIGHDOK|IMR_BDOK)
|
|
|
|
#define RT_IBSS_INT_MASKS (IMR_BcnInt | IMR_TBDOK | IMR_TBDER)
|
|
#define RT_AC_INT_MASKS (IMR_VIDOK | IMR_VODOK | IMR_BEDOK|IMR_BKDOK)
|
|
#define RT_BSS_INT_MASKS (RT_IBSS_INT_MASKS)
|
|
#endif
|
|
|
|
//----------------------------------------------------------------------------
|
|
// 8192C EEPROM/EFUSE share register definition.
|
|
//----------------------------------------------------------------------------
|
|
|
|
#ifdef CONFIG_PCI_HCI
|
|
//
|
|
// Interface type.
|
|
//
|
|
#endif
|
|
|
|
#ifdef CONFIG_USB_HCI
|
|
|
|
//should be renamed and moved to another file
|
|
typedef enum _BOARD_TYPE_8192CUSB{
|
|
BOARD_USB_DONGLE = 0, // USB dongle
|
|
BOARD_USB_High_PA = 1, // USB dongle with high power PA
|
|
BOARD_MINICARD = 2, // Minicard
|
|
BOARD_USB_SOLO = 3, // USB solo-Slim module
|
|
BOARD_USB_COMBO = 4, // USB Combo-Slim module
|
|
} BOARD_TYPE_8192CUSB, *PBOARD_TYPE_8192CUSB;
|
|
|
|
#define SUPPORT_HW_RADIO_DETECT(pHalData) (pHalData->BoardType == BOARD_MINICARD||\
|
|
pHalData->BoardType == BOARD_USB_SOLO||\
|
|
pHalData->BoardType == BOARD_USB_COMBO)
|
|
|
|
#endif
|
|
|
|
|
|
#define EFUSE_ACCESS_ON 0x69 // For RTL8723 only.
|
|
#define EFUSE_ACCESS_OFF 0x00 // For RTL8723 only.
|
|
|
|
//========================================================
|
|
// General definitions
|
|
//========================================================
|
|
|
|
|
|
#include "basic_types.h"
|
|
|
|
#endif
|
|
|