2 *************************************************************************
4 * 5F., No.36, Taiyuan St., Jhubei City,
8 * (c) Copyright 2002-2007, Ralink Technology, Inc.
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
15 * This program is distributed in the hope that it will be useful, *
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
18 * GNU General Public License for more details. *
20 * You should have received a copy of the GNU General Public License *
21 * along with this program; if not, write to the *
22 * Free Software Foundation, Inc., *
23 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
25 *************************************************************************
34 --------- ---------- ----------------------------------------------
40 #include "rtmp_type.h"
43 #include "rtmp_iface.h"
44 #include "rtmp_dot11.h"
48 // Device ID & Vendor ID related definitions,
49 // NOTE: you should not add the new VendorID/DeviceID here unless you not sure it belongs to what chip.
51 #define NIC_PCI_VENDOR_ID 0x1814
52 #define PCIBUS_INTEL_VENDOR 0x8086
54 #if !defined(PCI_CAP_ID_EXP)
55 #define PCI_CAP_ID_EXP 0x10
57 #if !defined(PCI_EXP_LNKCTL)
58 #define PCI_EXP_LNKCTL 0x10
60 #if !defined(PCI_CLASS_BRIDGE_PCI)
61 #define PCI_CLASS_BRIDGE_PCI 0x0604
69 #define RTMP_PKT_TAIL_PADDING 0
70 #define fRTMP_ADAPTER_NEED_STOP_TX 0
72 #define AUX_CTRL 0x10c
75 // TX descriptor format, Tx ring, Mgmt Ring
78 typedef struct PACKED _TXD_STRUC
{
95 UINT32 QSEL
:2; // select on-chip FIFO ID for 2nd-stage output scheduler.0:MGMT, 1:HCCA 2:EDCA
96 UINT32 WIV
:1; // Wireless Info Valid. 1 if Driver already fill WI, o if DMA needs to copy WI to correctposition
98 } TXD_STRUC
, *PTXD_STRUC
;
100 typedef struct PACKED _TXD_STRUC
{
114 UINT32 WIV
:1; // Wireless Info Valid. 1 if Driver already fill WI, o if DMA needs to copy WI to correctposition
115 UINT32 QSEL
:2; // select on-chip FIFO ID for 2nd-stage output scheduler.0:MGMT, 1:HCCA 2:EDCA
120 } TXD_STRUC
, *PTXD_STRUC
;
125 // Rx descriptor format, Rx Ring
128 typedef struct PACKED _RXD_STRUC
{
141 UINT32 PlcpRssil
:1;// To be moved
142 UINT32 PlcpSignal
:1; // To be moved
143 UINT32 Decrypted
:1; // this frame is being decrypted.
148 UINT32 AMSDU
:1; // rx with 802.3 header, not 802.11 header. obsolete.
149 UINT32 CipherErr
:2; // 0: decryption okay, 1:ICV error, 2:MIC error, 3:KEY not valid
150 UINT32 Crc
:1; // 1: CRC error
151 UINT32 MyBss
:1; // 1: this frame belongs to the same BSSID
152 UINT32 Bcast
:1; // 1: this is a broadcast frame
153 UINT32 Mcast
:1; // 1: this is a multicast frame
154 UINT32 U2M
:1; // 1: this RX frame is unicast to me
160 } RXD_STRUC
, *PRXD_STRUC
, RT28XX_RXD_STRUC
, *PRT28XX_RXD_STRUC
;
162 typedef struct PACKED _RXD_STRUC
{
178 UINT32 U2M
:1; // 1: this RX frame is unicast to me
179 UINT32 Mcast
:1; // 1: this is a multicast frame
180 UINT32 Bcast
:1; // 1: this is a broadcast frame
181 UINT32 MyBss
:1; // 1: this frame belongs to the same BSSID
182 UINT32 Crc
:1; // 1: CRC error
183 UINT32 CipherErr
:2; // 0: decryption okay, 1:ICV error, 2:MIC error, 3:KEY not valid
184 UINT32 AMSDU
:1; // rx with 802.3 header, not 802.11 header.
189 UINT32 Decrypted
:1; // this frame is being decrypted.
190 UINT32 PlcpSignal
:1; // To be moved
191 UINT32 PlcpRssil
:1;// To be moved
193 } RXD_STRUC
, *PRXD_STRUC
, RT28XX_RXD_STRUC
, *PRT28XX_RXD_STRUC
;
197 typedef union _TX_ATTENUATION_CTRL_STRUC
202 ULONG PCIE_PHY_TX_ATTEN_EN
:1;
203 ULONG PCIE_PHY_TX_ATTEN_VALUE
:3;
205 ULONG RF_ISOLATION_ENABLE
:1;
209 } TX_ATTENUATION_CTRL_STRUC
, *PTX_ATTENUATION_CTRL_STRUC
;
211 typedef union _TX_ATTENUATION_CTRL_STRUC
{
214 ULONG RF_ISOLATION_ENABLE
:1;
216 ULONG PCIE_PHY_TX_ATTEN_VALUE
:3;
217 ULONG PCIE_PHY_TX_ATTEN_EN
:1;
222 } TX_ATTENUATION_CTRL_STRUC
, *PTX_ATTENUATION_CTRL_STRUC
;
224 /* ----------------- EEPROM Related MACRO ----------------- */
226 // 8051 firmware image for RT2860 - base address = 0x4000
227 #define FIRMWARE_IMAGE_BASE 0x2000
228 #define MAX_FIRMWARE_IMAGE_SIZE 0x2000 // 8kbyte
231 /* ----------------- Frimware Related MACRO ----------------- */
232 #define RTMP_WRITE_FIRMWARE(_pAd, _pFwImage, _FwLen) \
235 RTMP_IO_WRITE32(_pAd, PBF_SYS_CTRL, 0x10000); \
237 for(_i=0; _i<_FwLen; _i+=4) \
239 _firm = _pFwImage[_i] + \
240 (_pFwImage[_i+3] << 24) + \
241 (_pFwImage[_i+2] << 16) + \
242 (_pFwImage[_i+1] << 8); \
243 RTMP_IO_WRITE32(_pAd, FIRMWARE_IMAGE_BASE + _i, _firm); \
245 RTMP_IO_WRITE32(_pAd, PBF_SYS_CTRL, 0x00000); \
246 RTMP_IO_WRITE32(_pAd, PBF_SYS_CTRL, 0x00001); \
248 /* initialize BBP R/W access agent */ \
249 RTMP_IO_WRITE32(_pAd, H2M_BBP_AGENT, 0); \
250 RTMP_IO_WRITE32(_pAd, H2M_MAILBOX_CSR, 0); \
254 /* ----------------- TX Related MACRO ----------------- */
255 #define RTMP_START_DEQUEUE(pAd, QueIdx, irqFlags) do{}while(0)
256 #define RTMP_STOP_DEQUEUE(pAd, QueIdx, irqFlags) do{}while(0)
259 #define RTMP_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \
260 ((freeNum) >= (ULONG)(pTxBlk->TotalFragNum + RTMP_GET_PACKET_FRAGMENTS(pPacket) + 3)) /* rough estimate we will use 3 more descriptor. */
261 #define RTMP_RELEASE_DESC_RESOURCE(pAd, QueIdx) \
264 #define NEED_QUEUE_BACK_FOR_AGG(pAd, QueIdx, freeNum, _TxFrameType) \
265 (((freeNum != (TX_RING_SIZE-1)) && (pAd->TxSwQueue[QueIdx].Number == 0)) || (freeNum<3))
266 //(((freeNum) != (TX_RING_SIZE-1)) && (pAd->TxSwQueue[QueIdx].Number == 1 /*0*/))
269 #define HAL_KickOutMgmtTx(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen) \
270 RtmpPCIMgmtKickOut(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen)
272 #define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
273 /* RtmpPCI_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)*/
275 #define HAL_WriteTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) \
276 RtmpPCI_WriteSingleTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
278 #define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \
279 RtmpPCI_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber)
281 #define HAL_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) \
282 RtmpPCI_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber)
284 #define HAL_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx) \
285 RtmpPCI_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx)
287 #define HAL_LastTxIdx(_pAd, _QueIdx,_LastTxIdx) \
288 /*RtmpPCIDataLastTxIdx(_pAd, _QueIdx,_LastTxIdx)*/
290 #define HAL_KickOutTx(_pAd, _pTxBlk, _QueIdx) \
291 RTMP_IO_WRITE32((_pAd), TX_CTX_IDX0+((_QueIdx)*0x10), (_pAd)->TxRing[(_QueIdx)].TxCpuIdx)
292 /* RtmpPCIDataKickOut(_pAd, _pTxBlk, _QueIdx)*/
294 #define HAL_KickOutNullFrameTx(_pAd, _QueIdx, _pNullFrame, _frameLen) \
295 MiniportMMRequest(_pAd, _QueIdx, _pNullFrame, _frameLen)
297 #define GET_TXRING_FREENO(_pAd, _QueIdx) \
298 (_pAd->TxRing[_QueIdx].TxSwFreeIdx > _pAd->TxRing[_QueIdx].TxCpuIdx) ? \
299 (_pAd->TxRing[_QueIdx].TxSwFreeIdx - _pAd->TxRing[_QueIdx].TxCpuIdx - 1) \
301 (_pAd->TxRing[_QueIdx].TxSwFreeIdx + TX_RING_SIZE - _pAd->TxRing[_QueIdx].TxCpuIdx - 1);
304 #define GET_MGMTRING_FREENO(_pAd) \
305 (_pAd->MgmtRing.TxSwFreeIdx > _pAd->MgmtRing.TxCpuIdx) ? \
306 (_pAd->MgmtRing.TxSwFreeIdx - _pAd->MgmtRing.TxCpuIdx - 1) \
308 (_pAd->MgmtRing.TxSwFreeIdx + MGMT_RING_SIZE - _pAd->MgmtRing.TxCpuIdx - 1);
311 /* ----------------- RX Related MACRO ----------------- */
314 /* ----------------- ASIC Related MACRO ----------------- */
315 // reset MAC of a station entry to 0x000000000000
316 #define RTMP_STA_ENTRY_MAC_RESET(pAd, Wcid) \
317 AsicDelWcidTab(pAd, Wcid);
319 // add this entry into ASIC RX WCID search table
320 #define RTMP_STA_ENTRY_ADD(pAd, pEntry) \
321 AsicUpdateRxWCIDTable(pAd, pEntry->Aid, pEntry->Addr);
323 // add by johnli, fix "in_interrupt" error when call "MacTableDeleteEntry" in Rx tasklet
324 // Set MAC register value according operation mode
325 #define RTMP_UPDATE_PROTECT(pAd) \
326 AsicUpdateProtect(pAd, 0, (ALLN_SETPROTECT), TRUE, 0);
329 // remove Pair-wise key material from ASIC
330 #define RTMP_STA_ENTRY_KEY_DEL(pAd, BssIdx, Wcid) \
331 AsicRemovePairwiseKeyEntry(pAd, BssIdx, (UCHAR)Wcid);
333 // add Client security information into ASIC WCID table and IVEIV table
334 #define RTMP_STA_SECURITY_INFO_ADD(pAd, apidx, KeyID, pEntry) \
335 RTMPAddWcidAttributeEntry(pAd, apidx, KeyID, \
336 pAd->SharedKey[apidx][KeyID].CipherAlg, pEntry);
338 #define RTMP_SECURITY_KEY_ADD(pAd, apidx, KeyID, pEntry) \
339 { /* update pairwise key information to ASIC Shared Key Table */ \
340 AsicAddSharedKeyEntry(pAd, apidx, KeyID, \
341 pAd->SharedKey[apidx][KeyID].CipherAlg, \
342 pAd->SharedKey[apidx][KeyID].Key, \
343 pAd->SharedKey[apidx][KeyID].TxMic, \
344 pAd->SharedKey[apidx][KeyID].RxMic); \
345 /* update ASIC WCID attribute table and IVEIV table */ \
346 RTMPAddWcidAttributeEntry(pAd, apidx, KeyID, \
347 pAd->SharedKey[apidx][KeyID].CipherAlg, \
351 // Insert the BA bitmap to ASIC for the Wcid entry
352 #define RTMP_ADD_BA_SESSION_TO_ASIC(_pAd, _Aid, _TID) \
354 UINT32 _Value = 0, _Offset; \
355 _Offset = MAC_WCID_BASE + (_Aid) * HW_WCID_ENTRY_SIZE + 4; \
356 RTMP_IO_READ32((_pAd), _Offset, &_Value);\
357 _Value |= (0x10000<<(_TID)); \
358 RTMP_IO_WRITE32((_pAd), _Offset, _Value);\
362 // Remove the BA bitmap from ASIC for the Wcid entry
363 // bitmap field starts at 0x10000 in ASIC WCID table
364 #define RTMP_DEL_BA_SESSION_FROM_ASIC(_pAd, _Wcid, _TID) \
366 UINT32 _Value = 0, _Offset; \
367 _Offset = MAC_WCID_BASE + (_Wcid) * HW_WCID_ENTRY_SIZE + 4; \
368 RTMP_IO_READ32((_pAd), _Offset, &_Value); \
369 _Value &= (~(0x10000 << (_TID))); \
370 RTMP_IO_WRITE32((_pAd), _Offset, _Value); \
374 /* ----------------- Interface Related MACRO ----------------- */
377 // Enable & Disable NIC interrupt via writing interrupt mask register
378 // Since it use ADAPTER structure, it have to be put after structure definition.
380 #define RTMP_ASIC_INTERRUPT_DISABLE(_pAd) \
382 RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, 0x0); /* 0: disable */ \
383 RTMP_CLEAR_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \
386 #define RTMP_ASIC_INTERRUPT_ENABLE(_pAd)\
388 RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, (_pAd)->int_enable_reg /*DELAYINTMASK*/); /* 1:enable */ \
389 RTMP_SET_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \
393 #define RTMP_IRQ_INIT(pAd) \
394 { pAd->int_enable_reg = ((DELAYINTMASK) | \
395 (RxINT|TxDataInt|TxMgmtInt)) & ~(0x03); \
396 pAd->int_disable_mask = 0; \
397 pAd->int_pending = 0; }
399 #define RTMP_IRQ_ENABLE(pAd) \
400 { /* clear garbage ints */ \
401 RTMP_IO_WRITE32(pAd, INT_SOURCE_CSR, 0xffffffff);\
402 RTMP_ASIC_INTERRUPT_ENABLE(pAd); }
405 /* ----------------- MLME Related MACRO ----------------- */
406 #define RTMP_MLME_HANDLER(pAd) MlmeHandler(pAd)
408 #define RTMP_MLME_PRE_SANITY_CHECK(pAd)
410 #define RTMP_MLME_STA_QUICK_RSP_WAKE_UP(pAd) \
411 RTMPSetTimer(&pAd->StaCfg.StaQuickResponeForRateUpTimer, 100);
413 #define RTMP_MLME_RESET_STATE_MACHINE(pAd) \
414 MlmeRestartStateMachine(pAd)
416 #define RTMP_HANDLE_COUNTER_MEASURE(_pAd, _pEntry)\
417 HandleCounterMeasure(_pAd, _pEntry)
419 /* ----------------- Power Save Related MACRO ----------------- */
420 #define RTMP_PS_POLL_ENQUEUE(pAd) EnqueuePsPoll(pAd)
423 // For RTMPPCIePowerLinkCtrlRestore () function
424 #define RESTORE_HALT 1
425 #define RESTORE_WAKEUP 2
426 #define RESTORE_CLOSE 3
428 #define PowerSafeCID 1
429 #define PowerRadioOffCID 2
430 #define PowerWakeCID 3
431 #define CID0MASK 0x000000ff
432 #define CID1MASK 0x0000ff00
433 #define CID2MASK 0x00ff0000
434 #define CID3MASK 0xff000000
437 #ifdef CONFIG_STA_SUPPORT
438 #define RTMP_STA_FORCE_WAKEUP(pAd, bFromTx) \
439 RT28xxPciStaAsicForceWakeup(pAd, bFromTx);
441 #define RTMP_STA_SLEEP_THEN_AUTO_WAKEUP(pAd, TbttNumToNextWakeUp) \
442 RT28xxPciStaAsicSleepThenAutoWakeup(pAd, TbttNumToNextWakeUp);
444 #define RTMP_SET_PSM_BIT(_pAd, _val) \
445 MlmeSetPsmBit(_pAd, _val);
446 #endif // CONFIG_STA_SUPPORT //
448 #define RTMP_MLME_RADIO_ON(pAd) \
449 RT28xxPciMlmeRadioOn(pAd);
451 #define RTMP_MLME_RADIO_OFF(pAd) \
452 RT28xxPciMlmeRadioOFF(pAd);
454 #endif //__MAC_PCI_H__ //