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

📄 cs8900.h

📁 Intel XScale PXA255 引导Linux的Redboot 版bootloader源代码!
💻 H
字号:
//==========================================================================////      dev/cs8900.h////      Cirrus Logic CS8900 Ethernet chip////==========================================================================//####COPYRIGHTBEGIN####//                                                                          // -------------------------------------------                              // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (the "License"); you may not use this file except in         // compliance with the License.  You may obtain a copy of the License at    // http://www.redhat.com/                                                   //                                                                          // Software distributed under the License is distributed on an "AS IS"      // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See the // License for the specific language governing rights and limitations under // the License.                                                             //                                                                          // The Original Code is eCos - Embedded Configurable Operating System,      // released September 30, 1998.                                             //                                                                          // The Initial Developer of the Original Code is Red Hat.                   // Portions created by Red Hat are                                          // Copyright (C) 1998, 1999, 2000 Red Hat, Inc.                             // All Rights Reserved.                                                     // -------------------------------------------                              //                                                                          //####COPYRIGHTEND####//####BSDCOPYRIGHTBEGIN####//// -------------------------------------------//// Portions of this software may have been derived from OpenBSD or other sources,// and are covered by the appropriate copyright disclaimers included herein.//// -------------------------------------------////####BSDCOPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):    gthomas// Contributors: gthomas// Date:         2000-01-10// Purpose:      // Description:  //              ////####DESCRIPTIONEND####////==========================================================================// Cirrus Logic CS8900A Ethernet// Assumption - all registers are 16 bits// Directly visible registers#define CS8900_RTDATA *(volatile unsigned short *)(CS8900_BASE+0x00)#define CS8900_TxCMD  *(volatile unsigned short *)(CS8900_BASE+0x08)#define CS8900_TxLEN  *(volatile unsigned short *)(CS8900_BASE+0x0C)#define CS8900_ISQ    *(volatile unsigned short *)(CS8900_BASE+0x10)#define CS8900_PPTR   *(volatile unsigned short *)(CS8900_BASE+0x14)#define CS8900_PDATA  *(volatile unsigned short *)(CS8900_BASE+0x18)#define ISQ_RxEvent     0x04#define ISQ_TxEvent     0x08#define ISQ_BufEvent    0x0C#define ISQ_RxMissEvent 0x10#define ISQ_TxColEvent  0x12#define ISQ_EventMask   0x3F// Registers available via "page pointer" (indirect access)#define PP_ChipID    0x0000  // Chip identifier - must be 0x630E#define PP_ChipRev   0x0002  // Chip revision, model codes#define PP_IntReg    0x0022  // Interrupt configuration#define PP_IntReg_IRQ0         0x0000  // Use INTR0 pin#define PP_IntReg_IRQ1         0x0001  // Use INTR1 pin#define PP_IntReg_IRQ2         0x0002  // Use INTR2 pin#define PP_IntReg_IRQ3         0x0003  // Use INTR3 pin#define PP_RxCFG     0x0102  // Receiver configuration#define PP_RxCFG_Skip1         0x0040  // Skip (i.e. discard) current frame#define PP_RxCFG_Stream        0x0080  // Enable streaming mode#define PP_RxCFG_RxOK          0x0100  // RxOK interrupt enable#define PP_RxCFG_RxDMAonly     0x0200  // Use RxDMA for all frames#define PP_RxCFG_AutoRxDMA     0x0400  // Select RxDMA automatically#define PP_RxCFG_BufferCRC     0x0800  // Include CRC characters in frame#define PP_RxCFG_CRC           0x1000  // Enable interrupt on CRC error#define PP_RxCFG_RUNT          0x2000  // Enable interrupt on RUNT frames#define PP_RxCFG_EXTRA         0x4000  // Enable interrupt on frames with extra data#define PP_RxCTL     0x0104  // Receiver control#define PP_RxCTL_IAHash        0x0040  // Accept frames that match hash#define PP_RxCTL_Promiscuous   0x0080  // Accept any frame#define PP_RxCTL_RxOK          0x0100  // Accept well formed frames#define PP_RxCTL_Multicast     0x0200  // Accept multicast frames#define PP_RxCTL_IA            0x0400  // Accept frame that matches IA#define PP_RxCTL_Broadcast     0x0800  // Accept broadcast frames#define PP_RxCTL_CRC           0x1000  // Accept frames with bad CRC#define PP_RxCTL_RUNT          0x2000  // Accept runt frames#define PP_RxCTL_EXTRA         0x4000  // Accept frames that are too long#define PP_TxCFG     0x0106  // Transmit configuration#define PP_TxCFG_CRS           0x0040  // Enable interrupt on loss of carrier#define PP_TxCFG_SQE           0x0080  // Enable interrupt on Signal Quality Error#define PP_TxCFG_TxOK          0x0100  // Enable interrupt on successful xmits#define PP_TxCFG_Late          0x0200  // Enable interrupt on "out of window" #define PP_TxCFG_Jabber        0x0400  // Enable interrupt on jabber detect#define PP_TxCFG_Collision     0x0800  // Enable interrupt if collision#define PP_TxCFG_16Collisions  0x8000  // Enable interrupt if > 16 collisions#define PP_TxCmd     0x0108  // Transmit command status#define PP_TxCmd_TxStart_5     0x0000  // Start after 5 bytes in buffer#define PP_TxCmd_TxStart_381   0x0040  // Start after 381 bytes in buffer#define PP_TxCmd_TxStart_1021  0x0080  // Start after 1021 bytes in buffer#define PP_TxCmd_TxStart_Full  0x00C0  // Start after all bytes loaded#define PP_TxCmd_Force         0x0100  // Discard any pending packets#define PP_TxCmd_OneCollision  0x0200  // Abort after a single collision#define PP_TxCmd_NoCRC         0x1000  // Do not add CRC#define PP_TxCmd_NoPad         0x2000  // Do not pad short packets#define PP_BufCFG    0x010A  // Buffer configuration#define PP_BufCFG_SWI          0x0040  // Force interrupt via software#define PP_BufCFG_RxDMA        0x0080  // Enable interrupt on Rx DMA#define PP_BufCFG_TxRDY        0x0100  // Enable interrupt when ready for Tx#define PP_BufCFG_TxUE         0x0200  // Enable interrupt in Tx underrun#define PP_BufCFG_RxMiss       0x0400  // Enable interrupt on missed Rx packets#define PP_BufCFG_Rx128        0x0800  // Enable Rx interrupt after 128 bytes#define PP_BufCFG_TxCol        0x1000  // Enable int on Tx collision ctr overflow#define PP_BufCFG_Miss         0x2000  // Enable int on Rx miss ctr overflow#define PP_BufCFG_RxDest       0x8000  // Enable int on Rx dest addr match#define PP_LineCTL   0x0112  // Line control#define PP_LineCTL_Rx          0x0040  // Enable receiver#define PP_LineCTL_Tx          0x0080  // Enable transmitter#define PP_RER       0x0124  // Receive event#define PP_RER_IAHash          0x0040  // Frame hash match#define PP_RER_Dribble         0x0080  // Frame had 1-7 extra bits after last byte#define PP_RER_RxOK            0x0100  // Frame received with no errors#define PP_RER_Hashed          0x0200  // Frame address hashed OK#define PP_RER_IA              0x0400  // Frame address matched IA#define PP_RER_Broadcast       0x0800  // Broadcast frame#define PP_RER_CRC             0x1000  // Frame had CRC error#define PP_RER_RUNT            0x2000  // Runt frame#define PP_RER_EXTRA           0x4000  // Frame was too long#define PP_TER       0x0128 // Transmit event#define PP_TER_CRS             0x0040  // Carrier lost#define PP_TER_SQE             0x0080  // Signal Quality Error#define PP_TER_TxOK            0x0100  // Packet sent without error#define PP_TER_Late            0x0200  // Out of window#define PP_TER_Jabber          0x0400  // Stuck transmit?#define PP_TER_NumCollisions   0x7800  // Number of collisions#define PP_TER_16Collisions    0x8000  // > 16 collisions#define PP_SelfCtl   0x0114  // Chip control#define PP_SelfCtl_Reset       0x0040  // Self-clearing reset#define PP_BusCtl    0x0116  // Bus control#define PP_BusCtl_ResetRxDMA   0x0040  // Reset receiver DMA engine#define PP_BusCtl_DMAextend    0x0100#define PP_BusCtl_UseSA        0x0200#define PP_BusCtl_MemoryE      0x0400  // Enable "memory mode"#define PP_BusCtl_DMAburst     0x0800#define PP_BusCtl_IOCH_RDYE    0x1000#define PP_BusCtl_RxDMAsize    0x2000#define PP_BusCtl_EnableIRQ    0x8000  // Enable interrupts#define PP_LineStat  0x0134  // Line status#define PP_LineStat_LinkOK     0x0080  // Line is connected and working#define PP_LineStat_AUI        0x0100  // Connected via AUI#define PP_LineStat_10BT       0x0200  // Connected via twisted pair#define PP_LineStat_Polarity   0x1000  // Line polarity OK (10BT only)#define PP_LineStat_CRS        0x4000  // Frame being received#define PP_SelfStat  0x0136  // Chip status#define PP_SelfStat_InitD      0x0080  // Chip initialization complete#define PP_SelfStat_SIBSY      0x0100  // EEPROM is busy#define PP_SelfStat_EEPROM     0x0200  // EEPROM present#define PP_SelfStat_EEPROM_OK  0x0400  // EEPROM checks out#define PP_SelfStat_ELPresent  0x0800  // External address latch logic available#define PP_SelfStat_EEsize     0x1000  // Size of EEPROM#define PP_BusStat   0x0138  // Bus status#define PP_BusStat_TxBid       0x0080  // Tx error#define PP_BusStat_TxRDY       0x0100  // Ready for Tx data#define PP_LAF       0x0150  // Logical address filter (6 bytes)#define PP_IA        0x0158  // Individual address (MAC)// "page pointer" access functionsstatic __inline__ unsigned shortget_reg(int regno){    CS8900_PPTR = regno;    return CS8900_PDATA;}static __inline__ voidput_reg(int regno, unsigned short val){    CS8900_PPTR = regno;    CS8900_PDATA = val;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -