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

📄 xemac_l.h

📁 powerpc405开发板的linux网口驱动程序
💻 H
📖 第 1 页 / 共 2 页
字号:
/* $Id: xemac_l.h,v 1.3 2006/03/08 17:07:34 moleres Exp $ *//********************************************************************************       XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS"*       AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND*       SOLUTIONS FOR XILINX DEVICES.  BY PROVIDING THIS DESIGN, CODE,*       OR INFORMATION AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE,*       APPLICATION OR STANDARD, XILINX IS MAKING NO REPRESENTATION*       THAT THIS IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT,*       AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY REQUIRE*       FOR YOUR IMPLEMENTATION.  XILINX EXPRESSLY DISCLAIMS ANY*       WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE*       IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR*       REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF*       INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS*       FOR A PARTICULAR PURPOSE.**       (c) Copyright 2003-2006 Xilinx Inc.*       All rights reserved.*******************************************************************************//*****************************************************************************//**** @file xemac_l.h** This header file contains identifiers and low-level driver functions (or* macros) that can be used to access the device.  High-level driver functions* are defined in xemac.h.** <pre>* MODIFICATION HISTORY:** Ver   Who  Date     Changes* ----- ---- -------- -----------------------------------------------* 1.00b rpm  04/26/02 First release* 1.00b rmm  09/23/02 Added XEmac_mPhyReset macro* 1.00c rpm  12/05/02 New version includes support for simple DMA* 1.00d rpm  09/26/03 New version includes support PLB Ethernet and v2.00a of*                     the packet fifo driver.* 1.00e rmm  04/06/04 Relocated IFG and MGT max values from 'c' files to this*                     one.* 1.00f rmm  10/19/04 Added constants for CAM address filtering & jumbo frame*                     support.* 1.01a rpm  03/08/06 Fixed EMIR TYPE mask* </pre>*******************************************************************************/#ifndef XEMAC_L_H /* prevent circular inclusions */#define XEMAC_L_H /* by using protection macros */#ifdef __cplusplusextern "C" {#endif/***************************** Include Files *********************************/#include "xbasic_types.h"#include "xio.h"/************************** Constant Definitions *****************************//* Offset of the MAC registers from the IPIF base address */#define XEM_REG_OFFSET     0x1100UL/* * Register offsets for the Ethernet MAC. Each register is 32 bits. */#define XEM_EMIR_OFFSET   (XEM_REG_OFFSET + 0x0)   /* EMAC Module ID */#define XEM_ECR_OFFSET    (XEM_REG_OFFSET + 0x4)   /* MAC Control */#define XEM_IFGP_OFFSET   (XEM_REG_OFFSET + 0x8)   /* Interframe Gap */#define XEM_SAH_OFFSET    (XEM_REG_OFFSET + 0xC)   /* Station addr, high */#define XEM_SAL_OFFSET    (XEM_REG_OFFSET + 0x10)  /* Station addr, low */#define XEM_MGTCR_OFFSET  (XEM_REG_OFFSET + 0x14)  /* MII mgmt control */#define XEM_MGTDR_OFFSET  (XEM_REG_OFFSET + 0x18)  /* MII mgmt data */#define XEM_RPLR_OFFSET   (XEM_REG_OFFSET + 0x1C)  /* Rx packet length */#define XEM_TPLR_OFFSET   (XEM_REG_OFFSET + 0x20)  /* Tx packet length */#define XEM_TSR_OFFSET    (XEM_REG_OFFSET + 0x24)  /* Tx status */#define XEM_RMFC_OFFSET   (XEM_REG_OFFSET + 0x28)  /* Rx missed frames */#define XEM_RCC_OFFSET    (XEM_REG_OFFSET + 0x2C)  /* Rx collisions */#define XEM_RFCSEC_OFFSET (XEM_REG_OFFSET + 0x30)  /* Rx FCS errors */#define XEM_RAEC_OFFSET   (XEM_REG_OFFSET + 0x34)  /* Rx alignment errors */#define XEM_TEDC_OFFSET   (XEM_REG_OFFSET + 0x38)  /* Transmit excess                                                    * deferral cnt */#define XEM_CAMH_OFFSET   (XEM_REG_OFFSET + 0x40)  /* CAM address, high */#define XEM_CAML_OFFSET   (XEM_REG_OFFSET + 0x44)  /* CAM address, low *//* * Register offsets for the IPIF components */#define XEM_ISR_OFFSET           0x20UL             /* Interrupt status */#define XEM_DMA_OFFSET           0x2300UL#define XEM_DMA_SEND_OFFSET      (XEM_DMA_OFFSET + 0x0)  /* DMA send channel */#define XEM_DMA_RECV_OFFSET      (XEM_DMA_OFFSET + 0x40) /* DMA recv channel */#define XEM_PFIFO_OFFSET         0x2000UL#define XEM_PFIFO_TXREG_OFFSET   (XEM_PFIFO_OFFSET + 0x0)    /* Tx registers */#define XEM_PFIFO_RXREG_OFFSET   (XEM_PFIFO_OFFSET + 0x10)   /* Rx registers */#define XEM_PFIFO_TXDATA_OFFSET  (XEM_PFIFO_OFFSET + 0x100)  /* Tx keyhole */#define XEM_PFIFO_RXDATA_OFFSET  (XEM_PFIFO_OFFSET + 0x200)  /* Rx keyhole *//* * EMAC Module Identification Register (EMIR) */#define XEM_EMIR_VERSION_MASK    0xFFFF0000UL        /* Device version */#define XEM_EMIR_ID_MASK         0x0000FF00UL        /* Device ID */#define XEM_EMIR_TYPE_MASK       0x000000FFUL        /* Device type *//* * EMAC Control Register (ECR) */#define XEM_ECR_FULL_DUPLEX_MASK         0x80000000UL /* Full duplex mode */#define XEM_ECR_XMIT_RESET_MASK          0x40000000UL /* Reset transmitter */#define XEM_ECR_XMIT_ENABLE_MASK         0x20000000UL /* Enable transmitter */#define XEM_ECR_RECV_RESET_MASK          0x10000000UL /* Reset receiver */#define XEM_ECR_RECV_ENABLE_MASK         0x08000000UL /* Enable receiver */#define XEM_ECR_PHY_ENABLE_MASK          0x04000000UL /* Enable PHY */#define XEM_ECR_XMIT_PAD_ENABLE_MASK     0x02000000UL /* Enable xmit pad insert */#define XEM_ECR_XMIT_FCS_ENABLE_MASK     0x01000000UL /* Enable xmit FCS insert */#define XEM_ECR_XMIT_ADDR_INSERT_MASK    0x00800000UL /* Enable xmit source addr                                                       * insertion */#define XEM_ECR_XMIT_ERROR_INSERT_MASK   0x00400000UL /* Insert xmit error */#define XEM_ECR_XMIT_ADDR_OVWRT_MASK     0x00200000UL /* Enable xmit source addr                                                       * overwrite */#define XEM_ECR_LOOPBACK_MASK            0x00100000UL /* Enable internal                                                       * loopback */#define XEM_ECR_RECV_STRIP_ENABLE_MASK   0x00080000UL /* Enable recv pad/fcs strip */#define XEM_ECR_UNICAST_ENABLE_MASK      0x00020000UL /* Enable unicast addr */#define XEM_ECR_MULTI_ENABLE_MASK        0x00010000UL /* Enable multicast addr */#define XEM_ECR_BROAD_ENABLE_MASK        0x00008000UL /* Enable broadcast addr */#define XEM_ECR_PROMISC_ENABLE_MASK      0x00004000UL /* Enable promiscuous mode */#define XEM_ECR_RECV_ALL_MASK            0x00002000UL /* Receive all frames */#define XEM_ECR_RECV_JUMBO_ENABLE_MASK   0x00001000UL /* Enable jumbo frame                                                         reception */#define XEM_ECR_CAM_ENABLE_MASK          0x00000800UL /* Enable multicast CAM                                                         filtering */#define XEM_ECR_PAUSE_FRAME_MASK         0x00000400UL /* Interpret pause frames */#define XEM_ECR_WRITE_CAM_MASK           0x00000100UL /* Add address to multicast                                                         CAM *//* * Interframe Gap Register (IFGR) */#define XEM_IFGP_PART1_MASK         0xF8000000UL /* Interframe Gap Part1 */#define XEM_IFGP_PART1_SHIFT        27#define XEM_IFGP_PART2_MASK         0x07C00000UL /* Interframe Gap Part2 */#define XEM_IFGP_PART2_SHIFT        22#define XEM_IFGP_PART1_MAX          31           /* Max IFG 1 value */#define XEM_IFGP_PART2_MAX          31           /* Max IFG 2 value *//* * Station Address High Register (SAH) */#define XEM_SAH_ADDR_MASK           0x0000FFFFUL /* Station address high bytes *//* * Station Address Low Register (SAL) */#define XEM_SAL_ADDR_MASK           0xFFFFFFFFUL /* Station address low bytes *//* * MII Management Control Register (MGTCR) */#define XEM_MGTCR_START_MASK        0x80000000UL /* Start/Busy */#define XEM_MGTCR_RW_NOT_MASK       0x40000000UL /* Read/Write Not (direction) */#define XEM_MGTCR_PHY_ADDR_MASK     0x3E000000UL /* PHY address */#define XEM_MGTCR_PHY_ADDR_SHIFT    25           /* PHY address shift */#define XEM_MGTCR_REG_ADDR_MASK     0x01F00000UL /* Register address */#define XEM_MGTCR_REG_ADDR_SHIFT    20           /* Register addr shift */#define XEM_MGTCR_MII_ENABLE_MASK   0x00080000UL /* Enable MII from EMAC */#define XEM_MGTCR_RD_ERROR_MASK     0x00040000UL /* MII mgmt read error */#define XEM_MGTCR_MAX_PHY_ADDR      31           /* Maximum PHY address */#define XEM_MGTCR_MAX_PHY_REG       31           /* Maximum PHY register number *//* * MII Management Data Register (MGTDR) */#define XEM_MGTDR_DATA_MASK         0x0000FFFFUL /* MII data *//* * Receive Packet Length Register (RPLR) */#define XEM_RPLR_LENGTH_MASK        0x0000FFFFUL /* Receive packet length *//* * Transmit Packet Length Register (TPLR) */#define XEM_TPLR_LENGTH_MASK        0x0000FFFFUL /* Transmit packet length *//* * Transmit Status Register (TSR) */#define XEM_TSR_EXCESS_DEFERRAL_MASK 0x80000000UL /* Transmit excess deferral */#define XEM_TSR_FIFO_UNDERRUN_MASK   0x40000000UL /* Packet FIFO underrun */#define XEM_TSR_ATTEMPTS_MASK        0x3E000000UL /* Transmission attempts */#define XEM_TSR_LATE_COLLISION_MASK  0x01000000UL /* Transmit late collision *//* * Receive Missed Frame Count (RMFC) */#define XEM_RMFC_DATA_MASK          0x0000FFFFUL/* * Receive Collision Count (RCC) */#define XEM_RCC_DATA_MASK           0x0000FFFFUL/* * Receive FCS Error Count (RFCSEC) */#define XEM_RFCSEC_DATA_MASK        0x0000FFFFUL/* * Receive Alignment Error Count (RALN) */#define XEM_RAEC_DATA_MASK          0x0000FFFFUL/* * Transmit Excess Deferral Count (TEDC) */#define XEM_TEDC_DATA_MASK          0x0000FFFFUL/* * CAM high (CAMH) */#define XEM_CAMH_CAM_MASK           0x0000FFFFUL#define XEM_CAMH_SLOT_MASK          0x003F0000UL#define XEM_CAMH_SLOT_SHIFT         16/* * EMAC Interrupt Registers (Status and Enable) masks. These registers are * part of the IPIF IP Interrupt registers */#define XEM_EIR_XMIT_DONE_MASK         0x00000001UL /* Xmit complete */#define XEM_EIR_RECV_DONE_MASK         0x00000002UL /* Recv complete */#define XEM_EIR_XMIT_ERROR_MASK        0x00000004UL /* Xmit error */#define XEM_EIR_RECV_ERROR_MASK        0x00000008UL /* Recv error */#define XEM_EIR_XMIT_SFIFO_EMPTY_MASK  0x00000010UL /* Xmit status fifo empty */#define XEM_EIR_RECV_LFIFO_EMPTY_MASK  0x00000020UL /* Recv length fifo empty */#define XEM_EIR_XMIT_LFIFO_FULL_MASK   0x00000040UL /* Xmit length fifo full */#define XEM_EIR_RECV_LFIFO_OVER_MASK   0x00000080UL /* Recv length fifo                                                     * overrun */

⌨️ 快捷键说明

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