Commit 5d9ffae0 authored by Gorskin Ilya's avatar Gorskin Ilya Committed by Greg Kroah-Hartman

Staging: rt2860: fix coding style issue in mac_pci.h, mac_usb.h, rtmp_mac.h, rtmp_phy.h

This is a patch to the mac_pci.h, mac_usb.h, rtmp_mac.h, rtmp_phy.h files
that fixes up errors found by the checkpatch.pl tool
Signed-off-by: default avatarGorskin Ilya <revent82@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 1995dbab
...@@ -147,13 +147,12 @@ typedef union _TX_ATTENUATION_CTRL_STRUC { ...@@ -147,13 +147,12 @@ typedef union _TX_ATTENUATION_CTRL_STRUC {
/* ----------------- Frimware Related MACRO ----------------- */ /* ----------------- Frimware Related MACRO ----------------- */
#define RTMP_WRITE_FIRMWARE(_pAd, _pFwImage, _FwLen) \ #define RTMP_WRITE_FIRMWARE(_pAd, _pFwImage, _FwLen) \
do{ \ do { \
unsigned long _i, _firm; \ unsigned long _i, _firm; \
RTMP_IO_WRITE32(_pAd, PBF_SYS_CTRL, 0x10000); \ RTMP_IO_WRITE32(_pAd, PBF_SYS_CTRL, 0x10000); \
\ \
for(_i=0; _i<_FwLen; _i+=4) \ for (_i = 0; _i < _FwLen; _i += 4) { \
{ \ _firm = _pFwImage[_i] + \
_firm = _pFwImage[_i] + \
(_pFwImage[_i+3] << 24) + \ (_pFwImage[_i+3] << 24) + \
(_pFwImage[_i+2] << 16) + \ (_pFwImage[_i+2] << 16) + \
(_pFwImage[_i+1] << 8); \ (_pFwImage[_i+1] << 8); \
...@@ -165,19 +164,19 @@ typedef union _TX_ATTENUATION_CTRL_STRUC { ...@@ -165,19 +164,19 @@ typedef union _TX_ATTENUATION_CTRL_STRUC {
/* initialize BBP R/W access agent */ \ /* initialize BBP R/W access agent */ \
RTMP_IO_WRITE32(_pAd, H2M_BBP_AGENT, 0); \ RTMP_IO_WRITE32(_pAd, H2M_BBP_AGENT, 0); \
RTMP_IO_WRITE32(_pAd, H2M_MAILBOX_CSR, 0); \ RTMP_IO_WRITE32(_pAd, H2M_MAILBOX_CSR, 0); \
}while(0) } while (0)
/* ----------------- TX Related MACRO ----------------- */ /* ----------------- TX Related MACRO ----------------- */
#define RTMP_START_DEQUEUE(pAd, QueIdx, irqFlags) do{}while(0) #define RTMP_START_DEQUEUE(pAd, QueIdx, irqFlags) do {} while (0)
#define RTMP_STOP_DEQUEUE(pAd, QueIdx, irqFlags) do{}while(0) #define RTMP_STOP_DEQUEUE(pAd, QueIdx, irqFlags) do {} while (0)
#define RTMP_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \ #define RTMP_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \
((freeNum) >= (unsigned long)(pTxBlk->TotalFragNum + RTMP_GET_PACKET_FRAGMENTS(pPacket) + 3)) /* rough estimate we will use 3 more descriptor. */ ((freeNum) >= (unsigned long)(pTxBlk->TotalFragNum + RTMP_GET_PACKET_FRAGMENTS(pPacket) + 3)) /* rough estimate we will use 3 more descriptor. */
#define RTMP_RELEASE_DESC_RESOURCE(pAd, QueIdx) \ #define RTMP_RELEASE_DESC_RESOURCE(pAd, QueIdx) do {} while (0)
do{}while(0)
#define NEED_QUEUE_BACK_FOR_AGG(pAd, QueIdx, freeNum, _TxFrameType) \ #define NEED_QUEUE_BACK_FOR_AGG(pAd, QueIdx, freeNum, _TxFrameType) \
(((freeNum != (TX_RING_SIZE-1)) && (pAd->TxSwQueue[QueIdx].Number == 0)) || (freeNum<3)) (((freeNum != (TX_RING_SIZE-1)) && \
(pAd->TxSwQueue[QueIdx].Number == 0)) || (freeNum < 3))
#define HAL_KickOutMgmtTx(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen) \ #define HAL_KickOutMgmtTx(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen) \
RtmpPCIMgmtKickOut(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen) RtmpPCIMgmtKickOut(_pAd, _QueIdx, _pPacket, _pSrcBufVA, _SrcBufLen)
...@@ -185,19 +184,19 @@ typedef union _TX_ATTENUATION_CTRL_STRUC { ...@@ -185,19 +184,19 @@ typedef union _TX_ATTENUATION_CTRL_STRUC {
#define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \ #define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
/* RtmpPCI_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) */ /* RtmpPCI_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) */
#define HAL_WriteTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) \ #define HAL_WriteTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
RtmpPCI_WriteSingleTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) RtmpPCI_WriteSingleTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
#define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \ #define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \
RtmpPCI_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) RtmpPCI_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber)
#define HAL_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) \ #define HAL_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber) \
RtmpPCI_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber) RtmpPCI_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber)
#define HAL_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx) \ #define HAL_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx) \
RtmpPCI_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx) RtmpPCI_FinalWriteTxResource(_pAd, _pTxBlk, _TotalMPDUSize, _FirstTxIdx)
#define HAL_LastTxIdx(_pAd, _QueIdx,_LastTxIdx) \ #define HAL_LastTxIdx(_pAd, _QueIdx, _LastTxIdx) \
/*RtmpPCIDataLastTxIdx(_pAd, _QueIdx,_LastTxIdx) */ /*RtmpPCIDataLastTxIdx(_pAd, _QueIdx,_LastTxIdx) */
#define HAL_KickOutTx(_pAd, _pTxBlk, _QueIdx) \ #define HAL_KickOutTx(_pAd, _pTxBlk, _QueIdx) \
...@@ -259,24 +258,24 @@ typedef union _TX_ATTENUATION_CTRL_STRUC { ...@@ -259,24 +258,24 @@ typedef union _TX_ATTENUATION_CTRL_STRUC {
/* Insert the BA bitmap to ASIC for the Wcid entry */ /* Insert the BA bitmap to ASIC for the Wcid entry */
#define RTMP_ADD_BA_SESSION_TO_ASIC(_pAd, _Aid, _TID) \ #define RTMP_ADD_BA_SESSION_TO_ASIC(_pAd, _Aid, _TID) \
do{ \ do { \
u32 _Value = 0, _Offset; \ u32 _Value = 0, _Offset; \
_Offset = MAC_WCID_BASE + (_Aid) * HW_WCID_ENTRY_SIZE + 4; \ _Offset = MAC_WCID_BASE + (_Aid) * HW_WCID_ENTRY_SIZE + 4; \
RTMP_IO_READ32((_pAd), _Offset, &_Value);\ RTMP_IO_READ32((_pAd), _Offset, &_Value);\
_Value |= (0x10000<<(_TID)); \ _Value |= (0x10000<<(_TID)); \
RTMP_IO_WRITE32((_pAd), _Offset, _Value);\ RTMP_IO_WRITE32((_pAd), _Offset, _Value);\
}while(0) } while (0)
/* Remove the BA bitmap from ASIC for the Wcid entry */ /* Remove the BA bitmap from ASIC for the Wcid entry */
/* bitmap field starts at 0x10000 in ASIC WCID table */ /* bitmap field starts at 0x10000 in ASIC WCID table */
#define RTMP_DEL_BA_SESSION_FROM_ASIC(_pAd, _Wcid, _TID) \ #define RTMP_DEL_BA_SESSION_FROM_ASIC(_pAd, _Wcid, _TID) \
do{ \ do { \
u32 _Value = 0, _Offset; \ u32 _Value = 0, _Offset; \
_Offset = MAC_WCID_BASE + (_Wcid) * HW_WCID_ENTRY_SIZE + 4; \ _Offset = MAC_WCID_BASE + (_Wcid) * HW_WCID_ENTRY_SIZE + 4; \
RTMP_IO_READ32((_pAd), _Offset, &_Value); \ RTMP_IO_READ32((_pAd), _Offset, &_Value); \
_Value &= (~(0x10000 << (_TID))); \ _Value &= (~(0x10000 << (_TID))); \
RTMP_IO_WRITE32((_pAd), _Offset, _Value); \ RTMP_IO_WRITE32((_pAd), _Offset, _Value); \
}while(0) } while (0)
/* ----------------- Interface Related MACRO ----------------- */ /* ----------------- Interface Related MACRO ----------------- */
...@@ -285,16 +284,16 @@ typedef union _TX_ATTENUATION_CTRL_STRUC { ...@@ -285,16 +284,16 @@ typedef union _TX_ATTENUATION_CTRL_STRUC {
/* Since it use ADAPTER structure, it have to be put after structure definition. */ /* Since it use ADAPTER structure, it have to be put after structure definition. */
/* */ /* */
#define RTMP_ASIC_INTERRUPT_DISABLE(_pAd) \ #define RTMP_ASIC_INTERRUPT_DISABLE(_pAd) \
do{ \ do { \
RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, 0x0); /* 0: disable */ \ RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, 0x0); /* 0: disable */ \
RTMP_CLEAR_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \ RTMP_CLEAR_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \
}while(0) } while (0)
#define RTMP_ASIC_INTERRUPT_ENABLE(_pAd)\ #define RTMP_ASIC_INTERRUPT_ENABLE(_pAd)\
do{ \ do { \
RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, (_pAd)->int_enable_reg /*DELAYINTMASK*/); /* 1:enable */ \ RTMP_IO_WRITE32((_pAd), INT_MASK_CSR, (_pAd)->int_enable_reg /*DELAYINTMASK*/); /* 1:enable */ \
RTMP_SET_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \ RTMP_SET_FLAG((_pAd), fRTMP_ADAPTER_INTERRUPT_ACTIVE); \
}while(0) } while (0)
#define RTMP_IRQ_INIT(pAd) \ #define RTMP_IRQ_INIT(pAd) \
{ pAd->int_enable_reg = ((DELAYINTMASK) | \ { pAd->int_enable_reg = ((DELAYINTMASK) | \
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
************************************************************************* *************************************************************************
Module Name: Module Name:
mac_usb.h mac_usb.h
Abstract: Abstract:
...@@ -46,7 +46,7 @@ ...@@ -46,7 +46,7 @@
#define USB_CYC_CFG 0x02a4 #define USB_CYC_CFG 0x02a4
#define BEACON_RING_SIZE 2 #define BEACON_RING_SIZE 2
#define MGMTPIPEIDX 0 /* EP6 is highest priority */ #define MGMTPIPEIDX 0 /* EP6 is highest priority */
#define RTMP_PKT_TAIL_PADDING 11 /* 3(max 4 byte padding) + 4 (last packet padding) + 4 (MaxBulkOutsize align padding) */ #define RTMP_PKT_TAIL_PADDING 11 /* 3(max 4 byte padding) + 4 (last packet padding) + 4 (MaxBulkOutsize align padding) */
...@@ -220,53 +220,51 @@ struct rt_rx_context { ...@@ -220,53 +220,51 @@ struct rt_rx_context {
******************************************************************************/ ******************************************************************************/
#define RTMP_START_DEQUEUE(pAd, QueIdx, irqFlags) \ #define RTMP_START_DEQUEUE(pAd, QueIdx, irqFlags) \
do{ \ do { \
RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \ RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
if (pAd->DeQueueRunning[QueIdx]) \ if (pAd->DeQueueRunning[QueIdx]) { \
{ \ RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
DBGPRINT(RT_DEBUG_OFF, ("DeQueueRunning[%d]= TRUE!\n", QueIdx)); \ DBGPRINT(RT_DEBUG_OFF, ("DeQueueRunning[%d]= TRUE!\n", QueIdx)); \
continue; \ continue; \
} \ } else { \
else \
{ \
pAd->DeQueueRunning[QueIdx] = TRUE; \ pAd->DeQueueRunning[QueIdx] = TRUE; \
RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\ RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
} \ } \
}while(0) } while (0)
#define RTMP_STOP_DEQUEUE(pAd, QueIdx, irqFlags) \ #define RTMP_STOP_DEQUEUE(pAd, QueIdx, irqFlags) \
do{ \ do { \
RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \ RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
pAd->DeQueueRunning[QueIdx] = FALSE; \ pAd->DeQueueRunning[QueIdx] = FALSE; \
RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \ RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
}while(0) } while (0)
#define RTMP_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \ #define RTMP_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \
(RTUSBFreeDescriptorRequest(pAd, pTxBlk->QueIdx, (pTxBlk->TotalFrameLen + GET_OS_PKT_LEN(pPacket))) == NDIS_STATUS_SUCCESS) (RTUSBFreeDescriptorRequest(pAd, pTxBlk->QueIdx, (pTxBlk->TotalFrameLen + GET_OS_PKT_LEN(pPacket))) == NDIS_STATUS_SUCCESS)
#define RTMP_RELEASE_DESC_RESOURCE(pAd, QueIdx) \ #define RTMP_RELEASE_DESC_RESOURCE(pAd, QueIdx) \
do{}while(0) do {} while (0)
#define NEED_QUEUE_BACK_FOR_AGG(_pAd, _QueIdx, _freeNum, _TxFrameType) \ #define NEED_QUEUE_BACK_FOR_AGG(_pAd, _QueIdx, _freeNum, _TxFrameType) \
((_TxFrameType == TX_RALINK_FRAME) && (RTUSBNeedQueueBackForAgg(_pAd, _QueIdx))) ((_TxFrameType == TX_RALINK_FRAME) && \
(RTUSBNeedQueueBackForAgg(_pAd, _QueIdx)))
#define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \ #define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
RtmpUSB_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) RtmpUSB_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
#define HAL_WriteTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) \ #define HAL_WriteTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
RtmpUSB_WriteSingleTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) RtmpUSB_WriteSingleTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
#define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \ #define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \
RtmpUSB_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) RtmpUSB_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber)
#define HAL_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) \ #define HAL_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber) \
RtmpUSB_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) RtmpUSB_WriteMultiTxResource(pAd, pTxBlk, frameNum, pFreeNumber)
#define HAL_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx) \ #define HAL_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx) \
RtmpUSB_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx) RtmpUSB_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx)
#define HAL_LastTxIdx(pAd, QueIdx,TxIdx) \ #define HAL_LastTxIdx(pAd, QueIdx, TxIdx) \
/*RtmpUSBDataLastTxIdx(pAd, QueIdx,TxIdx) */ /*RtmpUSBDataLastTxIdx(pAd, QueIdx,TxIdx) */
#define HAL_KickOutTx(pAd, pTxBlk, QueIdx) \ #define HAL_KickOutTx(pAd, pTxBlk, QueIdx) \
...@@ -286,8 +284,8 @@ struct rt_rx_context { ...@@ -286,8 +284,8 @@ struct rt_rx_context {
/* /*
* Device Hardware Interface Related MACRO * Device Hardware Interface Related MACRO
*/ */
#define RTMP_IRQ_INIT(pAd) do{}while(0) #define RTMP_IRQ_INIT(pAd) do {} while (0)
#define RTMP_IRQ_ENABLE(pAd) do{}while(0) #define RTMP_IRQ_ENABLE(pAd) do {} while (0)
/* /*
* MLME Related MACRO * MLME Related MACRO
...@@ -305,8 +303,8 @@ struct rt_rx_context { ...@@ -305,8 +303,8 @@ struct rt_rx_context {
RTUSBMlmeUp(pAd); } RTUSBMlmeUp(pAd); }
#define RTMP_MLME_RESET_STATE_MACHINE(pAd) \ #define RTMP_MLME_RESET_STATE_MACHINE(pAd) \
MlmeEnqueue(pAd, MLME_CNTL_STATE_MACHINE, MT2_RESET_CONF, 0, NULL); \ { MlmeEnqueue(pAd, MLME_CNTL_STATE_MACHINE, MT2_RESET_CONF, 0, NULL); \
RTUSBMlmeUp(pAd); RTUSBMlmeUp(pAd); }
#define RTMP_HANDLE_COUNTER_MEASURE(_pAd, _pEntry) \ #define RTMP_HANDLE_COUNTER_MEASURE(_pAd, _pEntry) \
{ RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_802_11_COUNTER_MEASURE, _pEntry, sizeof(struct rt_mac_table_entry)); \ { RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_802_11_COUNTER_MEASURE, _pEntry, sizeof(struct rt_mac_table_entry)); \
...@@ -330,12 +328,11 @@ struct rt_rx_context { ...@@ -330,12 +328,11 @@ struct rt_rx_context {
{\ {\
if ((_pAd)->StaCfg.WindowsPowerMode == Ndis802_11PowerModeFast_PSP) \ if ((_pAd)->StaCfg.WindowsPowerMode == Ndis802_11PowerModeFast_PSP) \
MlmeSetPsmBit(_pAd, _val);\ MlmeSetPsmBit(_pAd, _val);\
else \ else { \
{ \
u16 _psm_val; \ u16 _psm_val; \
_psm_val = _val; \ _psm_val = _val; \
RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_SET_PSM_BIT, &(_psm_val), sizeof(u16)); \ RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_SET_PSM_BIT, &(_psm_val), sizeof(u16)); \
}\ } \
} }
#define RTMP_MLME_RADIO_ON(pAd) \ #define RTMP_MLME_RADIO_ON(pAd) \
......
...@@ -154,7 +154,7 @@ typedef union _INT_SOURCE_CSR_STRUC { ...@@ -154,7 +154,7 @@ typedef union _INT_SOURCE_CSR_STRUC {
u32 GPTimer:1; u32 GPTimer:1;
u32 RxCoherent:1; /*bit16 */ u32 RxCoherent:1; /*bit16 */
u32 TxCoherent:1; u32 TxCoherent:1;
u32 : 14; u32: 14;
} field; } field;
u32 word; u32 word;
} INT_SOURCE_CSR_STRUC, *PINT_SOURCE_CSR_STRUC; } INT_SOURCE_CSR_STRUC, *PINT_SOURCE_CSR_STRUC;
...@@ -175,7 +175,7 @@ typedef union _INT_MASK_CSR_STRUC { ...@@ -175,7 +175,7 @@ typedef union _INT_MASK_CSR_STRUC {
u32 HccaDmaDone:1; u32 HccaDmaDone:1;
u32 MgmtDmaDone:1; u32 MgmtDmaDone:1;
u32 MCUCommandINT:1; u32 MCUCommandINT:1;
u32 : 20; u32: 20;
u32 RxCoherent:1; u32 RxCoherent:1;
u32 TxCoherent:1; u32 TxCoherent:1;
} field; } field;
...@@ -209,7 +209,7 @@ typedef union _WPDMA_RST_IDX_STRUC { ...@@ -209,7 +209,7 @@ typedef union _WPDMA_RST_IDX_STRUC {
u32 RST_DTX_IDX5:1; u32 RST_DTX_IDX5:1;
u32 rsv:10; u32 rsv:10;
u32 RST_DRX_IDX0:1; u32 RST_DRX_IDX0:1;
u32 : 15; u32: 15;
} field; } field;
u32 word; u32 word;
} WPDMA_RST_IDX_STRUC, *PWPDMA_RST_IDX_STRUC; } WPDMA_RST_IDX_STRUC, *PWPDMA_RST_IDX_STRUC;
...@@ -448,7 +448,7 @@ typedef union _BBP_CSR_CFG_STRUC { ...@@ -448,7 +448,7 @@ typedef union _BBP_CSR_CFG_STRUC {
u32 Busy:1; /* 1: ASIC is busy execute BBP programming. */ u32 Busy:1; /* 1: ASIC is busy execute BBP programming. */
u32 BBP_PAR_DUR:1; /* 0: 4 MAC clock cycles 1: 8 MAC clock cycles */ u32 BBP_PAR_DUR:1; /* 0: 4 MAC clock cycles 1: 8 MAC clock cycles */
u32 BBP_RW_MODE:1; /* 0: use serial mode 1:parallel */ u32 BBP_RW_MODE:1; /* 0: use serial mode 1:parallel */
u32 : 12; u32: 12;
} field; } field;
u32 word; u32 word;
} BBP_CSR_CFG_STRUC, *PBBP_CSR_CFG_STRUC; } BBP_CSR_CFG_STRUC, *PBBP_CSR_CFG_STRUC;
...@@ -494,7 +494,7 @@ typedef union _LED_CFG_STRUC { ...@@ -494,7 +494,7 @@ typedef union _LED_CFG_STRUC {
u32 GLedMode:2; /* green Led Mode */ u32 GLedMode:2; /* green Led Mode */
u32 YLedMode:2; /* yellow Led Mode */ u32 YLedMode:2; /* yellow Led Mode */
u32 LedPolar:1; /* Led Polarity. 0: active low1: active high */ u32 LedPolar:1; /* Led Polarity. 0: active low1: active high */
u32 : 1; u32: 1;
} field; } field;
u32 word; u32 word;
} LED_CFG_STRUC, *PLED_CFG_STRUC; } LED_CFG_STRUC, *PLED_CFG_STRUC;
...@@ -533,7 +533,7 @@ typedef union _BCN_TIME_CFG_STRUC { ...@@ -533,7 +533,7 @@ typedef union _BCN_TIME_CFG_STRUC {
u32 TsfSyncMode:2; /* Enable TSF sync, 00: disable, 01: infra mode, 10: ad-hoc mode */ u32 TsfSyncMode:2; /* Enable TSF sync, 00: disable, 01: infra mode, 10: ad-hoc mode */
u32 bTBTTEnable:1; u32 bTBTTEnable:1;
u32 bBeaconGen:1; /* Enable beacon generator */ u32 bBeaconGen:1; /* Enable beacon generator */
u32 : 3; u32: 3;
u32 TxTimestampCompensate:8; u32 TxTimestampCompensate:8;
} field; } field;
u32 word; u32 word;
...@@ -560,7 +560,7 @@ typedef union _AUTO_WAKEUP_STRUC { ...@@ -560,7 +560,7 @@ typedef union _AUTO_WAKEUP_STRUC {
u32 AutoLeadTime:8; u32 AutoLeadTime:8;
u32 NumofSleepingTbtt:7; /* ForceWake has high privilege than PutToSleep when both set */ u32 NumofSleepingTbtt:7; /* ForceWake has high privilege than PutToSleep when both set */
u32 EnableAutoWakeup:1; /* 0:sleep, 1:awake */ u32 EnableAutoWakeup:1; /* 0:sleep, 1:awake */
u32 : 16; u32: 16;
} field; } field;
u32 word; u32 word;
} AUTO_WAKEUP_STRUC, *PAUTO_WAKEUP_STRUC; } AUTO_WAKEUP_STRUC, *PAUTO_WAKEUP_STRUC;
...@@ -578,7 +578,7 @@ typedef union _EDCA_AC_CFG_STRUC { ...@@ -578,7 +578,7 @@ typedef union _EDCA_AC_CFG_STRUC {
u32 Aifsn:4; /* # of slot time */ u32 Aifsn:4; /* # of slot time */
u32 Cwmin:4; /* */ u32 Cwmin:4; /* */
u32 Cwmax:4; /*unit power of 2 */ u32 Cwmax:4; /*unit power of 2 */
u32 : 12; /* */ u32: 12; /* */
} field; } field;
u32 word; u32 word;
} EDCA_AC_CFG_STRUC, *PEDCA_AC_CFG_STRUC; } EDCA_AC_CFG_STRUC, *PEDCA_AC_CFG_STRUC;
...@@ -751,7 +751,7 @@ typedef union _AUTO_RSP_CFG_STRUC { ...@@ -751,7 +751,7 @@ typedef union _AUTO_RSP_CFG_STRUC {
u32 rsv:1; /* Power bit value in conrtrol frame */ u32 rsv:1; /* Power bit value in conrtrol frame */
u32 DualCTSEn:1; /* Power bit value in conrtrol frame */ u32 DualCTSEn:1; /* Power bit value in conrtrol frame */
u32 AckCtsPsmBit:1; /* Power bit value in conrtrol frame */ u32 AckCtsPsmBit:1; /* Power bit value in conrtrol frame */
u32 : 24; u32: 24;
} field; } field;
u32 word; u32 word;
} AUTO_RSP_CFG_STRUC, *PAUTO_RSP_CFG_STRUC; } AUTO_RSP_CFG_STRUC, *PAUTO_RSP_CFG_STRUC;
...@@ -981,21 +981,21 @@ typedef union _MPDU_DEN_CNT_STRUC { ...@@ -981,21 +981,21 @@ typedef union _MPDU_DEN_CNT_STRUC {
typedef union _SHAREDKEY_MODE_STRUC { typedef union _SHAREDKEY_MODE_STRUC {
struct { struct {
u32 Bss0Key0CipherAlg:3; u32 Bss0Key0CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss0Key1CipherAlg:3; u32 Bss0Key1CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss0Key2CipherAlg:3; u32 Bss0Key2CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss0Key3CipherAlg:3; u32 Bss0Key3CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss1Key0CipherAlg:3; u32 Bss1Key0CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss1Key1CipherAlg:3; u32 Bss1Key1CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss1Key2CipherAlg:3; u32 Bss1Key2CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss1Key3CipherAlg:3; u32 Bss1Key3CipherAlg:3;
u32 : 1; u32: 1;
} field; } field;
u32 word; u32 word;
} SHAREDKEY_MODE_STRUC, *PSHAREDKEY_MODE_STRUC; } SHAREDKEY_MODE_STRUC, *PSHAREDKEY_MODE_STRUC;
...@@ -1103,7 +1103,7 @@ typedef union _RX_FILTR_CFG_STRUC { ...@@ -1103,7 +1103,7 @@ typedef union _RX_FILTR_CFG_STRUC {
u32 DropBAR:1; /* */ u32 DropBAR:1; /* */
u32 DropRsvCntlType:1; u32 DropRsvCntlType:1;
u32 : 15; u32: 15;
} field; } field;
u32 word; u32 word;
} RX_FILTR_CFG_STRUC, *PRX_FILTR_CFG_STRUC; } RX_FILTR_CFG_STRUC, *PRX_FILTR_CFG_STRUC;
...@@ -1128,21 +1128,21 @@ typedef union _PHY_CSR4_STRUC { ...@@ -1128,21 +1128,21 @@ typedef union _PHY_CSR4_STRUC {
typedef union _SEC_CSR5_STRUC { typedef union _SEC_CSR5_STRUC {
struct { struct {
u32 Bss2Key0CipherAlg:3; u32 Bss2Key0CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss2Key1CipherAlg:3; u32 Bss2Key1CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss2Key2CipherAlg:3; u32 Bss2Key2CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss2Key3CipherAlg:3; u32 Bss2Key3CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss3Key0CipherAlg:3; u32 Bss3Key0CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss3Key1CipherAlg:3; u32 Bss3Key1CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss3Key2CipherAlg:3; u32 Bss3Key2CipherAlg:3;
u32 : 1; u32: 1;
u32 Bss3Key3CipherAlg:3; u32 Bss3Key3CipherAlg:3;
u32 : 1; u32: 1;
} field; } field;
u32 word; u32 word;
} SEC_CSR5_STRUC, *PSEC_CSR5_STRUC; } SEC_CSR5_STRUC, *PSEC_CSR5_STRUC;
......
...@@ -177,8 +177,7 @@ ...@@ -177,8 +177,7 @@
#ifdef RTMP_MAC_PCI #ifdef RTMP_MAC_PCI
#define RTMP_RF_IO_WRITE32(_A, _V) \ #define RTMP_RF_IO_WRITE32(_A, _V) \
{ \ { \
if ((_A)->bPCIclkOff == FALSE) \ if ((_A)->bPCIclkOff == FALSE) { \
{ \
PHY_CSR4_STRUC _value; \ PHY_CSR4_STRUC _value; \
unsigned long _busyCnt = 0; \ unsigned long _busyCnt = 0; \
\ \
...@@ -187,9 +186,8 @@ ...@@ -187,9 +186,8 @@
if (_value.field.Busy == IDLE) \ if (_value.field.Busy == IDLE) \
break; \ break; \
_busyCnt++; \ _busyCnt++; \
}while (_busyCnt < MAX_BUSY_COUNT); \ } while (_busyCnt < MAX_BUSY_COUNT); \
if(_busyCnt < MAX_BUSY_COUNT) \ if (_busyCnt < MAX_BUSY_COUNT) { \
{ \
RTMP_IO_WRITE32((_A), RF_CSR_CFG0, (_V)); \ RTMP_IO_WRITE32((_A), RF_CSR_CFG0, (_V)); \
} \ } \
} \ } \
...@@ -218,52 +216,46 @@ ...@@ -218,52 +216,46 @@
_bViaMCU: if we need access the bbp via the MCU. _bViaMCU: if we need access the bbp via the MCU.
*/ */
#define RTMP_BBP_IO_READ8(_pAd, _bbpID, _pV, _bViaMCU) \ #define RTMP_BBP_IO_READ8(_pAd, _bbpID, _pV, _bViaMCU) \
do{ \ do { \
BBP_CSR_CFG_STRUC BbpCsr; \ BBP_CSR_CFG_STRUC BbpCsr; \
int _busyCnt, _secCnt, _regID; \ int _busyCnt, _secCnt, _regID; \
\ \
_regID = ((_bViaMCU) == TRUE ? H2M_BBP_AGENT : BBP_CSR_CFG); \ _regID = ((_bViaMCU) == TRUE ? H2M_BBP_AGENT : BBP_CSR_CFG); \
for (_busyCnt=0; _busyCnt<MAX_BUSY_COUNT; _busyCnt++) \ for (_busyCnt = 0; _busyCnt < MAX_BUSY_COUNT; _busyCnt++) { \
{ \ RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \
RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \
if (BbpCsr.field.Busy == BUSY) \ if (BbpCsr.field.Busy == BUSY) \
continue; \ continue; \
BbpCsr.word = 0; \ BbpCsr.word = 0; \
BbpCsr.field.fRead = 1; \ BbpCsr.field.fRead = 1; \
BbpCsr.field.BBP_RW_MODE = 1; \ BbpCsr.field.BBP_RW_MODE = 1; \
BbpCsr.field.Busy = 1; \ BbpCsr.field.Busy = 1; \
BbpCsr.field.RegNum = _bbpID; \ BbpCsr.field.RegNum = _bbpID; \
RTMP_IO_WRITE32(_pAd, _regID, BbpCsr.word); \ RTMP_IO_WRITE32(_pAd, _regID, BbpCsr.word); \
if ((_bViaMCU) == TRUE) \ if ((_bViaMCU) == TRUE) { \
{ \ AsicSendCommandToMcu(_pAd, 0x80, 0xff, 0x0, 0x0); \
AsicSendCommandToMcu(_pAd, 0x80, 0xff, 0x0, 0x0); \ RTMPusecDelay(1000); \
RTMPusecDelay(1000); \ } \
} \ for (_secCnt = 0; _secCnt < MAX_BUSY_COUNT; _secCnt++) { \
for (_secCnt=0; _secCnt<MAX_BUSY_COUNT; _secCnt++) \
{ \
RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \ RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \
if (BbpCsr.field.Busy == IDLE) \ if (BbpCsr.field.Busy == IDLE) \
break; \ break; \
} \ } \
if ((BbpCsr.field.Busy == IDLE) && \ if ((BbpCsr.field.Busy == IDLE) && \
(BbpCsr.field.RegNum == _bbpID)) \ (BbpCsr.field.RegNum == _bbpID)) { \
{ \ *(_pV) = (u8)BbpCsr.field.Value; \
*(_pV) = (u8)BbpCsr.field.Value; \ break; \
break; \ } \
} \ } \
} \ if (BbpCsr.field.Busy == BUSY) { \
if (BbpCsr.field.Busy == BUSY) \ DBGPRINT_ERR(("BBP(viaMCU=%d) read R%d fail\n", (_bViaMCU), _bbpID)); \
{ \
DBGPRINT_ERR(("BBP(viaMCU=%d) read R%d fail\n", (_bViaMCU), _bbpID)); \
*(_pV) = (_pAd)->BbpWriteLatch[_bbpID]; \ *(_pV) = (_pAd)->BbpWriteLatch[_bbpID]; \
if ((_bViaMCU) == TRUE) \ if ((_bViaMCU) == TRUE) { \
{ \
RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \ RTMP_IO_READ32(_pAd, _regID, &BbpCsr.word); \
BbpCsr.field.Busy = 0; \ BbpCsr.field.Busy = 0; \
RTMP_IO_WRITE32(_pAd, _regID, BbpCsr.word); \ RTMP_IO_WRITE32(_pAd, _regID, BbpCsr.word); \
} \ } \
} \ } \
}while(0) } while (0)
/* /*
This marco used for the BBP read operation which didn't need via MCU. This marco used for the BBP read operation which didn't need via MCU.
...@@ -283,42 +275,35 @@ ...@@ -283,42 +275,35 @@
int i, k; \ int i, k; \
BOOLEAN brc; \ BOOLEAN brc; \
BbpCsr.field.Busy = IDLE; \ BbpCsr.field.Busy = IDLE; \
if ((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \ if ((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) \
&& ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \
&& ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE) \ && ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE) \
&& ((_A)->bPCIclkOff == FALSE) \ && ((_A)->bPCIclkOff == FALSE) \
&& ((_A)->brt30xxBanMcuCmd == FALSE)) \ && ((_A)->brt30xxBanMcuCmd == FALSE)) { \
{ \ for (i = 0; i < MAX_BUSY_COUNT; i++) { \
for (i=0; i<MAX_BUSY_COUNT; i++) \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
{ \ if (BbpCsr.field.Busy == BUSY) { \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ continue; \
if (BbpCsr.field.Busy == BUSY) \ } \
{ \ BbpCsr.word = 0; \
continue; \ BbpCsr.field.fRead = 1; \
} \ BbpCsr.field.BBP_RW_MODE = 1; \
BbpCsr.word = 0; \ BbpCsr.field.Busy = 1; \
BbpCsr.field.fRead = 1; \ BbpCsr.field.RegNum = _I; \
BbpCsr.field.BBP_RW_MODE = 1; \ RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \
BbpCsr.field.Busy = 1; \ brc = AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \
BbpCsr.field.RegNum = _I; \ if (brc == TRUE) { \
RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \ for (k = 0; k < MAX_BUSY_COUNT; k++) { \
brc = AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
if (brc == TRUE) \ if (BbpCsr.field.Busy == IDLE) \
{ \ break; \
for (k=0; k<MAX_BUSY_COUNT; k++) \ } \
{ \ if ((BbpCsr.field.Busy == IDLE) && \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ (BbpCsr.field.RegNum == _I)) { \
if (BbpCsr.field.Busy == IDLE) \ *(_pV) = (u8)BbpCsr.field.Value; \
break; \ break; \
} \ } \
if ((BbpCsr.field.Busy == IDLE) && \ } else { \
(BbpCsr.field.RegNum == _I)) \
{ \
*(_pV) = (u8)BbpCsr.field.Value; \
break; \
} \
} \
else \
{ \
BbpCsr.field.Busy = 0; \ BbpCsr.field.Busy = 0; \
RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \ RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \
} \ } \
...@@ -326,46 +311,38 @@ ...@@ -326,46 +311,38 @@
} \ } \
else if (!((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \ else if (!((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \
&& ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE)) \ && ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE)) \
&& ((_A)->bPCIclkOff == FALSE)) \ && ((_A)->bPCIclkOff == FALSE)) { \
{ \ for (i = 0; i < MAX_BUSY_COUNT; i++) { \
for (i=0; i<MAX_BUSY_COUNT; i++) \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
{ \ if (BbpCsr.field.Busy == BUSY) { \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ continue; \
if (BbpCsr.field.Busy == BUSY) \ } \
{ \ BbpCsr.word = 0; \
continue; \ BbpCsr.field.fRead = 1; \
} \ BbpCsr.field.BBP_RW_MODE = 1; \
BbpCsr.word = 0; \ BbpCsr.field.Busy = 1; \
BbpCsr.field.fRead = 1; \ BbpCsr.field.RegNum = _I; \
BbpCsr.field.BBP_RW_MODE = 1; \ RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \
BbpCsr.field.Busy = 1; \ AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \
BbpCsr.field.RegNum = _I; \ for (k = 0; k < MAX_BUSY_COUNT; k++) { \
RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \ if (BbpCsr.field.Busy == IDLE) \
for (k=0; k<MAX_BUSY_COUNT; k++) \ break; \
{ \ } \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ if ((BbpCsr.field.Busy == IDLE) && \
if (BbpCsr.field.Busy == IDLE) \ (BbpCsr.field.RegNum == _I)) { \
break; \ *(_pV) = (u8)BbpCsr.field.Value; \
} \ break; \
if ((BbpCsr.field.Busy == IDLE) && \ } \
(BbpCsr.field.RegNum == _I)) \ } \
{ \ } else { \
*(_pV) = (u8)BbpCsr.field.Value; \
break; \
} \
} \
} \
else \
{ \
DBGPRINT_ERR((" , brt30xxBanMcuCmd = %d, Read BBP %d \n", (_A)->brt30xxBanMcuCmd, (_I))); \ DBGPRINT_ERR((" , brt30xxBanMcuCmd = %d, Read BBP %d \n", (_A)->brt30xxBanMcuCmd, (_I))); \
*(_pV) = (_A)->BbpWriteLatch[_I]; \ *(_pV) = (_A)->BbpWriteLatch[_I]; \
} \ } \
if ((BbpCsr.field.Busy == BUSY) || ((_A)->bPCIclkOff == TRUE)) \ if ((BbpCsr.field.Busy == BUSY) || ((_A)->bPCIclkOff == TRUE)) { \
{ \ DBGPRINT_ERR(("BBP read R%d=0x%x fail\n", _I, BbpCsr.word)); \
DBGPRINT_ERR(("BBP read R%d=0x%x fail\n", _I, BbpCsr.word)); \ *(_pV) = (_A)->BbpWriteLatch[_I]; \
*(_pV) = (_A)->BbpWriteLatch[_I]; \ } \
} \
} }
/* /*
...@@ -376,43 +353,39 @@ ...@@ -376,43 +353,39 @@
_bViaMCU: if we need access the bbp via the MCU. _bViaMCU: if we need access the bbp via the MCU.
*/ */
#define RTMP_BBP_IO_WRITE8(_pAd, _bbpID, _pV, _bViaMCU) \ #define RTMP_BBP_IO_WRITE8(_pAd, _bbpID, _pV, _bViaMCU) \
do{ \ do { \
BBP_CSR_CFG_STRUC BbpCsr; \ BBP_CSR_CFG_STRUC BbpCsr; \
int _busyCnt, _regID; \ int _busyCnt, _regID; \
\ \
_regID = ((_bViaMCU) == TRUE ? H2M_BBP_AGENT : BBP_CSR_CFG); \ _regID = ((_bViaMCU) == TRUE ? H2M_BBP_AGENT : BBP_CSR_CFG); \
for (_busyCnt=0; _busyCnt<MAX_BUSY_COUNT; _busyCnt++) \ for (_busyCnt = 0; _busyCnt < MAX_BUSY_COUNT; _busyCnt++) { \
{ \
RTMP_IO_READ32((_pAd), BBP_CSR_CFG, &BbpCsr.word); \ RTMP_IO_READ32((_pAd), BBP_CSR_CFG, &BbpCsr.word); \
if (BbpCsr.field.Busy == BUSY) \ if (BbpCsr.field.Busy == BUSY) \
continue; \ continue; \
BbpCsr.word = 0; \ BbpCsr.word = 0; \
BbpCsr.field.fRead = 0; \ BbpCsr.field.fRead = 0; \
BbpCsr.field.BBP_RW_MODE = 1; \ BbpCsr.field.BBP_RW_MODE = 1; \
BbpCsr.field.Busy = 1; \ BbpCsr.field.Busy = 1; \
BbpCsr.field.Value = _pV; \ BbpCsr.field.Value = _pV; \
BbpCsr.field.RegNum = _bbpID; \ BbpCsr.field.RegNum = _bbpID; \
RTMP_IO_WRITE32((_pAd), BBP_CSR_CFG, BbpCsr.word); \ RTMP_IO_WRITE32((_pAd), BBP_CSR_CFG, BbpCsr.word); \
if ((_bViaMCU) == TRUE) \ if ((_bViaMCU) == TRUE) { \
{ \ AsicSendCommandToMcu(_pAd, 0x80, 0xff, 0x0, 0x0); \
AsicSendCommandToMcu(_pAd, 0x80, 0xff, 0x0, 0x0); \ if ((_pAd)->OpMode == OPMODE_AP) \
if ((_pAd)->OpMode == OPMODE_AP) \ RTMPusecDelay(1000); \
RTMPusecDelay(1000); \ } \
} \ (_pAd)->BbpWriteLatch[_bbpID] = _pV; \
(_pAd)->BbpWriteLatch[_bbpID] = _pV; \ break; \
break; \ } \
} \ if (_busyCnt == MAX_BUSY_COUNT) { \
if (_busyCnt == MAX_BUSY_COUNT) \ DBGPRINT_ERR(("BBP write R%d fail\n", _bbpID)); \
{ \ if ((_bViaMCU) == TRUE) { \
DBGPRINT_ERR(("BBP write R%d fail\n", _bbpID)); \
if((_bViaMCU) == TRUE) \
{ \
RTMP_IO_READ32(_pAd, H2M_BBP_AGENT, &BbpCsr.word); \ RTMP_IO_READ32(_pAd, H2M_BBP_AGENT, &BbpCsr.word); \
BbpCsr.field.Busy = 0; \ BbpCsr.field.Busy = 0; \
RTMP_IO_WRITE32(_pAd, H2M_BBP_AGENT, BbpCsr.word); \ RTMP_IO_WRITE32(_pAd, H2M_BBP_AGENT, BbpCsr.word); \
} \ } \
} \ } \
}while(0) } while (0)
/* /*
This marco used for the BBP write operation which didn't need via MCU. This marco used for the BBP write operation which didn't need via MCU.
...@@ -426,25 +399,22 @@ ...@@ -426,25 +399,22 @@
will use this function too and didn't access the bbp register via the MCU. will use this function too and didn't access the bbp register via the MCU.
*/ */
/* Write BBP register by register's ID & value */ /* Write BBP register by register's ID & value */
#define RTMP_BBP_IO_WRITE8_BY_REG_ID(_A, _I, _V) \ #define RTMP_BBP_IO_WRITE8_BY_REG_ID(_A, _I, _V) \
{ \ { \
BBP_CSR_CFG_STRUC BbpCsr; \ BBP_CSR_CFG_STRUC BbpCsr; \
int BusyCnt = 0; \ int BusyCnt = 0; \
BOOLEAN brc; \ BOOLEAN brc; \
if (_I < MAX_NUM_OF_BBP_LATCH) \ if (_I < MAX_NUM_OF_BBP_LATCH) { \
{ \ if ((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) \
if ((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \ && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \
&& ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE) \ && ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE) \
&& ((_A)->bPCIclkOff == FALSE) \ && ((_A)->bPCIclkOff == FALSE) \
&& ((_A)->brt30xxBanMcuCmd == FALSE)) \ && ((_A)->brt30xxBanMcuCmd == FALSE)) { \
{ \ if (_A->AccessBBPFailCount > 20) { \
if (_A->AccessBBPFailCount > 20) \ AsicResetBBPAgent(_A); \
{ \ _A->AccessBBPFailCount = 0; \
AsicResetBBPAgent(_A); \ } \
_A->AccessBBPFailCount = 0; \ for (BusyCnt = 0; BusyCnt < MAX_BUSY_COUNT; BusyCnt++) { \
} \
for (BusyCnt=0; BusyCnt<MAX_BUSY_COUNT; BusyCnt++) \
{ \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
if (BbpCsr.field.Busy == BUSY) \ if (BbpCsr.field.Busy == BUSY) \
continue; \ continue; \
...@@ -456,29 +426,24 @@ ...@@ -456,29 +426,24 @@
BbpCsr.field.RegNum = _I; \ BbpCsr.field.RegNum = _I; \
RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \ RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \
brc = AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \ brc = AsicSendCommandToMcu(_A, 0x80, 0xff, 0x0, 0x0); \
if (brc == TRUE) \ if (brc == TRUE) { \
{ \
(_A)->BbpWriteLatch[_I] = _V; \ (_A)->BbpWriteLatch[_I] = _V; \
} \ } else { \
else \
{ \
BbpCsr.field.Busy = 0; \ BbpCsr.field.Busy = 0; \
RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \ RTMP_IO_WRITE32(_A, H2M_BBP_AGENT, BbpCsr.word); \
} \ } \
break; \ break; \
} \ } \
} \ } \
else if (!((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) && ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \ else if (!((IS_RT3090((_A)) || IS_RT3572((_A)) || IS_RT3390((_A))) \
&& ((_A)->StaCfg.PSControl.field.rt30xxPowerMode == 3) \
&& ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE)) \ && ((_A)->StaCfg.PSControl.field.EnableNewPS == TRUE)) \
&& ((_A)->bPCIclkOff == FALSE)) \ && ((_A)->bPCIclkOff == FALSE)) { \
{ \ if (_A->AccessBBPFailCount > 20) { \
if (_A->AccessBBPFailCount > 20) \ AsicResetBBPAgent(_A); \
{ \ _A->AccessBBPFailCount = 0; \
AsicResetBBPAgent(_A); \ } \
_A->AccessBBPFailCount = 0; \ for (BusyCnt = 0; BusyCnt < MAX_BUSY_COUNT; BusyCnt++) { \
} \
for (BusyCnt=0; BusyCnt<MAX_BUSY_COUNT; BusyCnt++) \
{ \
RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \ RTMP_IO_READ32(_A, H2M_BBP_AGENT, &BbpCsr.word); \
if (BbpCsr.field.Busy == BUSY) \ if (BbpCsr.field.Busy == BUSY) \
continue; \ continue; \
...@@ -493,20 +458,15 @@ ...@@ -493,20 +458,15 @@
(_A)->BbpWriteLatch[_I] = _V; \ (_A)->BbpWriteLatch[_I] = _V; \
break; \ break; \
} \ } \
} \ } else { \
else \
{ \
DBGPRINT_ERR((" brt30xxBanMcuCmd = %d. Write BBP %d \n", (_A)->brt30xxBanMcuCmd, (_I))); \ DBGPRINT_ERR((" brt30xxBanMcuCmd = %d. Write BBP %d \n", (_A)->brt30xxBanMcuCmd, (_I))); \
} \ } \
if ((BusyCnt == MAX_BUSY_COUNT) || ((_A)->bPCIclkOff == TRUE)) \ if ((BusyCnt == MAX_BUSY_COUNT) || ((_A)->bPCIclkOff == TRUE)) { \
{ \ if (BusyCnt == MAX_BUSY_COUNT) \
if (BusyCnt == MAX_BUSY_COUNT) \
(_A)->AccessBBPFailCount++; \ (_A)->AccessBBPFailCount++; \
DBGPRINT_ERR(("BBP write R%d=0x%x fail. BusyCnt= %d.bPCIclkOff = %d. \n", _I, BbpCsr.word, BusyCnt, (_A)->bPCIclkOff )); \ DBGPRINT_ERR(("BBP write R%d=0x%x fail. BusyCnt= %d.bPCIclkOff = %d. \n", _I, BbpCsr.word, BusyCnt, (_A)->bPCIclkOff)); \
} \ } \
} \ } else { \
else \
{ \
DBGPRINT_ERR(("****** BBP_Write_Latch Buffer exceeds max boundry ****** \n")); \ DBGPRINT_ERR(("****** BBP_Write_Latch Buffer exceeds max boundry ****** \n")); \
} \ } \
} }
...@@ -522,7 +482,7 @@ ...@@ -522,7 +482,7 @@
#ifdef RT30xx #ifdef RT30xx
#define RTMP_ASIC_MMPS_DISABLE(_pAd) \ #define RTMP_ASIC_MMPS_DISABLE(_pAd) \
do{ \ do { \
u32 _macData; \ u32 _macData; \
u8 _bbpData = 0; \ u8 _bbpData = 0; \
/* disable MMPS BBP control register */ \ /* disable MMPS BBP control register */ \
...@@ -534,10 +494,10 @@ ...@@ -534,10 +494,10 @@
RTMP_IO_READ32(_pAd, 0x1210, &_macData); \ RTMP_IO_READ32(_pAd, 0x1210, &_macData); \
_macData &= ~(0x09); /*bit 0, 3*/ \ _macData &= ~(0x09); /*bit 0, 3*/ \
RTMP_IO_WRITE32(_pAd, 0x1210, _macData); \ RTMP_IO_WRITE32(_pAd, 0x1210, _macData); \
}while(0) } while (0)
#define RTMP_ASIC_MMPS_ENABLE(_pAd) \ #define RTMP_ASIC_MMPS_ENABLE(_pAd) \
do{ \ do { \
u32 _macData; \ u32 _macData; \
u8 _bbpData = 0; \ u8 _bbpData = 0; \
/* enable MMPS BBP control register */ \ /* enable MMPS BBP control register */ \
...@@ -549,7 +509,7 @@ ...@@ -549,7 +509,7 @@
RTMP_IO_READ32(_pAd, 0x1210, &_macData); \ RTMP_IO_READ32(_pAd, 0x1210, &_macData); \
_macData |= (0x09); /*bit 0, 3*/ \ _macData |= (0x09); /*bit 0, 3*/ \
RTMP_IO_WRITE32(_pAd, 0x1210, _macData); \ RTMP_IO_WRITE32(_pAd, 0x1210, _macData); \
}while(0) } while (0)
#endif /* RT30xx // */ #endif /* RT30xx // */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment