?? rt_linux.h
字號:
}#endif // RT2870 //#ifndef wait_event_interruptible_timeout#define __wait_event_interruptible_timeout(wq, condition, ret) \do { \ wait_queue_t __wait; \ init_waitqueue_entry(&__wait, current); \ add_wait_queue(&wq, &__wait); \ for (;;) { \ set_current_state(TASK_INTERRUPTIBLE); \ if (condition) \ break; \ if (!signal_pending(current)) { \ ret = schedule_timeout(ret); \ if (!ret) \ break; \ continue; \ } \ ret = -ERESTARTSYS; \ break; \ } \ current->state = TASK_RUNNING; \ remove_wait_queue(&wq, &__wait); \} while (0)#define wait_event_interruptible_timeout(wq, condition, timeout) \({ \ long __ret = timeout; \ if (!(condition)) \ __wait_event_interruptible_timeout(wq, condition, __ret); \ __ret; \})#endif#define ONE_TICK 1#define OS_WAIT(_time) \{ int _i; \ long _loop = ((_time)/(1000/OS_HZ)) > 0 ? ((_time)/(1000/OS_HZ)) : 1;\ wait_queue_head_t _wait; \ init_waitqueue_head(&_wait); \ for (_i=0; _i<(_loop); _i++) \ wait_event_interruptible_timeout(_wait, 0, ONE_TICK); }/* Modified by Wu Xi-Kun 4/21/2006 */typedef void (*TIMER_FUNCTION)(unsigned long);#define COPY_MAC_ADDR(Addr1, Addr2) memcpy((Addr1), (Addr2), MAC_ADDR_LEN)#define MlmeAllocateMemory(_pAd, _ppVA) os_alloc_mem(_pAd, _ppVA, MGMT_DMA_BUFFER_SIZE)#define MlmeFreeMemory(_pAd, _pVA) os_free_mem(_pAd, _pVA)#ifdef RT2870#define BUILD_TIMER_FUNCTION(_func) \void linux_##_func(unsigned long data) \{ \ PRALINK_TIMER_STRUCT _pTimer = (PRALINK_TIMER_STRUCT)data; \ RT2870_TIMER_ENTRY *_pQNode; \ RTMP_ADAPTER *_pAd; \ \ _pTimer->handle = _func; \ _pAd = (RTMP_ADAPTER *)_pTimer->pAd; \ _pQNode = RT2870_TimerQ_Insert(_pAd, _pTimer); \ if ((_pQNode == NULL) && (_pAd->TimerQ.status & RT2870_THREAD_CAN_DO_INSERT)) \ RTMP_OS_Add_Timer(&_pTimer->TimerObj, HZ); \}#endif // RT2870 //#define DECLARE_TIMER_FUNCTION(_func) \void linux_##_func(unsigned long data) #define GET_TIMER_FUNCTION(_func) \ linux_##_func DECLARE_TIMER_FUNCTION(MlmePeriodicExec);DECLARE_TIMER_FUNCTION(MlmeRssiReportExec);DECLARE_TIMER_FUNCTION(AsicRxAntEvalTimeout);DECLARE_TIMER_FUNCTION(APSDPeriodicExec);DECLARE_TIMER_FUNCTION(AsicRfTuningExec);#ifdef RT2870DECLARE_TIMER_FUNCTION(BeaconUpdateExec);#endif // RT2870 //#ifdef CONFIG_STA_SUPPORTDECLARE_TIMER_FUNCTION(BeaconTimeout);DECLARE_TIMER_FUNCTION(ScanTimeout);DECLARE_TIMER_FUNCTION(AuthTimeout);DECLARE_TIMER_FUNCTION(AssocTimeout);DECLARE_TIMER_FUNCTION(ReassocTimeout);DECLARE_TIMER_FUNCTION(DisassocTimeout);DECLARE_TIMER_FUNCTION(LinkDownExec);#ifdef LEAP_SUPPORTDECLARE_TIMER_FUNCTION(LeapAuthTimeout);#endifDECLARE_TIMER_FUNCTION(StaQuickResponeForRateUpExec);DECLARE_TIMER_FUNCTION(WpaDisassocApAndBlockAssoc);DECLARE_TIMER_FUNCTION(PsPollWakeExec);DECLARE_TIMER_FUNCTION(RadioOnExec);#ifdef QOS_DLS_SUPPORTDECLARE_TIMER_FUNCTION(DlsTimeoutAction);#endif // QOS_DLS_SUPPORT //#endif // CONFIG_STA_SUPPORT //#undef AP_WSC_INCLUDED#undef STA_WSC_INCLUDED#undef WSC_INCLUDED#ifdef CONFIG_STA_SUPPORT#endif // CONFIG_STA_SUPPORT //#if defined(AP_WSC_INCLUDED) || defined(STA_WSC_INCLUDED)#define WSC_INCLUDED#endifvoid RTMP_GetCurrentSystemTime(LARGE_INTEGER *time);/* * packet helper * - convert internal rt packet to os packet or * os packet to rt packet */ #define RTPKT_TO_OSPKT(_p) ((struct sk_buff *)(_p))#define OSPKT_TO_RTPKT(_p) ((PNDIS_PACKET)(_p))#define GET_OS_PKT_DATAPTR(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->data)#define GET_OS_PKT_LEN(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->len)#define GET_OS_PKT_DATATAIL(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->tail)#define GET_OS_PKT_HEAD(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->head)#define GET_OS_PKT_END(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->end)#define GET_OS_PKT_NETDEV(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->dev)#define GET_OS_PKT_TYPE(_pkt) \ (RTPKT_TO_OSPKT(_pkt))#define GET_OS_PKT_NEXT(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->next)#define OS_NTOHS(_Val) \ (ntohs(_Val))#define OS_HTONS(_Val) \ (htons(_Val))#define OS_NTOHL(_Val) \ (ntohl(_Val))#define OS_HTONL(_Val) \ (htonl(_Val))/* statistics counter */#define STATS_INC_RX_PACKETS(_pAd, _dev)#define STATS_INC_TX_PACKETS(_pAd, _dev)#define STATS_INC_RX_BYTESS(_pAd, _dev, len)#define STATS_INC_TX_BYTESS(_pAd, _dev, len)#define STATS_INC_RX_ERRORS(_pAd, _dev)#define STATS_INC_TX_ERRORS(_pAd, _dev)#define STATS_INC_RX_DROPPED(_pAd, _dev)#define STATS_INC_TX_DROPPED(_pAd, _dev)#define CB_OFF 10// check DDK NDIS_PACKET data structure and find out only MiniportReservedEx[0..7] can be used by our driver without// ambiguity. Fields after pPacket->MiniportReservedEx[8] may be used by other wrapper layer thus crashes the driver////#define RTMP_GET_PACKET_MR(_p) (RTPKT_TO_OSPKT(_p))// User Priority#define RTMP_SET_PACKET_UP(_p, _prio) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+0] = _prio)#define RTMP_GET_PACKET_UP(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+0])// Fragment ##define RTMP_SET_PACKET_FRAGMENTS(_p, _num) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+1] = _num) #define RTMP_GET_PACKET_FRAGMENTS(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+1])// 0x0 ~0x7f: TX to AP's own BSS which has the specified AID. if AID>127, set bit 7 in RTMP_SET_PACKET_EMACTAB too. //(this value also as MAC(on-chip WCID) table index)// 0x80~0xff: TX to a WDS link. b0~6: WDS index#define RTMP_SET_PACKET_WCID(_p, _wdsidx) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+2] = _wdsidx)#define RTMP_GET_PACKET_WCID(_p) ((UCHAR)(RTPKT_TO_OSPKT(_p)->cb[CB_OFF+2]))// 0xff: PKTSRC_NDIS, others: local TX buffer index. This value affects how to a packet#define RTMP_SET_PACKET_SOURCE(_p, _pktsrc) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+3] = _pktsrc)#define RTMP_GET_PACKET_SOURCE(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+3]) // RTS/CTS-to-self protection method#define RTMP_SET_PACKET_RTS(_p, _num) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+4] = _num)#define RTMP_GET_PACKET_RTS(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+4]) // see RTMP_S(G)ET_PACKET_EMACTAB// TX rate index#define RTMP_SET_PACKET_TXRATE(_p, _rate) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+5] = _rate)#define RTMP_GET_PACKET_TXRATE(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+5])// From which Interface #define RTMP_SET_PACKET_IF(_p, _ifdx) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+6] = _ifdx)#define RTMP_GET_PACKET_IF(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+6])#define RTMP_SET_PACKET_NET_DEVICE_MBSSID(_p, _bss) RTMP_SET_PACKET_IF((_p), (_bss))#define RTMP_SET_PACKET_NET_DEVICE_WDS(_p, _bss) RTMP_SET_PACKET_IF((_p), ((_bss) + MIN_NET_DEVICE_FOR_WDS))#define RTMP_SET_PACKET_NET_DEVICE_APCLI(_p, _idx) RTMP_SET_PACKET_IF((_p), ((_idx) + MIN_NET_DEVICE_FOR_APCLI))#define RTMP_SET_PACKET_NET_DEVICE_MESH(_p, _idx) RTMP_SET_PACKET_IF((_p), ((_idx) + MIN_NET_DEVICE_FOR_MESH))#define RTMP_GET_PACKET_NET_DEVICE_MBSSID(_p) RTMP_GET_PACKET_IF((_p))#define RTMP_GET_PACKET_NET_DEVICE(_p) RTMP_GET_PACKET_IF((_p))#define RTMP_SET_PACKET_MOREDATA(_p, _morebit) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+7] = _morebit)#define RTMP_GET_PACKET_MOREDATA(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+7])//#define RTMP_SET_PACKET_NET_DEVICE_MBSSID(_p, _bss) (RTPKT_TO_OSPKT(_p)->cb[8] = _bss)//#define RTMP_GET_PACKET_NET_DEVICE_MBSSID(_p) (RTPKT_TO_OSPKT(_p)->cb[8])//// Sepcific Pakcet Type definition//#define RTMP_PACKET_SPECIFIC_CB_OFFSET 11#define RTMP_PACKET_SPECIFIC_DHCP 0x01#define RTMP_PACKET_SPECIFIC_EAPOL 0x02#define RTMP_PACKET_SPECIFIC_IPV4 0x04#define RTMP_PACKET_SPECIFIC_WAI 0x08#define RTMP_PACKET_SPECIFIC_VLAN 0x10#define RTMP_PACKET_SPECIFIC_LLCSNAP 0x20//Specific#define RTMP_SET_PACKET_SPECIFIC(_p, _flg) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] = _flg) //DHCP#define RTMP_SET_PACKET_DHCP(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_DHCP); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_DHCP); \ }while(0)#define RTMP_GET_PACKET_DHCP(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_DHCP)//EAPOL#define RTMP_SET_PACKET_EAPOL(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_EAPOL); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_EAPOL); \ }while(0)#define RTMP_GET_PACKET_EAPOL(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_EAPOL)//WAI#define RTMP_SET_PACKET_WAI(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_WAI); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_WAI); \ }while(0)#define RTMP_GET_PACKET_WAI(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_WAI)#define RTMP_GET_PACKET_LOWRATE(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & (RTMP_PACKET_SPECIFIC_EAPOL | RTMP_PACKET_SPECIFIC_DHCP | RTMP_PACKET_SPECIFIC_WAI))//VLAN#define RTMP_SET_PACKET_VLAN(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_VLAN); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_VLAN); \ }while(0)#define RTMP_GET_PACKET_VLAN(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_VLAN)//LLC/SNAP#define RTMP_SET_PACKET_LLCSNAP(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_LLCSNAP); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_LLCSNAP); \ }while(0) #define RTMP_GET_PACKET_LLCSNAP(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_LLCSNAP)// IP#define RTMP_SET_PACKET_IPV4(_p, _flg) \ do{ \ if (_flg) \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) |= (RTMP_PACKET_SPECIFIC_IPV4); \ else \ (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11]) &= (!RTMP_PACKET_SPECIFIC_IPV4); \ }while(0) #define RTMP_GET_PACKET_IPV4(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+11] & RTMP_PACKET_SPECIFIC_IPV4)// If this flag is set, it indicates that this EAPoL frame MUST be clear. #define RTMP_SET_PACKET_CLEAR_EAP_FRAME(_p, _flg) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+12] = _flg)#define RTMP_GET_PACKET_CLEAR_EAP_FRAME(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+12])#define RTMP_SET_PACKET_5VT(_p, _flg) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+22] = _flg)#define RTMP_GET_PACKET_5VT(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+22])#ifdef INF_AMAZON_SE/*Iverson patch for WMM A5-T07 ,WirelessStaToWirelessSta do not bulk out aggregate */#define RTMP_SET_PACKET_NOBULKOUT(_p, _morebit) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+23] = _morebit)#define RTMP_GET_PACKET_NOBULKOUT(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+23]) #endif // INF_AMAZON_SE //#ifdef CONFIG_5VT_ENHANCE#define BRIDGE_TAG 0x35564252 // depends on 5VT define in br_input.c#endif#define NDIS_SET_PACKET_STATUS(_p, _status)#define GET_SG_LIST_FROM_PACKET(_p, _sc) \ rt_get_sg_list_from_packet(_p, _sc)#define NdisMoveMemory(Destination, Source, Length) memmove(Destination, Source, Length)#define NdisZeroMemory(Destination, Length) memset(Destination, 0, Length)#define NdisFillMemory(Destination, Length, Fill) memset(Destination, Fill, Length)#define NdisEqualMemory(Source1, Source2, Length) (!memcmp(Source1, Source2, Length))#define RTMPEqualMemory(Source1, Source2, Length) (!memcmp(Source1, Source2, Length)) #define RTMP_INC_REF(_A) 0#define RTMP_DEC_REF(_A) 0#define RTMP_GET_REF(_A) 0/* * ULONG * RTMP_GetPhysicalAddressLow( * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress); */#define RTMP_GetPhysicalAddressLow(PhysicalAddress) (PhysicalAddress)/* * ULONG * RTMP_GetPhysicalAddressHigh( * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress); */#define RTMP_GetPhysicalAddressHigh(PhysicalAddress) (0)/* * VOID * RTMP_SetPhysicalAddressLow( * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress, * IN ULONG Value); */#define RTMP_SetPhysicalAddressLow(PhysicalAddress, Value) \ PhysicalAddress = Value;/* * VOID * RTMP_SetPhysicalAddressHigh( * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress, * IN ULONG Value); */#define RTMP_SetPhysicalAddressHigh(PhysicalAddress, Value)//CONTAINING_RECORD(pEntry, NDIS_PACKET, MiniportReservedEx);#define QUEUE_ENTRY_TO_PACKET(pEntry) \ (PNDIS_PACKET)(pEntry)#define PACKET_TO_QUEUE_ENTRY(pPacket) \ (PQUEUE_ENTRY)(pPacket)#ifndef CONTAINING_RECORD#define CONTAINING_RECORD(address, type, field) \((type *)((PCHAR)(address) - offsetof(type, field)))#endif#define RELEASE_NDIS_PACKET(_pAd, _pPacket, _Status) \{ \ RTMPFreeNdisPacket(_pAd, _pPacket); \}#define SWITCH_PhyAB(_pAA, _pBB) \{ \ ULONG AABasePaHigh; \ ULONG AABasePaLow; \ ULONG BBBasePaHigh; \ ULONG BBBasePaLow; \ BBBasePaHigh = RTMP_GetPhysicalAddressHigh(_pBB); \ BBBasePaLow = RTMP_GetPhysicalAddressLow(_pBB); \ AABasePaHigh = RTMP_GetPhysicalAddressHigh(_pAA); \ AABasePaLow = RTMP_GetPhysicalAddressLow(_pAA); \ RTMP_SetPhysicalAddressHigh(_pAA, BBBasePaHigh); \ RTMP_SetPhysicalAddressLow(_pAA, BBBasePaLow); \ RTMP_SetPhysicalAddressHigh(_pBB, AABasePaHigh); \ RTMP_SetPhysicalAddressLow(_pBB, AABasePaLow); \}#define NdisWriteErrorLogEntry(_a, _b, _c, _d)#define NdisMAllocateMapRegisters(_a, _b, _c, _d, _e) NDIS_STATUS_SUCCESS#define NdisAcquireSpinLock RTMP_SEM_LOCK#define NdisReleaseSpinLock RTMP_SEM_UNLOCKstatic inline void NdisGetSystemUpTime(ULONG *time){ *time = jiffies;}//pPacket = CONTAINING_RECORD(pEntry, NDIS_PACKET, MiniportReservedEx);#define QUEUE_ENTRY_TO_PKT(pEntry) \ ((PNDIS_PACKET) (pEntry))int rt28xx_packet_xmit(struct sk_buff *skb);void rtmp_os_thread_init(PUCHAR pThreadName, PVOID pNotify);
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -