⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rt_linux.h

📁 ralink 2870 usb无线网卡 最新驱动
💻 H
📖 第 1 页 / 共 2 页
字号:
})
#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 + -