📄 rt_linux.h
字号:
})
#define RTMP_TIME_AFTER_EQ(a,b) \
(typecheck(unsigned long, (unsigned long)a) && \
typecheck(unsigned long, (unsigned long)b) && \
((long)(a) - (long)(b) >= 0))
#define RTMP_TIME_BEFORE(a,b) RTMP_TIME_AFTER_EQ(b,a)
#define RTMP_TIME_AFTER(a,b) time_after(a, b)
#endif#define ONE_TICK 1static inline void NdisGetSystemUpTime(ULONG *time){ *time = jiffies;}/*********************************************************************************** * OS specific cookie data structure binding to RTMP_ADAPTER ***********************************************************************************/struct os_cookie {#ifdef RTMP_MAC_USB struct usb_device *pUsb_Dev;#endif // RTMP_MAC_USB // RTMP_NET_TASK_STRUCT rx_done_task; RTMP_NET_TASK_STRUCT mgmt_dma_done_task; RTMP_NET_TASK_STRUCT ac0_dma_done_task; RTMP_NET_TASK_STRUCT ac1_dma_done_task; RTMP_NET_TASK_STRUCT ac2_dma_done_task; RTMP_NET_TASK_STRUCT ac3_dma_done_task; RTMP_NET_TASK_STRUCT hcca_dma_done_task; RTMP_NET_TASK_STRUCT tbtt_task;#ifdef RTMP_MAC_USB RTMP_NET_TASK_STRUCT null_frame_complete_task; RTMP_NET_TASK_STRUCT rts_frame_complete_task; RTMP_NET_TASK_STRUCT pspoll_frame_complete_task;#endif // RTMP_MAC_USB // unsigned long apd_pid; //802.1x daemon pid INT ioctl_if_type; INT ioctl_if;};typedef struct os_cookie * POS_COOKIE;/*********************************************************************************** * OS debugging and printing related definitions and data structure ***********************************************************************************/#define PRINT_MAC(addr) \ addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]#ifdef DBGextern ULONG RTDebugLevel;#define DBGPRINT_RAW(Level, Fmt) \do{ \ if (Level <= RTDebugLevel) \ { \ printk Fmt; \ } \}while(0)#define DBGPRINT(Level, Fmt) DBGPRINT_RAW(Level, Fmt)#define DBGPRINT_ERR(Fmt) \{ \ printk("ERROR!!! "); \ printk Fmt; \}#define DBGPRINT_S(Status, Fmt) \{ \ printk Fmt; \}#else#define DBGPRINT(Level, Fmt)#define DBGPRINT_RAW(Level, Fmt)#define DBGPRINT_S(Status, Fmt)#define DBGPRINT_ERR(Fmt)#endif#undef ASSERT#define ASSERT(x) \{ \ if (!(x)) \ { \ printk(KERN_WARNING __FILE__ ":%d assert " #x "failed\n", __LINE__); \ } \}void hex_dump(char *str, unsigned char *pSrcBufVA, unsigned int SrcBufLen);/********************************************************************************************************* The following code are not revised, temporary put it here. *********************************************************************************************************//*********************************************************************************** * Device DMA Access related definitions and data structures. **********************************************************************************/#ifdef RTMP_MAC_USB#define PCI_MAP_SINGLE(_handle, _ptr, _size, _dir) (ULONG)0#define PCI_UNMAP_SINGLE(_handle, _ptr, _size, _dir)#endif // RTMP_MAC_USB ///* * 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)#define NdisMIndicateStatus(_w, _x, _y, _z)/*********************************************************************************** * Device Register I/O Access related definitions and data structures. **********************************************************************************/#ifdef RTMP_MAC_USB//Patch for ASIC turst read/write bug, needs to remove after metel fix#define RTMP_IO_READ32(_A, _R, _pV) \ RTUSBReadMACRegister((_A), (_R), (PUINT32) (_pV))#define RTMP_IO_READ8(_A, _R, _pV) \{ \}#define RTMP_IO_WRITE32(_A, _R, _V) \ RTUSBWriteMACRegister((_A), (_R), (UINT32) (_V))#define RTMP_IO_WRITE8(_A, _R, _V) \{ \ USHORT _Val = _V; \ RTUSBSingleWrite((_A), (_R), (USHORT) (_Val)); \}#define RTMP_IO_WRITE16(_A, _R, _V) \{ \ RTUSBSingleWrite((_A), (_R), (USHORT) (_V)); \}#endif // RTMP_MAC_USB ///*********************************************************************************** * Network Related data structure and marco definitions ***********************************************************************************/#define PKTSRC_NDIS 0x7f#define PKTSRC_DRIVER 0x0f#define RTMP_OS_NETDEV_GET_PRIV(_pNetDev) ((_pNetDev)->priv)#define RTMP_OS_NETDEV_SET_PRIV(_pNetDev, _pPriv) ((_pNetDev)->priv = (_pPriv))#define RTMP_OS_NETDEV_GET_DEVNAME(_pNetDev) ((_pNetDev)->name)#define RTMP_OS_NETDEV_GET_PHYADDR(_PNETDEV) ((_PNETDEV)->dev_addr)#define RTMP_OS_NETDEV_START_QUEUE(_pNetDev) netif_start_queue((_pNetDev))#define RTMP_OS_NETDEV_STOP_QUEUE(_pNetDev) netif_stop_queue((_pNetDev))#define RTMP_OS_NETDEV_WAKE_QUEUE(_pNetDev) netif_wake_queue((_pNetDev))#define RTMP_OS_NETDEV_CARRIER_OFF(_pNetDev) netif_carrier_off((_pNetDev))#define QUEUE_ENTRY_TO_PACKET(pEntry) \ (PNDIS_PACKET)(pEntry)#define PACKET_TO_QUEUE_ENTRY(pPacket) \ (PQUEUE_ENTRY)(pPacket)#ifdef CONFIG_5VT_ENHANCE#define BRIDGE_TAG 0x35564252 // depends on 5VT define in br_input.c#endif#define GET_SG_LIST_FROM_PACKET(_p, _sc) \ rt_get_sg_list_from_packet(_p, _sc)#define RELEASE_NDIS_PACKET(_pAd, _pPacket, _Status) \{ \ RTMPFreeNdisPacket(_pAd, _pPacket); \}/* * 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 SET_OS_PKT_DATAPTR(_pkt, _dataPtr) \ (RTPKT_TO_OSPKT(_pkt)->data) = (_dataPtr)#define GET_OS_PKT_LEN(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->len)#define SET_OS_PKT_LEN(_pkt, _len) \ (RTPKT_TO_OSPKT(_pkt)->len) = (_len) #define GET_OS_PKT_DATATAIL(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->tail)#define SET_OS_PKT_DATATAIL(_pkt, _start, _len) \ ((RTPKT_TO_OSPKT(_pkt))->tail) = (PUCHAR)((_start) + (_len)) #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 SET_OS_PKT_NETDEV(_pkt, _pNetDev) \ (RTPKT_TO_OSPKT(_pkt)->dev) = (_pNetDev) #define GET_OS_PKT_TYPE(_pkt) \ (RTPKT_TO_OSPKT(_pkt))#define GET_OS_PKT_NEXT(_pkt) \ (RTPKT_TO_OSPKT(_pkt)->next)#define OS_PKT_CLONED(_pkt) skb_cloned(RTPKT_TO_OSPKT(_pkt))#define OS_NTOHS(_Val) \ (ntohs(_Val))#define OS_HTONS(_Val) \ (htons(_Val))#define OS_NTOHL(_Val) \ (ntohl(_Val))#define OS_HTONL(_Val) \ (htonl(_Val))#define CB_OFF 10// 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])//// 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])/* use bit3 of cb[CB_OFF+16] */#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/* [CB_OFF+28], 1B, 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+28] = _morebit)#define RTMP_GET_PACKET_NOBULKOUT(_p) (RTPKT_TO_OSPKT(_p)->cb[CB_OFF+28]) #endif // INF_AMAZON_SE ///* Max skb->cb = 48B = [CB_OFF+38] *//*********************************************************************************** * Other function prototypes definitions ***********************************************************************************/void RTMP_GetCurrentSystemTime(LARGE_INTEGER *time);int rt28xx_packet_xmit(struct sk_buff *skb);void FlashWrite(UCHAR * p, ULONG a, ULONG b);void FlashRead(UCHAR * p, ULONG a, ULONG b);#if LINUX_VERSION_CODE <= 0x20402 // Red Hat 7.1struct net_device *alloc_netdev(int sizeof_priv, const char *mask, void (*setup)(struct net_device *));#endif // LINUX_VERSION_CODE //INT rt28xx_ioctl( IN PNET_DEV net_dev, IN OUT struct ifreq *rq, IN INT cmd);#ifdef CONFIG_STA_SUPPORTINT rt28xx_sta_ioctl( IN PNET_DEV net_dev, IN OUT struct ifreq *rq, IN INT cmd);#endif // CONFIG_STA_SUPPORT //extern int ra_mtd_write(int num, loff_t to, size_t len, const u_char *buf);extern int ra_mtd_read(int num, loff_t from, size_t len, u_char *buf);#endif // __RT_LINUX_H__ //
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -