亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rtl81x9.c

?? 8139在vxworks平臺下的驅動
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* rtl81x9End.c - RealTek RTL81x9 Fast Ethernet interface header */

/* Copyright 1984-2000 Wind River Systems, Inc. */
/*
modification history
--------------------
01f,17feb00,dgy  Updated interrupt routine to ensure reserved interrupt
				 bits are masked out prior to checking status.
01e,16feb00,dgy  Updated rtl81x9HandleRecvInt to cover more checking within the 
				 loop that looks for RX biffer empty.
01d,16feb00,dgy  Updated rtl81x9Wait to fix problem whereby always timed as
				 checking incorrect register.
01c,28jan00,dgy  Updated comments that refered to the wrong files.
01c,28jan00,dgy  Updated comments that refered to the wrong files.
01b,28jan00,dgy  Changed ryl81x9CsrReadByte to use the correct SYS_IN
				 macro.
01a,29oct99,dgy  created
*/

/*
				Theory of Operation

I. Board Compatibility

This device driver is designed for the RealTek RTL81x9, the RealTek Fast
Ethernet controllers for PCI.  This chip is used on a few clone boards.


II. Board-specific settings

PCI bus devices are configured by the system at boot time, so no jumpers
need to be set on the board.  The system BIOS will assign the
PCI INTA signal to a (preferably otherwise unused) system IRQ line.

III. Driver operation

IIIa. Rx Ring buffers

The receive unit uses a single linear ring buffer rather than the more
common (and more efficient) descriptor-based architecture.  Incoming frames
are sequentially stored into the Rx region, and the host copies them into
mBlks.

IIIb. Tx operation

The RTL81x9 uses a fixed set of four Tx descriptors in register space.

EXTERNAL INTERFACE
The only external interface is the rtl81x9EndLoad() routine, which expects
the <initString> parameter as input.  This parameter passes in a 
colon-delimited string of the format:

<unit>:<devMemAddr>:<devIoAddr>:<pciMemBase:<vecNum>:<intLvl>:<memAdrs>:
<memSize>:<memWidth>:<flags>:<buffMultiplier>

The el3c90xEndLoad() function uses strtok() to parse the string.

TARGET-SPECIFIC PARAMETERS
.IP <unit>
A convenient holdover from the former model.  This parameter is used only
in the string name for the driver.

.IP <devMemAddr>
This parameter in the memory base address of the device registers in the
memory map of the CPU. It indicates to the driver where to find the
register set. < This parameter should be equal to NONE if the device
does not support memory mapped registers.


.IP <devIoAddr>
This parameter in the IO base address of the device registers in the
IO map of some CPUs. It indicates to the driver where to find the RDP
register. If both <devIoAddr> and <devMemAddr> are given then the device
chooses <devMemAddr> which is a memory mapped register base address.
This parameter should be equal to NONE if the device does not support 
IO mapped registers.


. <pciMemBase>
This parameter is the base address of the CPU memory as seen from the
PCI bus. This parameter is zero for most intel architectures.

.IP <vecNum>
This parameter is the vector associated with the device interrupt.
This driver configures the LANCE device to generate hardware interrupts
for various events within the device; thus it contains
an interrupt handler routine.  The driver calls intConnect() to connect 
its interrupt handler to the interrupt vector generated as a result of 
the LANCE interrupt.

.IP <intLvl>
Some targets use additional interrupt controller devices to help organize
and service the various interrupt sources.  This driver avoids all
board-specific knowledge of such devices.  During the driver's
initialization, the external routine sysRtl81x9IntEnable() is called to
perform any board-specific operations required to allow the servicing of a
NIC interrupt.  For a description of sysRtl81x9IntEnable(), see "External
Support Requirements" below.

.IP <memAdrs>
This parameter gives the driver the memory address to carve out its
buffers and data structures. If this parameter is specified to be
NONE then the driver allocates cache coherent memory for buffers
and descriptors from the system pool.
The 3C90x NIC is a DMA type of device and typically shares access to
some region of memory with the CPU.  This driver is designed for systems
that directly share memory between the CPU and the NIC.  It
assumes that this shared memory is directly available to it
without any arbitration or timing concerns.

.IP <memSize>
This parameter can be used to explicitly limit the amount of shared
memory (bytes) this driver will use.  The constant NONE can be used to
indicate no specific size limitation.  This parameter is used only if
a specific memory region is provided to the driver.

.IP <memWidth>
Some target hardware that restricts the shared memory region to a
specific location also restricts the access width to this region by
the CPU.  On these targets, performing an access of an invalid width
will cause a bus error.

This parameter can be used to specify the number of bytes of access
width to be used by the driver during access to the shared memory.
The constant NONE can be used to indicate no restrictions.

Current internal support for this mechanism is not robust; implementation 
may not work on all targets requiring these restrictions.

.IP <flags>
This is parameter is used for future use, currently its value should be
zero.


EXTERNAL SUPPORT REQUIREMENTS
This driver requires several external support functions, defined as macros:
.CS
    SYS_INT_CONNECT(pDrvCtrl, routine, arg)
    SYS_INT_DISCONNECT (pDrvCtrl, routine, arg)
    SYS_INT_ENABLE(pDrvCtrl)
    SYS_INT_DISABLE(pDrvCtrl)
    SYS_OUT_BYTE(pDrvCtrl, reg, data)
    SYS_IN_BYTE(pDrvCtrl, reg, data)
    SYS_OUT_WORD(pDrvCtrl, reg, data)
    SYS_IN_WORD(pDrvCtrl, reg, data)
    SYS_OUT_LONG(pDrvCtrl, reg, data)
    SYS_IN_LONG(pDrvCtrl, reg, data)
    SYS_DELAY (delay)
    sysEl3c90xIntEnable(pDrvCtrl->intLevel) 
    sysEl3c90xIntDisable(pDrvCtrl->intLevel)
    sysDelay (delay)
.CE

There are default values in the source code for these macros.  They presume
memory mapped accesses to the device registers and the normal intConnect(),
and intEnable() BSP functions.  The first argument to each is the device
controller structure. Thus, each has access back to all the device-specific
information.  Having the pointer in the macro facilitates the addition 
of new features to this driver.

The macros SYS_INT_CONNECT, SYS_INT_DISCONNECT, SYS_INT_ENABLE and
SYS_INT_DISABLE allow the driver to be customized for BSPs that use special
versions of these routines.

The macro SYS_INT_CONNECT is used to connect the interrupt handler to
the appropriate vector.  By default it is the routine intConnect().

The macro SYS_INT_DISCONNECT is used to disconnect the interrupt handler prior
to unloading the module.  By default this is a dummy routine that
returns OK.

The macro SYS_INT_ENABLE is used to enable the interrupt level for the
end device.  It is called once during initialization.  It calls an
external board level routine sysRtl81x9IntEnable(). 

The macro SYS_INT_DISABLE is used to disable the interrupt level for the
end device.  It is called during stop.  It calls an
external board level routine sysRtl81x9IntDisable().

The macro SYS_DELAY is used for a delay loop. It calls an external board
level routine sysDelay(delay). The granularity of delay is one microsecond.

SYSTEM RESOURCE USAGE
When implemented, this driver requires the following system resources:

    - one mutual exclusion semaphore
    - one interrupt vector
    - 24072 bytes in text for a I80486 target
    - 112 bytes in the initialized data section (data)
    - 0 bytes in the uninitialized data section (BSS)

The driver allocates clusters of size 1536 bytes for receive frames and
and transmit frames. There are 16 descriptors in the upload ring
and 16 descriptors in the download ring. The buffer multiplier by default
is 2, which means that the total number of clusters allocated by default
are 64 ((upload descriptors + download descriptors)*2). There are as many
clBlks as the number of clusters. The number of mBlks allocated are twice
the number of clBlks. By default there are 64 clusters, 64 clBlks and 128
mBlks allocated in the pool for the device. Depending on the load of the
system increase the number of clusters allocated by incrementing the buffer
multiplier.


INCLUDES:
end.h endLib.h etherMultiLib.h rtl81x9End.h

SEE ALSO: muxLib, endLib, netBufLib
.pG "Writing and Enhanced Network Driver"

*/

#define END_MACROS

#include "vxWorks.h"
#include "wdLib.h"
#include "stdlib.h"
#include "taskLib.h"
#include "logLib.h"
#include "intLib.h"
#include "netLib.h"
#include "stdio.h"
#include "stdlib.h"
#include "sysLib.h"
#include "iv.h"
#include "memLib.h"
#include "semLib.h"
#include "cacheLib.h"
#include "sys/ioctl.h"
#include "etherLib.h"
#include "ioLib.h"

#ifndef DOC             /* don't include when building documentation */
#include "net/mbuf.h"
#endif  /* DOC */

#include "net/protosw.h"
#include "sys/socket.h"
#include "errno.h"
#include "net/if.h"
#include "net/route.h"
#include "netinet/in.h"
#include "netinet/in_systm.h"
#include "netinet/in_var.h"
#include "netinet/ip.h"
#include "netinet/if_ether.h"
#include "net/if_subr.h"
#include "m2Lib.h"
#include "etherMultiLib.h"		/* multicast stuff. */
#include "end.h"			/* Common END structures. */
#include "netBufLib.h"
#include "muxLib.h"

#include "endLib.h"
#include "lstLib.h"			/* Needed to maintain protocol list. */


/***** LOCAL DEFINITIONS *****/
#include "drv/end/unsupported/rtl81x9.h"

#ifdef	DRV_DEBUG
	int	rtl81x9Debug = 0; /* Turn it off initially. */
#endif /* DRV_DEBUG */

/* network buffers configuration */

M_CL_CONFIG rtlMclConfig = 	/* mBlk configuration table */
    {
    0, 0, NULL, 0
    };

CL_DESC rtlClDesc [] = 	/* network cluster pool configuration table */
    {
    /* 
    clusterSize	num		memArea		memSize
    -----------	----		-------		-------
    */
    {RTL_BUFSIZ,		0,	NULL,		0}
    }; 

int rtlClDescNumEnt = (NELEMENTS(rtlClDesc));


#define END_FLAGS_ISSET(pEnd, setBits)                                  \
            ((pEnd)->flags & (setBits))

#define END_HADDR(pEnd)                                                 \
		((pEnd)->mib2Tbl.ifPhysAddress.phyAddress)

#define END_HADDR_LEN(pEnd)                                             \
		((pEnd)->mib2Tbl.ifPhysAddress.addrLength)

/*
 * Default macro definitions for BSP interface.
 * For X86 arch, the intConnect/Disconnect defaults are pciIntConnect and
 * pciIntDisconnect.  For all others it is just intConnect and a dummy
 * disconnect function.
 * HELP: This needs to be fixed by porting pciIntLib to all architectures.
 */


#if CPU_FAMILY == I80X86
#ifndef SYS_INT_CONNECT
#define SYS_INT_CONNECT(pDrvCtrl,rtn,arg,pResult)                       \
    {                                                                   \
    IMPORT STATUS pciIntConnect();                                      \
    *pResult = pciIntConnect ((VOIDFUNCPTR *)INUM_TO_IVEC (pDrvCtrl->ivec),\
			     (rtn), (int)(arg));                        \
    }
#endif	/* SYS_INT_CONNECT */

#ifndef SYS_INT_DISCONNECT
#define SYS_INT_DISCONNECT(pDrvCtrl,rtn,arg,pResult)                    \
    {                                                                   \
    IMPORT STATUS pciIntDisconnect();                                      \
    *pResult = pciIntDisconnect ((VOIDFUNCPTR *)INUM_TO_IVEC (pDrvCtrl->ivec),\
			     (rtn));		                        \
    }
#endif /* SYS_INT_DISCONNECT */

#else /* CPU_FAMILY == I80X86 */

#ifndef SYS_INT_CONNECT
#define SYS_INT_CONNECT(pDrvCtrl,rtn,arg,pResult)                       \
    {                                                                   \
    IMPORT STATUS intConnect();                                      \
    *pResult = intConnect ((VOIDFUNCPTR *)INUM_TO_IVEC (pDrvCtrl->ivec),\
			     (rtn), (int)(arg));                        \
    }
#endif /*SYS_INT_CONNECT*/

#ifndef SYS_INT_DISCONNECT
#define SYS_INT_DISCONNECT(pDrvCtrl,rtn,arg,pResult)                    \
    {                                                                   \
    *pResult = OK;							\
    }
#endif /*SYS_INT_DISCONNECT*/


#endif /* CPU_FAMILY == I80X86 */

/* Macro to enable the appropriate interrupt level */

#ifndef SYS_INT_ENABLE
#define SYS_INT_ENABLE(pDrvCtrl) \
    { \
    IMPORT STATUS sysRtl81x9IntEnable(); \
    sysRtl81x9IntEnable ((pDrvCtrl)->ilevel); \
    }
#endif /* SYS_INT_ENABLE*/

/* Macro to disable the appropriate interrupt level */

#ifndef SYS_INT_DISABLE
#define SYS_INT_DISABLE(pDrvCtrl) \
    { \
    IMPORT void sysRtl81x9IntDisable (); \
    sysRtl81x9IntDisable ((pDrvCtrl)->ilevel); \
    }
#endif

#ifndef SYS_OUT_LONG
#define SYS_OUT_LONG(pDrvCtrl,addr,value) \
    { \
    *((ULONG *)(addr)) = PCI_SWAP((value)); \
    }
#endif /* SYS_OUT_LONG */

#ifndef SYS_IN_LONG
#define SYS_IN_LONG(pDrvCtrl,addr,data) \
    { \
    ((data) = PCI_SWAP(*((ULONG *)(addr)))); \
    }
#endif /* SYS_IN_LONG */

#ifndef SYS_OUT_SHORT
#define SYS_OUT_SHORT(pDrvCtrl,addr,value) \
    { \
    *((USHORT *)(addr)) = PCI_WORD_SWAP((value)); \
    }
#endif /* SYS_OUT_SHORT*/

#ifndef SYS_IN_SHORT
#define SYS_IN_SHORT(pDrvCtrl,addr,data) \
    { \
    ((data) = PCI_WORD_SWAP(*((USHORT *)(addr)))); \
    }      
#endif /* SYS_IN_SHORT*/

#ifndef SYS_OUT_BYTE
#define SYS_OUT_BYTE(pDrvCtrl,addr,value) \
    { \
    *((UCHAR *)(addr)) = (value); \
    }
#endif /* SYS_OUT_BYTE */

#ifndef SYS_IN_BYTE
#define SYS_IN_BYTE(pDrvCtrl,addr,data) \
    { \
    ((data) = *((UCHAR *)(addr))); \
    }
#endif /* SYS_IN_BYTE */

#ifndef SYS_OUT_SHORT_CSR
#define SYS_OUT_SHORT_CSR(pDrvCtrl,addr,value) \
    { \
    *(USHORT *)addr = value; \
    }
#endif /*SYS_OUT_SHORT_CSR*/

#ifndef SYS_IN_SHORT_CSR
#define SYS_IN_SHORT_CSR(pDrvCtrl,addr,pData) \
    (*(USHORT *)pData = *(USHORT *)addr)
#endif /*SYS_IN_SHORT_CSR*/


#define SYS_DELAY(count)	{                                               \
			volatile int cx = 0;                            \
			for (cx = 0; cx < (count); cx++);               \
			}

#ifndef SYS_ENET_ADDR_GET
#define SYS_ENET_ADDR_GET(pDrvCtrl, pAddress) \
    { \
    IMPORT STATUS sysRtl81x9EnetAddrGet (RTL81X9END_DEVICE *pDrvCtrl, \
                                     char * enetAdrs); \
    sysRtl81x9EnetAddrGet (pDrvCtrl, pAddress); \
    }
#endif /* SYS_ENET_ADDR_GET */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利视频一区二区三区| 日韩专区一卡二卡| 成人午夜短视频| 欧美韩日一区二区三区| 国产一区二区调教| 国产精品久久久久久久久动漫| www.亚洲国产| 一区二区三区欧美在线观看| 欧美视频一区二区在线观看| 午夜精彩视频在线观看不卡| 日韩欧美资源站| 粉嫩蜜臀av国产精品网站| 国产精品久久久久毛片软件| 色屁屁一区二区| 青青国产91久久久久久| 久久天天做天天爱综合色| 国产乱国产乱300精品| 中文字幕亚洲综合久久菠萝蜜| 色综合视频一区二区三区高清| 亚洲成人综合网站| 久久嫩草精品久久久久| 91最新地址在线播放| 日本aⅴ亚洲精品中文乱码| 亚洲精品一区二区三区蜜桃下载 | 色妞www精品视频| 日本美女视频一区二区| 国产日韩欧美综合在线| 欧美天堂一区二区三区| 国产毛片精品视频| 伊人一区二区三区| 亚洲精品一区二区三区香蕉| 色av综合在线| 高清成人免费视频| 天涯成人国产亚洲精品一区av| 久久久国产综合精品女国产盗摄| 丁香激情综合国产| 日本三级韩国三级欧美三级| 国产精品久久久爽爽爽麻豆色哟哟| 欧美日韩情趣电影| av一本久道久久综合久久鬼色| 亚洲超碰97人人做人人爱| 国产欧美一区二区精品久导航| 欧美午夜精品免费| 成人免费不卡视频| 麻豆免费看一区二区三区| 曰韩精品一区二区| 国产日本亚洲高清| 日韩欧美一二三四区| 日本精品一级二级| 成人av在线播放网站| 韩国视频一区二区| 日本成人在线不卡视频| 一区二区在线观看视频在线观看| 久久综合一区二区| 91精品福利在线一区二区三区| 色综合视频在线观看| 高清成人在线观看| 国产精品资源站在线| 麻豆精品新av中文字幕| 亚洲国产va精品久久久不卡综合 | 亚洲人成精品久久久久| 国产亚洲一区字幕| 精品区一区二区| 欧美一区二区久久| 欧美精品少妇一区二区三区| 日本精品裸体写真集在线观看| 97精品国产97久久久久久久久久久久 | 久久久国产精品午夜一区ai换脸| 欧美一区二区三区免费大片| 欧美日韩视频在线第一区| 欧美亚洲综合色| 91美女视频网站| 91丨porny丨国产| 色综合久久综合中文综合网| 国产69精品一区二区亚洲孕妇| 极品少妇一区二区| 国产一区二区三区不卡在线观看 | 国产老妇另类xxxxx| 激情五月婷婷综合| 国产一区三区三区| 国产成人免费视频| av亚洲精华国产精华精华| 99精品1区2区| 欧美影视一区二区三区| 欧美精品丝袜中出| 精品美女在线播放| 国产精品网曝门| 亚洲日本欧美天堂| 亚洲福利视频导航| 日本不卡的三区四区五区| 久久91精品国产91久久小草| 国产乱码精品一品二品| av中文字幕在线不卡| 在线观看视频一区二区欧美日韩| 在线观看www91| 91精品国产免费| 337p粉嫩大胆色噜噜噜噜亚洲| 国产欧美日韩另类一区| 1024成人网| 调教+趴+乳夹+国产+精品| 久久99久久99小草精品免视看| 国产aⅴ综合色| 色综合中文字幕国产 | 亚洲一区二区综合| 日本不卡在线视频| 成人一区二区三区视频在线观看| 91麻豆福利精品推荐| 欧美猛男男办公室激情| 久久色中文字幕| 自拍偷拍欧美激情| 捆绑调教美女网站视频一区| 国产老妇另类xxxxx| 在线观看亚洲专区| 久久影院午夜片一区| 亚洲精选免费视频| 久久精品噜噜噜成人av农村| jizz一区二区| 欧美一级免费观看| 成人欧美一区二区三区视频网页| 午夜亚洲国产au精品一区二区| 国产精品12区| 3d动漫精品啪啪一区二区竹菊| 国产丝袜美腿一区二区三区| 亚洲mv在线观看| 99久久综合精品| 日韩你懂的在线播放| 一区二区三区91| 国产精品影视在线观看| 欧美日韩成人激情| 国产精品久线观看视频| 热久久免费视频| 一本久道中文字幕精品亚洲嫩| 日韩欧美电影一二三| 洋洋av久久久久久久一区| 国产91在线|亚洲| 日韩三级电影网址| 亚洲成av人片www| 色偷偷久久一区二区三区| 久久精品亚洲国产奇米99| 日日夜夜精品视频天天综合网| 99久久99久久久精品齐齐| 久久一区二区三区四区| 五月婷婷久久综合| 91色.com| 自拍偷拍亚洲激情| 粉嫩aⅴ一区二区三区四区| 欧美一区二区免费视频| 亚洲国产精品自拍| 色又黄又爽网站www久久| 国产欧美日韩不卡| 国产精品一区二区在线观看网站 | 欧美三级在线看| 中文字幕一区二| 国产91精品精华液一区二区三区| 精品久久久久久久久久久久久久久 | 色欧美88888久久久久久影院| 国产精品久久久久7777按摩| 韩国一区二区在线观看| www国产精品av| 极品少妇xxxx偷拍精品少妇| 91精品国产一区二区三区蜜臀| 亚洲国产精品久久人人爱 | 裸体一区二区三区| 91精品国产91热久久久做人人| 亚洲444eee在线观看| 欧美日韩中文另类| 亚洲成在人线在线播放| 欧美美女直播网站| 日本伊人色综合网| 日韩精品一区二区三区蜜臀| 轻轻草成人在线| 精品国产一区二区三区忘忧草 | 自拍偷拍亚洲综合| 一本到不卡免费一区二区| 亚洲欧美日韩中文播放| 一本大道久久a久久精二百 | 午夜精品久久久久久久99水蜜桃| 欧美在线免费视屏| 午夜日韩在线观看| 制服丝袜亚洲播放| 黄网站免费久久| 久久久影视传媒| av欧美精品.com| 一区二区三区精密机械公司| 欧美视频在线不卡| 丝袜亚洲另类欧美综合| 日韩免费观看高清完整版| 国产麻豆精品视频| 亚洲视频图片小说| 欧美精品欧美精品系列| 久久99日本精品| 国产精品女人毛片| 欧美色倩网站大全免费| 六月丁香婷婷色狠狠久久| 国产精品女人毛片| 91.xcao| 国产精品主播直播| 亚洲妇熟xx妇色黄| 久久精品视频一区| 色偷偷久久一区二区三区|