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

📄 xemac_l.h

📁 实用的程序代码
💻 H
📖 第 1 页 / 共 2 页
字号:
/* $Id: xemac_l.h,v 1.2 2002/08/02 17:13:04 meinelte 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 2002 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
* </pre>
*
******************************************************************************/

#ifndef XEMAC_L_H /* prevent circular inclusions */
#define XEMAC_L_H /* by using protection macros */

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

/*
 * 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_TYPE_MASK       0x0000FF00UL        /* 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_RESERVED2_MASK           0x00001000UL /* Reserved */
#define XEM_ECR_MULTI_HASH_ENABLE_MASK   0x00000800UL /* Enable multicast hash */
#define XEM_ECR_PAUSE_FRAME_MASK         0x00000400UL /* Interpret pause frames */
#define XEM_ECR_CLEAR_HASH_MASK          0x00000200UL /* Clear hash table */
#define XEM_ECR_ADD_HASH_ADDR_MASK       0x00000100UL /* Add hash table address */

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

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

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


/*
 * 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 */
#define XEM_EIR_RECV_LFIFO_UNDER_MASK  0x00000100UL /* Recv length fifo

⌨️ 快捷键说明

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