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

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

?? cssysend.c

?? ROM型的vxworksBSP包 編譯測試通過
?? 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 */

/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *
 * 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)	((*(volatile UINT16 *)(port))) = (value)
#define SYS_ENET_IN_WORD(port)		(*(volatile UINT16 *)(port))
#define SYS_ENET_IN_BYTE(port)		(*(volatile UINT8 *)(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

/* 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 long 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
*/

BOOL CheckAddress(CS_END_DEVICE *pCS)
{
    unsigned short Data = 0, arBuf[5];
    int i;
    
    for( i = 0; i < 5; i++ )
    {
        csReadEEPROM(pCS, i, &arBuf[i]);	
    }
    
    for( i = 0; i < 5; i++ )
    {
        Data ^= arBuf[i];
    }
    
    return Data ? FALSE : TRUE;	
}

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;
      }
      
      if( !CheckAddress(pCS) ) 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;*/
      
      if ( csReadEEPROM(pCS, 1, &pIA->word[0]) == ERROR )
         return ERROR;
      if ( csReadEEPROM(pCS, 2, &pIA->word[1]) == ERROR )
         return ERROR;
      if ( csReadEEPROM(pCS, 3, &pIA->word[2]) == ERROR )
         return ERROR;   
   }
   else  /* Use Ethernet Address defined in csEnetAddr */
      bcopyBytes ((char *) csEnetAddr, (char *) pIA, 6);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.性欧美| 日韩美女在线视频| 国产亚洲一本大道中文在线| 视频一区二区中文字幕| 99riav一区二区三区| 51精品秘密在线观看| 婷婷开心久久网| 欧美一区二区三区四区久久 | 91精品视频网| 日韩和欧美一区二区| 日韩欧美123| 国产一区二区在线影院| 中文字幕精品一区二区精品绿巨人 | 亚洲天堂中文字幕| 91理论电影在线观看| 亚洲午夜av在线| 日韩免费看网站| av资源网一区| 午夜精品国产更新| 久久九九影视网| 在线亚洲免费视频| 久久狠狠亚洲综合| 日韩一区在线免费观看| 欧美午夜电影一区| 不卡av在线网| 亚洲精品久久7777| 26uuu亚洲| 欧美老人xxxx18| 丁香亚洲综合激情啪啪综合| 亚洲一区二区黄色| 国产午夜精品久久| 欧美一卡二卡三卡| 在线影院国内精品| 丁香激情综合五月| 欧美视频在线一区二区三区| 日本不卡中文字幕| 一级特黄大欧美久久久| 国产日韩欧美精品电影三级在线 | 一区二区三区 在线观看视频 | 91麻豆精品国产91久久久久| 99久久精品免费观看| 韩国女主播一区| 麻豆精品一区二区综合av| 亚洲综合免费观看高清在线观看| 久久精品亚洲乱码伦伦中文 | 欧美日韩精品一区二区三区蜜桃 | 日韩二区三区在线观看| 亚洲精品免费看| 一区二区三区在线观看国产| 国产精品天美传媒沈樵| 国产午夜亚洲精品不卡| 久久综合色婷婷| 久久品道一品道久久精品| 欧美成人精品福利| 久久久久国产精品人| 精品国产欧美一区二区| 久久夜色精品国产噜噜av| 久久久久青草大香线综合精品| 欧美videos中文字幕| 精品三级av在线| 国产精品福利一区| 亚洲免费观看高清完整版在线观看熊| 精品国产伦一区二区三区观看体验 | 成人自拍视频在线观看| 成人黄色av电影| 欧美少妇性性性| 337p亚洲精品色噜噜| 精品国产免费一区二区三区四区 | 日韩一区二区三区在线视频| 欧美一区二区三区系列电影| 国产农村妇女毛片精品久久麻豆| 国产精品美女久久久久aⅴ| 一区二区三区国产豹纹内裤在线| 亚洲欧美激情一区二区| 美女视频一区在线观看| 97精品视频在线观看自产线路二| 欧美丝袜丝交足nylons| 丰满白嫩尤物一区二区| 狠狠色丁香婷婷综合| 99精品视频免费在线观看| 欧美日韩国产综合一区二区三区 | 国产suv精品一区二区6| 欧美三级视频在线观看| 中文欧美字幕免费| 免费成人性网站| 欧美在线观看一区| 国产精品免费人成网站| 看电影不卡的网站| 欧美男男青年gay1069videost| 国产精品乱码久久久久久| 精品一区中文字幕| 精品日韩欧美在线| 日韩电影免费在线| 91麻豆精品国产无毒不卡在线观看| 日本一区二区不卡视频| 成人精品电影在线观看| 26uuu久久综合| 91色porny在线视频| 久久婷婷综合激情| 国产精品一区二区久久不卡| 欧美一区二区在线看| 日韩av中文在线观看| 正在播放亚洲一区| 久久精品国产一区二区三| 欧美一区二区三区爱爱| 久久国产生活片100| 国产日韩综合av| 成人免费视频免费观看| 国产精品你懂的在线| 99r国产精品| 日韩成人免费看| 久久综合色8888| 972aa.com艺术欧美| 视频一区二区三区中文字幕| 日韩美女天天操| av在线播放不卡| 日韩国产欧美在线观看| 欧美xxxxx牲另类人与| 99精品国产热久久91蜜凸| 亚洲一区二区三区四区的| 欧美草草影院在线视频| gogogo免费视频观看亚洲一| 五月婷婷久久丁香| 中文av一区二区| 日韩一区二区三区观看| 成人午夜看片网址| 秋霞午夜鲁丝一区二区老狼| 亚洲欧洲性图库| 久久嫩草精品久久久久| 欧美人动与zoxxxx乱| caoporen国产精品视频| 国产一区三区三区| 亚洲va中文字幕| ●精品国产综合乱码久久久久| 日韩一区二区三区观看| 图片区日韩欧美亚洲| 欧美国产一区视频在线观看| 欧美美女喷水视频| 色婷婷av一区| av动漫一区二区| 成人av资源站| 高清在线成人网| 国产成人免费视频网站| 狠狠色丁香婷婷综合| 国产原创一区二区三区| 一片黄亚洲嫩模| 亚洲午夜日本在线观看| 亚洲精品精品亚洲| 亚洲精品免费视频| 洋洋成人永久网站入口| 亚洲一区二区三区在线| 天天综合网天天综合色| 视频一区欧美日韩| 精品写真视频在线观看 | 久久综合狠狠综合久久综合88| 91精品国产综合久久福利软件 | 99国产精品久久久久| 一道本成人在线| 91精品欧美一区二区三区综合在 | 国v精品久久久网| 91色porny在线视频| 欧美日韩精品欧美日韩精品一| 欧美另类高清zo欧美| 国产欧美日韩在线| 亚洲精品午夜久久久| 免费观看在线色综合| av在线这里只有精品| 欧美色精品在线视频| 久久精品免费在线观看| 亚洲午夜电影网| 国模大尺度一区二区三区| 91色porny在线视频| 精品少妇一区二区三区免费观看 | 国产精品看片你懂得| 蜜桃视频免费观看一区| 99视频一区二区三区| 日韩欧美123| 亚洲成av人综合在线观看| 国产成人精品免费网站| 91精品久久久久久久久99蜜臂| 国产色婷婷亚洲99精品小说| 天天综合色天天综合色h| 不卡视频在线观看| 久久久亚洲国产美女国产盗摄 | 中文字幕欧美一区| 久久99精品网久久| 日本精品一级二级| 国产精品三级电影| 国产成人av网站| 久久久久久久网| 狠狠色丁香婷婷综合| 欧美一级淫片007| 日韩国产在线观看| 欧美一级日韩免费不卡| 一区二区三区视频在线观看| 成人av小说网| 亚洲色欲色欲www| 色一情一伦一子一伦一区| 欧美一区二区三区在| 日韩一区欧美小说|