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

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

?? cssysend.c

?? cs8900在vxworks系統下的驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* csSysEnd.c - PCx86 or ARM system-dependent module for CS8900 Ethernet driver */
/*                                                                          */
/* Copyright 2000 Crystal Semiconductor Corp.                               */
/*                                                                          */
/*               Last release: v3.05a                                       */
/* Mod level for last release: 05a                                          */

/*
MODIFICATION HISTORY
--------------------
v3.05a,06/26/01, kml - Added Support for Interrupt Level and Interrupt Vector for 
                       Non-Ix86 processors. 
					 - Added CS8900_INTERRUPT_REQUEST_PIN_NUM for Non-Ix86 processors to 
					   write their interrupt pin number to InterruptNumber Register.
                     - Modified the code so that logMsg is used only when CS_DEBUG_ENABLE is
					   defined.  Thus, compiler warning mesages can be avoided if 
					   CS_DEBUG_ENABLE is not defined.
                     - Added "Define your BSP Type" for users to define their
					   CS_BSP_TYPE string.


v3.03a,10/02/00, kml -Merged for PCx86 and ARM.

   June 20000        -Modified for ARM 940 by Conexant Systems, Inc.                     

v3.02a,24Sep99, kml  -Set offset 2 to the receiving buffer pointer when copying received frames from chip
                      so that the IP header stars from the 17th bytes for 32-bits-Alignment.
                     -Change receiving buffer size from 32 to 64.
                     -Correction: If the memory address parameter is zero, the CS8900 operates in the
                      mode specified by EEPROM or the Config Flag parameter.

v3.01a,07May, kml    ported to the Enhanced Network Driver (END) model 
                       to support the MUX interface:  


10f,11apr97,rks  Added variables for "early tx" support to CS_END_DEVICE structure
                 (TxUnderruns, TotalTxUnderruns, TxStartCMD, and TxLenght.

10e,05apr97,rks  Added CS_MAX_NET_JOBS and STRESS_TESTING defines.

10d,11mar97,rks  Moved some typedefs to this file so "config.h" could include
                 "if_cs.h" easily. 

01c,25feb97,rks  Changed SysEnetAddrGet parameters to Unit, IA addr pointer

01b,31jan97,rks  Modified sysEnetAddrGet to take Ethernet address from EEPROM
                 or from the csEnetAddr array based on the value of the 
                 GET_ENET_ADDR_FROM_BOARD flag.
		 
01a,16dec96,rks  Written (using routines originally written by q_s in "if_cs.c".
*/


/*
DESCRIPTION

This module provides PCx86 and ARM board-specific routines and data types require
by the Crystal Semiconductor CS8900 Ethernet VxWorks END network interface driver.  
It implements five routines called from the "csEnd.c" main driver module:

* sysEnetGetConfig( CS_END_DEVICE *pCS )
This routine takes configuration parameters not specifed to csLoad(), if any,
from non-volatile storage (e.g. an attached EEPROM) and puts them in the 
CS_END_DEVICE structure. If all the parameters were specified to csLoad(), then 
this routine does not attempt to read the EEPROM.

* sysEnetAddrGet( CS_END_DEVICE pCS, unsigned char *pAddr )
This routine obtains the Ethernet MAC address from non-volatile storage or from 
the "csEnetAddr" array defined in csSysEnd.c and saves it in the CS_END_DEVICE
structure.

* sysEnetHWInit( CS_END_DEVICE *pCS )
This routine uses global variables in the CS_END_DEVICE structure to configure the 
adapter for the board-specific IO circuitry and supported media types.

* sysEnetIntEnable( CS_END_DEVICE *pCS )
This routine enables the interrupt used by the CS8900 at the system level. 
 
* sysEnetIntDisable( CS_END_DEVICE *pCS )
This routine disables the interrupt used by the CS8900 at the system level.  
*/



/* DEFINES */
#ifdef CPU_FAMILY
#undef CPU_FAMILY
#endif

#ifdef _BYTE_ORDER
#undef _BYTE_ORDER
#endif

#define CPU_FAMILY    ARM 
#define _BYTE_ORDER    _LITTLE_ENDIAN 
/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *
 * Driver Configuration Defines                                            *
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */

/* Maximum number of CS8900 chips supported */

#define CS_MAX_NUM_UNITS        1 


/* Maximum number of receive buffers */ 
     
#define CS_NUM_RX_BUFFERS      64

/* Minimum bytes of first buffer for chain used by scattered transmission. */
#define CS_MIN_FBUF  5

/* Number of elements held by TX and RX queues */
#define CS_QUEUE_SIZE  200  /* @kml */


/* Initial TXStartCMD (number of bytes to buffer before CS8900 starts the TX */
/* Select one of: [TX_CMD_START_5 | TX_CMD_START_381 | TX_CMD_START_1021 | 
 * TX_CMD_START_ALL ] */

#define CS_INITIAL_START_CMD	TX_CMD_START_5

/* Number of underruns with current TXStartCMD before TXStartCMD is set to next value */

#define CS_TX_UNDRUN_TRHSHOLD   2 

/* BSP type supported by this driver */ 
#if CPU_FAMILY ==  ARM 
#define CS_BSP_TYPE	"ARM"

#elif  CPU_FAMILY ==  MIPS         
#define CS_BSP_TYPE	"MIPS"

#elif  CPU_FAMILY == I80X86
#define CS_BSP_TYPE	"i[3|4]86"

#else
#define CS_BSP_TYPE	"Unknown BSP Type"
#endif

/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *
 * Miscellaneous and BSP-specific defines                                  *
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */

/* Define a unique cluster type */

/* 
This flag determines if the Ethernet address is taked from EEPROM or from
the csEnetAddr array defined below.  Define as 0 to take the Ethernet address
from csEnetAddr.  WARNING! The Ethernet address must be unique for each Ethernet
device on the network.
*/

#define GET_ENET_ADDR_FROM_BOARD  1

/* 
These macros are used to communicate with the CS8900. These functions need to be supplied 
by syslib.c
*/
 
/* Macros used to provide platform independence for IO accesses */

#if CPU_FAMILY ==  ARM
#define SYS_ENET_OUT_WORD(port, value)	sysOutWord((int)(port), (value))
#define SYS_ENET_IN_WORD(port)			sysInWord((int)(port))
#define SYS_ENET_IN_BYTE(port)			sysInByte((int)(port))
#else
#define SYS_ENET_OUT_WORD(port, value)	sysOutWord(port, value)
#define SYS_ENET_IN_WORD(port)			sysInWord(port)
#define SYS_ENET_IN_BYTE(port)			sysInByte(port)
#endif


/*add by syx*/
#define EXTINT1 0x5600008C
#define GPGCON  0x56000060
#define BWSCON 0x48000000
#define BANKCON2 0x4800000C
/*end add*/


/* TYPEDEFS */

/* Individual Address (Ethernet Address) */
typedef struct
{
   USHORT word[3];
} IA, *PIA;



typedef struct 
{
    void  *Queue[CS_QUEUE_SIZE+1];
    int    Head;
    int    Tail;   
} CIR_QUEUE; 


#if CPU_FAMILY ==  ARM
typedef unsigned long IOADDR;    /* IO space address is 32-bit */
#else
typedef unsigned short IOADDR;    /* IO space address is 16-bit */
IMPORT UINT sysVectorIRQ0;           /* vector for IRQ0 */
#endif

/* Driver control structure for a single unit */

typedef struct
{
   END_OBJ    end;
   int        unit;
   UCHAR      enetAddr[6];
   IOADDR     IOAddr;
   USHORT     IntLevel;
   USHORT     IntVector;
   unsigned short    *pPacketPage;      
   USHORT     MediaType;
   USHORT     ConfigFlags;
   BOOL       InMemoryMode;
   BOOL       Resetting;
   USHORT     MaxTxDepth;
   USHORT     TxQueueDepth;
   USHORT     MaxTxQueueDepth;
   UINT	      Rdy4TxInts;
   M_BLK_ID   pTxFrameChain;
   BOOL       TxInProgress;
   BOOL       InISR;
   CIR_QUEUE *pTxBuffFreeList;
   CIR_QUEUE *pRxBuffProcessList;
   CIR_QUEUE *pTxQueue;
   UINT	      NetJobDepth;
   USHORT     TxStartCMD;
   USHORT     TxUnderruns;
   UINT       TotalTxUnderruns;
   UINT       TxLength;
   UINT       Collisions;
   CL_POOL_ID pClPoolId;
   USHORT     MulticastTable[4];
} CS_END_DEVICE;



/* Define GET_ENET_ADDR_FROM_BOARD as 0 to take the Ethernet address
from csEnetAddr.  */

/* LOCALS */
unsigned char csEnetAddr [6] = { 0x08, 0x00, 0x20, 0x74, 0x80, 0xa7 };

/* Instance variables */
LOCAL CS_END_DEVICE cs_end[CS_MAX_NUM_UNITS];  
CIR_QUEUE TxBuffFreeList;
CIR_QUEUE RxBuffProcessList;
CIR_QUEUE TxQueue;



/* For ARM user only:   */
/* The following code is specific for Conexant IRD, ARM 940. You can take it as an
   example or ignore it. */

/* @Conexant ARM 940 specific code */ 
/*
#include "basetype.h"
#include "sabine.h"
#include "hwconfig.h"
#include "hwlib.h"
#include "retcodes.h"

extern  PFNISR  ethernetChainNode;  // ISR linked list node storage
extern  void csIntr(CS_END_DEVICE *arg);

CS_END_DEVICE *EndObject;

int ethernetIntHandler(unsigned int IntID, int FIQ, PFNISR *nextNode)
{

    csIntr(EndObject);
    *nextNode = ethernetChainNode;
    return(RC_ISR_NOTHANDLED);  // All PCI ints return this
}

void    init_cs8900(void)
{

   // Set the memory base address
   SYS_ENET_OUT_WORD(0x3150030a, 0x002c);
   SYS_ENET_OUT_WORD(0x3150030c, 0x0000);
   SYS_ENET_OUT_WORD(0x3150030a, 0x002e);
   SYS_ENET_OUT_WORD(0x3150030c, 0x0000);

   int_register_isr(INT_GPIO68, (PFNISR)ethernetIntHandler, FALSE, FALSE,
                   &ethernetChainNode);
   set_gpio_int_edge(68, POS_EDGE);
}    



int    sysCsIntAck(void)
{
    
    clear_pic_interrupt(PIC_GPIO, INT_GPIO68);
    return 1;
}
*/
/* end of Conexant IRD, ARM 940 */



/* Crystal Semiconductor supplied code */

/* FORWARD DECLARATIONS */
LOCAL STATUS sysEnetGetConfig( CS_END_DEVICE *pCS );
LOCAL STATUS sysEnetAddrGet( CS_END_DEVICE *pCS, unsigned char *pAddr ); /*@kml*/
LOCAL void   sysEnetHWInit( CS_END_DEVICE *pCS );
LOCAL STATUS sysEnetIntEnable( CS_END_DEVICE *pCS );
LOCAL STATUS sysEnetIntDisable( CS_END_DEVICE *pCS );  /*@kml*/


/* sub-routines for above functions */

LOCAL STATUS csGetUnspecifiedParms( CS_END_DEVICE *pCS );
LOCAL STATUS csValidateParms( CS_END_DEVICE *pCS );
LOCAL STATUS csReadEEPROM( CS_END_DEVICE *pCS, USHORT Offset, USHORT *pValue );

#ifdef TRUE
/* These routines defined in csEnd.c but available for use here. */
/* Ifdef FALSE if none are called from this module */
#define DECLARED_IN_SYS_ENET
LOCAL USHORT csReadPacketPage( CS_END_DEVICE *pCS, USHORT Offset );
LOCAL void   csWritePacketPage( CS_END_DEVICE *pCS, USHORT Offset, USHORT Value );
#endif


#define MAXLOOP       0x8888  /* Delay loop counter  */        


/******************************************************************************
*
* sysEnetGetConfig - Get any CS8900 parameters not specifed to csLoad
*
* This routine gets parameters that were not specifed to csAttach() from an 
* EEPROM, if used, and puts them in the CS_END_DEVICE structure.  If all the 
* parameters were specified to csAttach(), then this routine does not attempt 
* to read the EEPROM.
*
* RETURNS: OK or ERROR
*
*/

LOCAL STATUS sysEnetGetConfig( CS_END_DEVICE *pCS )
{
	/* Get parameters, which were not specified, from the EEPROM */
   if ( csGetUnspecifiedParms(pCS) == ERROR )
      return ERROR;

	/* Verify that parameters are valid */
   if ( csValidateParms(pCS) == ERROR )
      return ERROR;

   /* If memory address was specified but configuration flags were not */
   if ( pCS->pPacketPage != 0  )
      pCS->ConfigFlags |= CFGFLG_MEM_MODE;  /* Implictly set memory mode */

   /* If the interrupt vector was not specified then derive it */
   if ( pCS->IntVector == 0 ) {
#if CPU_FAMILY == I80X86
    pCS->IntVector = sysVectorIRQ0 + pCS->IntLevel;
#else
     pCS->IntVector = pCS->IntLevel;
#endif
   }
	return OK;
}


/*******************************************************************************
*
* sysEnetAddrGet - saves the Ethernet address to the CS_END_DEVICE structure
*
* The Ethernet address is taked from EEPROM or from the csEnetAddr array 
* then the Ethernet address was saved in the CS_END_DEVICE structure.
*
* pAddr: the pointer points to the array holding Ethernet Addr in CA_END_DEVICE
*
* RETURNS: OK or ERROR
*/

LOCAL STATUS sysEnetAddrGet( CS_END_DEVICE *pCS, unsigned char *pAddr )
{
   USHORT SelfStatus;
   PIA pIA;


   /* Setup pointer for the Ethernet address */
   pIA = (PIA)pAddr;

   /* If the Ethernet address in EEPROM */
   if ( GET_ENET_ADDR_FROM_BOARD )   /* defined in config.h */
   {
      /* Verify that the EEPROM is present and OK */
      SelfStatus = csReadPacketPage( pCS, PKTPG_SELF_ST );
      if ( !((SelfStatus & SELF_ST_EEP_PRES) && (SelfStatus & SELF_ST_EEP_OK)))
      {
#ifdef CS_DEBUG_ENABLE
         logMsg("\ncs0 - EEPROM is missing or bad\n",0,0,0,0,0,0);
#endif
         return ERROR;
      }

      /* Get Ethernet address from the EEPROM */
      if ( csReadEEPROM(pCS,EEPROM_IND_ADDR_H,&pIA->word[0]) == ERROR )
         return ERROR;
      if ( csReadEEPROM(pCS,EEPROM_IND_ADDR_M,&pIA->word[1]) == ERROR )
         return ERROR;
      if ( csReadEEPROM(pCS,EEPROM_IND_ADDR_L,&pIA->word[2]) == ERROR )
         return ERROR;
   }
   else  /* Use Ethernet Address defined in csEnetAddr */
      bcopyBytes ((char *) csEnetAddr, (char *) pIA, 6);

   return OK;
}


/*******************************************************************************
*
* sysEnetHWInit - configure the adapter for board-specific IO and media support
*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一二三区视频在线观看| 日韩欧美中文字幕制服| 亚洲成人久久影院| 高清视频一区二区| 欧美精品一卡两卡| 婷婷夜色潮精品综合在线| 色嗨嗨av一区二区三区| 亚洲乱码国产乱码精品精的特点| 国产黑丝在线一区二区三区| 欧美电影免费观看高清完整版| 亚洲777理论| 91精品国产色综合久久| 亚洲欧美一区二区不卡| 色妞www精品视频| 亚洲精品午夜久久久| 99久久久国产精品免费蜜臀| 亚洲欧美激情视频在线观看一区二区三区| eeuss鲁片一区二区三区在线观看| 精品福利视频一区二区三区| 乱一区二区av| 欧美韩日一区二区三区四区| 本田岬高潮一区二区三区| 一区二区三区在线播| 欧美人与z0zoxxxx视频| 九色porny丨国产精品| 久久久精品人体av艺术| 国产精品一线二线三线精华| 激情国产一区二区| 国产日韩欧美精品在线| 一本大道av伊人久久综合| 婷婷成人激情在线网| 日韩免费福利电影在线观看| 国产精品中文字幕日韩精品| 国产精品国产自产拍在线| 91福利在线看| 久久成人羞羞网站| 亚洲少妇30p| 在线观看日韩一区| 久久99国产精品麻豆| 国产精品美女久久久久久久久久久 | 亚洲欧美激情在线| 精品久久免费看| 一本一本久久a久久精品综合麻豆| 免费成人美女在线观看.| 亚洲欧美日韩国产一区二区三区| 欧美电影免费提供在线观看| 色av成人天堂桃色av| 欧美一区二区三区免费在线看| 成人白浆超碰人人人人| 久久国产婷婷国产香蕉| 午夜激情一区二区| 亚洲综合一区二区精品导航| 国产免费成人在线视频| 精品国产免费一区二区三区香蕉| 欧美曰成人黄网| 成人免费看视频| 国产精品一区二区久久精品爱涩| 免费看日韩a级影片| 无吗不卡中文字幕| 亚洲综合色区另类av| 亚洲黄色av一区| 日韩毛片高清在线播放| 国产精品美女久久久久aⅴ | 午夜精品久久久久久久久久 | 制服丝袜亚洲精品中文字幕| 色综合一区二区三区| 99视频超级精品| 91在线免费看| 91丨porny丨蝌蚪视频| 99视频精品在线| 色综合久久天天综合网| 91女神在线视频| 91精彩视频在线观看| 91麻豆免费看| 在线免费观看成人短视频| 色婷婷综合久久久中文一区二区| 9人人澡人人爽人人精品| 91视视频在线观看入口直接观看www| 国产成人精品在线看| 波多野结衣在线aⅴ中文字幕不卡| 成人激情电影免费在线观看| aa级大片欧美| 91国在线观看| 欧美乱妇20p| 日韩视频在线你懂得| 久久综合九色综合久久久精品综合| 精品久久久久一区二区国产| 精品sm在线观看| 国产欧美日韩三级| 中文字幕日韩一区| 亚洲一区二区三区四区在线| 日韩激情一区二区| 国产麻豆视频一区| 波多野结衣的一区二区三区| 在线看日本不卡| 91精品国产一区二区| 久久久久久99精品| 亚洲欧美日韩国产综合在线| 亚洲成av人片观看| 黄网站免费久久| 成人av集中营| 欧美日韩国产另类一区| 精品国产伦一区二区三区观看体验 | 欧美色偷偷大香| 日韩免费视频一区| 亚洲欧美自拍偷拍| 午夜国产不卡在线观看视频| 激情五月婷婷综合| 91视频在线看| 精品久久久久久亚洲综合网| 免费精品视频在线| aa级大片欧美| 日韩亚洲电影在线| 亚洲品质自拍视频| 精品中文av资源站在线观看| 一本大道av一区二区在线播放 | 日韩你懂的在线观看| 国产精品二区一区二区aⅴ污介绍| 亚洲国产日韩一级| 国产一区啦啦啦在线观看| 97久久久精品综合88久久| 欧美一区二区三区视频免费播放 | 亚洲老妇xxxxxx| 麻豆91精品91久久久的内涵| 成人激情图片网| 日韩美女在线视频| 亚洲乱码日产精品bd| 国模一区二区三区白浆| 91蜜桃婷婷狠狠久久综合9色| 91麻豆精品国产91久久久久久久久| 国产日韩在线不卡| 免费高清成人在线| 在线欧美日韩国产| 国产精品久久久久久久久晋中| 免费在线观看成人| 欧美天堂一区二区三区| 国产精品高潮呻吟| 国产一区视频导航| 678五月天丁香亚洲综合网| 亚洲日本在线a| 丁香激情综合五月| 日韩精品一区二区三区在线观看| 一区二区日韩电影| 一本色道久久综合狠狠躁的推荐| 精品国产免费久久| 日本不卡视频在线| 在线观看网站黄不卡| 亚洲视频免费在线观看| 成人av集中营| 亚洲国产激情av| 国产精品中文字幕日韩精品| 日韩精品一区二区三区视频播放| 婷婷久久综合九色综合绿巨人| 91在线视频播放| 亚洲人成网站影音先锋播放| 成人高清在线视频| 亚洲国产精品激情在线观看| 国产一区二三区好的| 日韩精品一区二区三区老鸭窝| 日本一不卡视频| 538prom精品视频线放| 亚洲第一二三四区| 欧美精品久久久久久久多人混战| 洋洋成人永久网站入口| 在线观看日韩国产| 亚洲国产精品久久久久秋霞影院 | 不卡视频免费播放| 国产精品乱码妇女bbbb| 成人ar影院免费观看视频| 精品国产乱码久久久久久影片| 青青草91视频| 欧美精品一区二区三区一线天视频| 麻豆高清免费国产一区| 久久人人爽人人爽| 成人高清免费观看| 亚洲精选在线视频| 欧美日韩精品一区二区三区| 亚洲精品免费一二三区| 欧美日韩一本到| 免费精品视频最新在线| 久久中文字幕电影| 成人禁用看黄a在线| 韩国欧美一区二区| 国产视频视频一区| 99久久国产综合色|国产精品| 亚洲视频免费看| 欧美剧情片在线观看| 老司机午夜精品99久久| 国产婷婷一区二区| 色婷婷综合五月| 蜜桃av一区二区在线观看| 国产欧美精品在线观看| 色88888久久久久久影院按摩| 日韩电影在线免费观看| 久久久亚洲精华液精华液精华液| 成人黄色777网| 亚洲第一综合色| 久久看人人爽人人| 在线一区二区三区四区五区| 蜜桃av一区二区在线观看 |