123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- // SPDX-License-Identifier: GPL-2.0+
- /*
- * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
- * All rights reserved.
- *
- * File: device.h
- *
- * Purpose: MAC Data structure
- *
- * Author: Tevin Chen
- *
- * Date: Mar 17, 1997
- *
- */
- #ifndef __DEVICE_H__
- #define __DEVICE_H__
- #include <linux/module.h>
- #include <linux/types.h>
- #include <linux/pci.h>
- #include <linux/etherdevice.h>
- #include <linux/skbuff.h>
- #include <linux/interrupt.h>
- #include <linux/crc32.h>
- #include <net/mac80211.h>
- /* device specific */
- #include "device_cfg.h"
- #include "card.h"
- #include "srom.h"
- #include "desc.h"
- #include "key.h"
- #include "mac.h"
- /*--------------------- Export Definitions -------------------------*/
- #define RATE_1M 0
- #define RATE_2M 1
- #define RATE_5M 2
- #define RATE_11M 3
- #define RATE_6M 4
- #define RATE_9M 5
- #define RATE_12M 6
- #define RATE_18M 7
- #define RATE_24M 8
- #define RATE_36M 9
- #define RATE_48M 10
- #define RATE_54M 11
- #define MAX_RATE 12
- #define AUTO_FB_NONE 0
- #define AUTO_FB_0 1
- #define AUTO_FB_1 2
- #define FB_RATE0 0
- #define FB_RATE1 1
- /* Antenna Mode */
- #define ANT_A 0
- #define ANT_B 1
- #define ANT_DIVERSITY 2
- #define ANT_RXD_TXA 3
- #define ANT_RXD_TXB 4
- #define ANT_UNKNOWN 0xFF
- #define BB_VGA_LEVEL 4
- #define BB_VGA_CHANGE_THRESHOLD 16
- #define MAKE_BEACON_RESERVED 10 /* (us) */
- /* BUILD OBJ mode */
- #define AVAIL_TD(p, q) ((p)->opts.tx_descs[(q)] - ((p)->iTDUsed[(q)]))
- /* 0:11A 1:11B 2:11G */
- #define BB_TYPE_11A 0
- #define BB_TYPE_11B 1
- #define BB_TYPE_11G 2
- /* 0:11a, 1:11b, 2:11gb (only CCK in BasicRate), 3:11ga (OFDM in BasicRate) */
- #define PK_TYPE_11A 0
- #define PK_TYPE_11B 1
- #define PK_TYPE_11GB 2
- #define PK_TYPE_11GA 3
- #define OWNED_BY_HOST 0
- #define OWNED_BY_NIC 1
- struct vnt_options {
- int rx_descs0; /* Number of RX descriptors0 */
- int rx_descs1; /* Number of RX descriptors1 */
- int tx_descs[2]; /* Number of TX descriptors 0, 1 */
- int int_works; /* interrupt limits */
- int short_retry;
- int long_retry;
- int bbp_type;
- u32 flags;
- };
- struct vnt_private {
- struct pci_dev *pcid;
- /* mac80211 */
- struct ieee80211_hw *hw;
- struct ieee80211_vif *vif;
- unsigned long key_entry_inuse;
- u32 basic_rates;
- u16 current_aid;
- int mc_list_count;
- u8 mac_hw;
- /* dma addr, rx/tx pool */
- dma_addr_t pool_dma;
- dma_addr_t rd0_pool_dma;
- dma_addr_t rd1_pool_dma;
- dma_addr_t td0_pool_dma;
- dma_addr_t td1_pool_dma;
- dma_addr_t tx_bufs_dma0;
- dma_addr_t tx_bufs_dma1;
- dma_addr_t tx_beacon_dma;
- unsigned char *tx0_bufs;
- unsigned char *tx1_bufs;
- unsigned char *tx_beacon_bufs;
- void __iomem *PortOffset;
- u32 memaddr;
- u32 ioaddr;
- unsigned char byRxMode;
- spinlock_t lock;
- volatile int iTDUsed[TYPE_MAXTD];
- struct vnt_tx_desc *apCurrTD[TYPE_MAXTD];
- struct vnt_tx_desc *apTailTD[TYPE_MAXTD];
- struct vnt_tx_desc *apTD0Rings;
- struct vnt_tx_desc *apTD1Rings;
- struct vnt_rx_desc *aRD0Ring;
- struct vnt_rx_desc *aRD1Ring;
- struct vnt_rx_desc *pCurrRD[TYPE_MAXRD];
- struct vnt_options opts;
- u32 flags;
- u32 rx_buf_sz;
- u8 rx_rate;
- u32 rx_bytes;
- /* Version control */
- unsigned char byLocalID;
- unsigned char byRFType;
- unsigned char byMaxPwrLevel;
- unsigned char byZoneType;
- bool bZoneRegExist;
- unsigned char byOriginalZonetype;
- unsigned char abyCurrentNetAddr[ETH_ALEN]; __aligned(2)
- bool bLinkPass; /* link status: OK or fail */
- unsigned int uCurrRSSI;
- unsigned char byCurrSQ;
- unsigned long dwTxAntennaSel;
- unsigned long dwRxAntennaSel;
- unsigned char byAntennaCount;
- unsigned char byRxAntennaMode;
- unsigned char byTxAntennaMode;
- bool bTxRxAntInv;
- unsigned char *pbyTmpBuff;
- unsigned int uSIFS; /* Current SIFS */
- unsigned int uDIFS; /* Current DIFS */
- unsigned int uEIFS; /* Current EIFS */
- unsigned int uSlot; /* Current SlotTime */
- unsigned int uCwMin; /* Current CwMin */
- unsigned int uCwMax; /* CwMax is fixed on 1023. */
- /* PHY parameter */
- unsigned char bySIFS;
- unsigned char byDIFS;
- unsigned char byEIFS;
- unsigned char bySlot;
- unsigned char byCWMaxMin;
- u8 byBBType; /* 0:11A, 1:11B, 2:11G */
- u8 byPacketType; /*
- * 0:11a,1:11b,2:11gb (only CCK
- * in BasicRate), 3:11ga (OFDM in
- * Basic Rate)
- */
- unsigned short wBasicRate;
- unsigned char byACKRate;
- unsigned char byTopOFDMBasicRate;
- unsigned char byTopCCKBasicRate;
- unsigned char byMinChannel;
- unsigned char byMaxChannel;
- unsigned char byPreambleType;
- unsigned char byShortPreamble;
- unsigned short wCurrentRate;
- unsigned char byShortRetryLimit;
- unsigned char byLongRetryLimit;
- enum nl80211_iftype op_mode;
- bool bBSSIDFilter;
- unsigned short wMaxTransmitMSDULifetime;
- bool bEncryptionEnable;
- bool bLongHeader;
- bool bShortSlotTime;
- bool bProtectMode;
- bool bNonERPPresent;
- bool bBarkerPreambleMd;
- bool bRadioControlOff;
- bool bRadioOff;
- bool bEnablePSMode;
- unsigned short wListenInterval;
- bool bPWBitOn;
- /* GPIO Radio Control */
- unsigned char byRadioCtl;
- unsigned char byGPIO;
- bool bHWRadioOff;
- bool bPrvActive4RadioOFF;
- bool bGPIOBlockRead;
- /* Beacon related */
- unsigned short wSeqCounter;
- unsigned short wBCNBufLen;
- bool bBeaconBufReady;
- bool bBeaconSent;
- bool bIsBeaconBufReadySet;
- unsigned int cbBeaconBufReadySetCnt;
- bool bFixRate;
- u16 byCurrentCh;
- bool bAES;
- unsigned char byAutoFBCtrl;
- /* For Update BaseBand VGA Gain Offset */
- bool bUpdateBBVGA;
- unsigned int uBBVGADiffCount;
- unsigned char byBBVGANew;
- unsigned char byBBVGACurrent;
- unsigned char abyBBVGA[BB_VGA_LEVEL];
- long ldBmThreshold[BB_VGA_LEVEL];
- unsigned char byBBPreEDRSSI;
- unsigned char byBBPreEDIndex;
- unsigned long dwDiagRefCount;
- /* For FOE Tuning */
- unsigned char byFOETuning;
- /* For RF Power table */
- unsigned char byCCKPwr;
- unsigned char byOFDMPwrG;
- unsigned char byCurPwr;
- char byCurPwrdBm;
- unsigned char abyCCKPwrTbl[CB_MAX_CHANNEL_24G + 1];
- unsigned char abyOFDMPwrTbl[CB_MAX_CHANNEL + 1];
- char abyCCKDefaultPwr[CB_MAX_CHANNEL_24G + 1];
- char abyOFDMDefaultPwr[CB_MAX_CHANNEL + 1];
- char abyRegPwr[CB_MAX_CHANNEL + 1];
- char abyLocalPwr[CB_MAX_CHANNEL + 1];
- /* BaseBand Loopback Use */
- unsigned char byBBCR4d;
- unsigned char byBBCRc9;
- unsigned char byBBCR88;
- unsigned char byBBCR09;
- unsigned char abyEEPROM[EEP_MAX_CONTEXT_SIZE]; /* unsigned long alignment */
- unsigned short wBeaconInterval;
- u16 wake_up_count;
- struct work_struct interrupt_work;
- struct ieee80211_low_level_stats low_stats;
- };
- #endif
|