mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-25 11:25:17 +00:00
ba94a1bba3
- Add IXP4xx NPE ethernet MAC support - Add support for Intel IXDPG425 board - Add support for Prodrive PDNB3 board - Add IRQ support Patch by Stefan Roese, 23 May 2006 [This patch does not include cpu/ixp/npe/IxNpeMicrocode.c which still sufferes from licensing issues. Blame Intel.]
782 lines
22 KiB
C
782 lines
22 KiB
C
#ifndef __doxygen_HIDE /* This file is not part of the API */
|
|
|
|
/**
|
|
* @file IxNpeA.h
|
|
*
|
|
* @date 22-Mar-2002
|
|
*
|
|
* @brief Header file for the IXP400 ATM NPE API
|
|
*
|
|
*
|
|
* @par
|
|
* IXP400 SW Release version 2.0
|
|
*
|
|
* -- Copyright Notice --
|
|
*
|
|
* @par
|
|
* Copyright 2001-2005, Intel Corporation.
|
|
* All rights reserved.
|
|
*
|
|
* @par
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. Neither the name of the Intel Corporation nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* @par
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* @par
|
|
* -- End of Copyright Notice --
|
|
*/
|
|
|
|
/**
|
|
* @defgroup IxNpeA IXP400 NPE-A (IxNpeA) API
|
|
*
|
|
* @brief The Public API for the IXP400 NPE-A
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
#ifndef IX_NPE_A_H
|
|
#define IX_NPE_A_H
|
|
|
|
#include "IxQMgr.h"
|
|
#include "IxOsal.h"
|
|
#include "IxQueueAssignments.h"
|
|
|
|
/* General Message Ids */
|
|
|
|
/* ATM Message Ids */
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_UTOPIA_CONFIG_WRITE
|
|
*
|
|
* @brief ATM Message ID command to write the data to the offset in the
|
|
* Utopia Configuration Table
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_UTOPIA_CONFIG_WRITE 0x20
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_UTOPIA_CONFIG_LOAD
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to copy the Utopia
|
|
* Configuration Table to the Utopia coprocessor
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_UTOPIA_CONFIG_LOAD 0x21
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_UTOPIA_STATUS_UPLOAD
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to read-back the Utopia
|
|
* status registers and update the Utopia Status Table.
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_UTOPIA_STATUS_UPLOAD 0x22
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_UTOPIA_STATUS_READ
|
|
*
|
|
* @brief ATM Message ID command to read the Utopia Status Table at the
|
|
* specified offset.
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_UTOPIA_STATUS_READ 0x23
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_TX_ENABLE
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to re-enable processing
|
|
* of any entries on the TxVcQ for this port.
|
|
*
|
|
* This command will be ignored for a port already enabled
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_TX_ENABLE 0x25
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_TX_DISABLE
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to disable processing on
|
|
* this port
|
|
*
|
|
* This command will be ignored for a port already disabled
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_TX_DISABLE 0x26
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_RX_ENABLE
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to process any received
|
|
* cells for this VC according to the VC Lookup Table.
|
|
*
|
|
* Re-issuing this command with different contents for a VC that is not
|
|
* disabled will cause unpredictable behavior.
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_RX_ENABLE 0x27
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_RX_DISABLE
|
|
*
|
|
* @brief ATM Message ID command triggers the NPE to disable processing for
|
|
* this VC.
|
|
*
|
|
* This command will be ignored for a VC already disabled
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_RX_DISABLE 0x28
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_ATM_STATUS_READ
|
|
*
|
|
* @brief ATM Message ID command to read the ATM status. The data is returned via
|
|
* a response message
|
|
*/
|
|
#define IX_NPE_A_MSSG_ATM_STATUS_READ 0x29
|
|
|
|
/*--------------------------------------------------------------------------
|
|
* HSS Message IDs
|
|
*--------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PORT_CONFIG_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the ConfigWord value to the location
|
|
* in the HSS_CONFIG_TABLE specified by offset for HSS port hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PORT_CONFIG_WRITE 0x40
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PORT_CONFIG_LOAD
|
|
*
|
|
* @brief HSS Message ID command triggers the NPE to copy the contents of the
|
|
* HSS Configuration Table to the appropriate configuration registers in the
|
|
* HSS coprocessor for the port specified by hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PORT_CONFIG_LOAD 0x41
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PORT_ERROR_READ
|
|
*
|
|
* @brief HSS Message ID command triggers the NPE to return an HssErrorReadResponse
|
|
* message for HSS port hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PORT_ERROR_READ 0x42
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_FLOW_ENABLE
|
|
*
|
|
* @brief HSS Message ID command triggers the NPE to reset internal status and
|
|
* enable the HssChannelized operation on the HSS port specified by hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_FLOW_ENABLE 0x43
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_FLOW_DISABLE
|
|
*
|
|
* @brief HSS Message ID command triggers the NPE to disable the HssChannelized
|
|
* operation on the HSS port specified by hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_FLOW_DISABLE 0x44
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_IDLE_PATTERN_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_IDLE_PATTERN value for HSS
|
|
* port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_IDLE_PATTERN_WRITE 0x45
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_NUM_CHANS_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_NUM_CHANNELS value for HSS
|
|
* port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_NUM_CHANS_WRITE 0x46
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_RX_BUF_ADDR_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_RX_BUF_ADDR value for HSS
|
|
* port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_RX_BUF_ADDR_WRITE 0x47
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_RX_BUF_CFG_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_RX_BUF_SIZEB and
|
|
* HSSnC_RX_TRIG_PERIOD values for HSS port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_RX_BUF_CFG_WRITE 0x48
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_TX_BLK_CFG_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_TX_BLK1_SIZEB,
|
|
* HSSnC_TX_BLK1_SIZEW, HSSnC_TX_BLK2_SIZEB, and HSSnC_TX_BLK2_SIZEW values
|
|
* for HSS port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_TX_BLK_CFG_WRITE 0x49
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_TX_BUF_ADDR_WRITE
|
|
* @brief HSS Message ID command writes the HSSnC_TX_BUF_ADDR value for HSS
|
|
* port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_TX_BUF_ADDR_WRITE 0x4A
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_CHAN_TX_BUF_SIZE_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnC_TX_BUF_SIZEN value for HSS
|
|
* port hPort. (n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_CHAN_TX_BUF_SIZE_WRITE 0x4B
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_FLOW_ENABLE
|
|
*
|
|
* @brief HSS Message ID command triggers the NPE to reset internal status and
|
|
* enable the HssPacketized operation for the flow specified by pPipe on
|
|
* the HSS port specified by hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_FLOW_ENABLE 0x50
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_FLOW_DISABLE
|
|
* @brief HSS Message ID command triggers the NPE to disable the HssPacketized
|
|
* operation for the flow specified by pPipe on the HSS port specified by hPort.
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_FLOW_DISABLE 0x51
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_NUM_PIPES_WRITE
|
|
* @brief HSS Message ID command writes the HSSnP_NUM_PIPES value for HSS
|
|
* port hPort.(n=hPort)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_NUM_PIPES_WRITE 0x52
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_FIFO_SIZEW_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnP_PIPEp_FIFOSIZEW value for
|
|
* packet-pipe pPipe on HSS port hPort. (n=hPort, p=pPipe)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_FIFO_SIZEW_WRITE 0x53
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_HDLC_CFG_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnP_PIPEp_HDLC_RXCFG and
|
|
* HSSnP_PIPEp_HDLC_TXCFG values for packet-pipe pPipe on HSS port hPort.
|
|
* (n=hPort, p=pPipe)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_HDLC_CFG_WRITE 0x54
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_IDLE_PATTERN_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnP_PIPEp_IDLE_PATTERN value
|
|
* for packet-pipe pPipe on HSS port hPort. (n=hPort, p=pPipe)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_IDLE_PATTERN_WRITE 0x55
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_RX_SIZE_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnP_PIPEp_RXSIZEB value for
|
|
* packet-pipe pPipe on HSS port hPort. (n=hPort, p=pPipe)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_RX_SIZE_WRITE 0x56
|
|
|
|
/**
|
|
* @def IX_NPE_A_MSSG_HSS_PKT_PIPE_MODE_WRITE
|
|
*
|
|
* @brief HSS Message ID command writes the HSSnP_PIPEp_MODE value for
|
|
* packet-pipe pPipe on HSS port hPort. (n=hPort, p=pPipe)
|
|
*/
|
|
#define IX_NPE_A_MSSG_HSS_PKT_PIPE_MODE_WRITE 0x57
|
|
|
|
|
|
|
|
/* Queue Entry Masks */
|
|
|
|
/*--------------------------------------------------------------------------
|
|
* ATM Descriptor Structure offsets
|
|
*--------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_STATUS_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Status field
|
|
*
|
|
* It is used for descriptor error reporting.
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_STATUS_OFFSET 0
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_VCID_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor VC ID field
|
|
*
|
|
* It is used to hold an identifier number for this VC
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_VCID_OFFSET 1
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_CURRMBUFSIZE_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Current Mbuf
|
|
* Size field
|
|
*
|
|
* Number of bytes the current mbuf data buffer can hold
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_CURRMBUFSIZE_OFFSET 2
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_ATMHEADER_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor ATM Header
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_ATMHEADER_OFFSET 4
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_CURRMBUFLEN_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Current MBuf length
|
|
*
|
|
*
|
|
* RX - Initialized to zero. The NPE updates this field as each cell is received and
|
|
* zeroes it with every new mbuf for chaining. Will not be bigger than currBbufSize.
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_CURRMBUFLEN_OFFSET 12
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_TIMELIMIT__OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Time Limit field
|
|
*
|
|
* Contains the Payload Reassembly Time Limit (used for aal0_xx only)
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_TIMELIMIT_OFFSET 14
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_PCURRMBUFF_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Current MBuf Pointer
|
|
*
|
|
* The current mbuf pointer of a chain of mbufs.
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_PCURRMBUFF_OFFSET 20
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_PCURRMBUFDATA_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Current MBuf Pointer
|
|
*
|
|
* Pointer to the next byte to be read or next free location to be written.
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_PCURRMBUFDATA_OFFSET 24
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_PNEXTMBUF_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Next MBuf Pointer
|
|
*
|
|
* Pointer to the next MBuf in a chain of MBufs.
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_PNEXTMBUF_OFFSET 28
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_TOTALLENGTH_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Total Length
|
|
*
|
|
* Total number of bytes written to the chain of MBufs by the NPE
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_TOTALLENGTH_OFFSET 32
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_AAL5CRCRESIDUE_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor AAL5 CRC Residue
|
|
*
|
|
* Current CRC value for a PDU
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_AAL5CRCRESIDUE_OFFSET 36
|
|
|
|
/**
|
|
* @def IX_NPE_A_RXDESCRIPTOR_SIZE
|
|
*
|
|
* @brief ATM Descriptor structure offset for Receive Descriptor Size
|
|
*
|
|
* The size of the Receive descriptor
|
|
*/
|
|
#define IX_NPE_A_RXDESCRIPTOR_SIZE 40
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_PORT_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Port
|
|
*
|
|
* Port identifier.
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_PORT_OFFSET 0
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_RSVD_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor RSVD
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_RSVD_OFFSET 1
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_CURRMBUFLEN_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Current MBuf Length
|
|
*
|
|
* TX - Initialized by the XScale to the number of bytes in the current MBuf data buffer.
|
|
* The NPE decrements this field for every transmitted cell. Thus, when the NPE writes a
|
|
* descriptor the TxDone queue, this field will equal zero.
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_CURRMBUFLEN_OFFSET 2
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_ATMHEADER_OFFSET
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor ATM Header
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_ATMHEADER_OFFSET 4
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_PCURRMBUFF_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Pointer to the current MBuf chain
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_PCURRMBUFF_OFFSET 8
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_PCURRMBUFDATA_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Pointer to the current MBuf Data
|
|
*
|
|
* Pointer to the next byte to be read or next free location to be written.
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_PCURRMBUFDATA_OFFSET 12
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_PNEXTMBUF_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Pointer to the Next MBuf chain
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_PNEXTMBUF_OFFSET 16
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_TOTALLENGTH_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Total Length
|
|
*
|
|
* Total number of bytes written to the chain of MBufs by the NPE
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_TOTALLENGTH_OFFSET 20
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_AAL5CRCRESIDUE_OFFSET
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor AAL5 CRC Residue
|
|
*
|
|
* Current CRC value for a PDU
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_AAL5CRCRESIDUE_OFFSET 24
|
|
|
|
/**
|
|
* @def IX_NPE_A_TXDESCRIPTOR_SIZE
|
|
*
|
|
* @brief ATM Descriptor structure offset for Transmit Descriptor Size
|
|
*/
|
|
#define IX_NPE_A_TXDESCRIPTOR_SIZE 28
|
|
|
|
/**
|
|
* @def IX_NPE_A_CHAIN_DESC_COUNT_MAX
|
|
*
|
|
* @brief Maximum number of chained MBufs that can be chained together
|
|
*/
|
|
#define IX_NPE_A_CHAIN_DESC_COUNT_MAX 256
|
|
|
|
/*
|
|
* Definition of the ATM cell header
|
|
*
|
|
* This would most conviently be defined as the bit field shown below.
|
|
* Endian portability prevents this, therefore a set of macros
|
|
* are defined to access the fields within the cell header assumed to
|
|
* be passed as a UINT32.
|
|
*
|
|
* Changes to field sizes or orders must be reflected in the offset
|
|
* definitions above.
|
|
*
|
|
* typedef struct
|
|
* {
|
|
* unsigned int gfc:4;
|
|
* unsigned int vpi:8;
|
|
* unsigned int vci:16;
|
|
* unsigned int pti:3;
|
|
* unsigned int clp:1;
|
|
* } IxNpeA_AtmCellHeader;
|
|
*
|
|
*/
|
|
|
|
/** Mask to acess GFC */
|
|
#define GFC_MASK 0xf0000000
|
|
|
|
/** return GFC from ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_GFC_GET( header ) \
|
|
(((header) & GFC_MASK) >> 28)
|
|
|
|
/** set GFC into ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_GFC_SET( header,gfc ) \
|
|
do { \
|
|
(header) &= ~GFC_MASK; \
|
|
(header) |= (((gfc) << 28) & GFC_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess VPI */
|
|
#define VPI_MASK 0x0ff00000
|
|
|
|
/** return VPI from ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_VPI_GET( header ) \
|
|
(((header) & VPI_MASK) >> 20)
|
|
|
|
/** set VPI into ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_VPI_SET( header, vpi ) \
|
|
do { \
|
|
(header) &= ~VPI_MASK; \
|
|
(header) |= (((vpi) << 20) & VPI_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess VCI */
|
|
#define VCI_MASK 0x000ffff0
|
|
|
|
/** return VCI from ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_VCI_GET( header ) \
|
|
(((header) & VCI_MASK) >> 4)
|
|
|
|
/** set VCI into ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_VCI_SET( header, vci ) \
|
|
do { \
|
|
(header) &= ~VCI_MASK; \
|
|
(header) |= (((vci) << 4) & VCI_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess PTI */
|
|
#define PTI_MASK 0x0000000e
|
|
|
|
/** return PTI from ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_PTI_GET( header ) \
|
|
(((header) & PTI_MASK) >> 1)
|
|
|
|
/** set PTI into ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_PTI_SET( header, pti ) \
|
|
do { \
|
|
(header) &= ~PTI_MASK; \
|
|
(header) |= (((pti) << 1) & PTI_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess CLP */
|
|
#define CLP_MASK 0x00000001
|
|
|
|
/** return CLP from ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_CLP_GET( header ) \
|
|
((header) & CLP_MASK)
|
|
|
|
/** set CLP into ATM cell header */
|
|
#define IX_NPE_A_ATMCELLHEADER_CLP_SET( header, clp ) \
|
|
do { \
|
|
(header) &= ~CLP_MASK; \
|
|
(header) |= ((clp) & CLP_MASK); \
|
|
} while(0)
|
|
|
|
|
|
/*
|
|
* Definition of the Rx bitfield
|
|
*
|
|
* This would most conviently be defined as the bit field shown below.
|
|
* Endian portability prevents this, therefore a set of macros
|
|
* are defined to access the fields within the rxBitfield assumed to
|
|
* be passed as a UINT32.
|
|
*
|
|
* Changes to field sizes or orders must be reflected in the offset
|
|
* definitions above.
|
|
*
|
|
* Rx bitfield
|
|
* struct
|
|
* { IX_NPEA_RXBITFIELD(
|
|
* unsigned int status:1,
|
|
* unsigned int port:7,
|
|
* unsigned int vcId:8,
|
|
* unsigned int currMbufSize:16);
|
|
* } rxBitField;
|
|
*
|
|
*/
|
|
|
|
/** Mask to acess the rxBitField status */
|
|
#define STATUS_MASK 0x80000000
|
|
|
|
/** return the rxBitField status */
|
|
#define IX_NPE_A_RXBITFIELD_STATUS_GET( rxbitfield ) \
|
|
(((rxbitfield) & STATUS_MASK) >> 31)
|
|
|
|
/** set the rxBitField status */
|
|
#define IX_NPE_A_RXBITFIELD_STATUS_SET( rxbitfield, status ) \
|
|
do { \
|
|
(rxbitfield) &= ~STATUS_MASK; \
|
|
(rxbitfield) |= (((status) << 31) & STATUS_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess the rxBitField port */
|
|
#define PORT_MASK 0x7f000000
|
|
|
|
/** return the rxBitField port */
|
|
#define IX_NPE_A_RXBITFIELD_PORT_GET( rxbitfield ) \
|
|
(((rxbitfield) & PORT_MASK) >> 24)
|
|
|
|
/** set the rxBitField port */
|
|
#define IX_NPE_A_RXBITFIELD_PORT_SET( rxbitfield, port ) \
|
|
do { \
|
|
(rxbitfield) &= ~PORT_MASK; \
|
|
(rxbitfield) |= (((port) << 24) & PORT_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess the rxBitField vcId */
|
|
#define VCID_MASK 0x00ff0000
|
|
|
|
/** return the rxBitField vcId */
|
|
#define IX_NPE_A_RXBITFIELD_VCID_GET( rxbitfield ) \
|
|
(((rxbitfield) & VCID_MASK) >> 16)
|
|
|
|
/** set the rxBitField vcId */
|
|
#define IX_NPE_A_RXBITFIELD_VCID_SET( rxbitfield, vcid ) \
|
|
do { \
|
|
(rxbitfield) &= ~VCID_MASK; \
|
|
(rxbitfield) |= (((vcid) << 16) & VCID_MASK); \
|
|
} while(0)
|
|
|
|
/** Mask to acess the rxBitField mbuf size */
|
|
#define CURRMBUFSIZE_MASK 0x0000ffff
|
|
|
|
/** return the rxBitField mbuf size */
|
|
#define IX_NPE_A_RXBITFIELD_CURRMBUFSIZE_GET( rxbitfield ) \
|
|
((rxbitfield) & CURRMBUFSIZE_MASK)
|
|
|
|
/** set the rxBitField mbuf size */
|
|
#define IX_NPE_A_RXBITFIELD_CURRMBUFSIZE_SET( rxbitfield, currmbufsize ) \
|
|
do { \
|
|
(rxbitfield) &= ~CURRMBUFSIZE_MASK; \
|
|
(rxbitfield) |= ((currmbufsize) & CURRMBUFSIZE_MASK); \
|
|
} while(0)
|
|
|
|
|
|
|
|
/**
|
|
* @brief Tx Descriptor definition
|
|
*/
|
|
typedef struct
|
|
{
|
|
UINT8 port; /**< Tx Port number */
|
|
UINT8 aalType; /**< AAL Type */
|
|
UINT16 currMbufLen; /**< mbuf length */
|
|
UINT32 atmCellHeader; /**< ATM cell header */
|
|
IX_OSAL_MBUF *pCurrMbuf; /**< pointer to mbuf */
|
|
unsigned char *pCurrMbufData; /**< Pointer to mbuf->dat */
|
|
IX_OSAL_MBUF *pNextMbuf; /**< Pointer to next mbuf */
|
|
UINT32 totalLen; /**< Total Length */
|
|
UINT32 aal5CrcResidue; /**< AAL5 CRC Residue */
|
|
} IxNpeA_TxAtmVc;
|
|
|
|
/* Changes to field sizes or orders must be reflected in the offset
|
|
* definitions above. */
|
|
|
|
|
|
|
|
|
|
/**
|
|
* @brief Rx Descriptor definition
|
|
*/
|
|
typedef struct
|
|
{
|
|
UINT32 rxBitField; /**< Recieved bit field */
|
|
UINT32 atmCellHeader; /**< ATM Cell Header */
|
|
UINT32 rsvdWord0; /**< Reserved field */
|
|
UINT16 currMbufLen; /**< Mbuf Length */
|
|
UINT8 timeLimit; /**< Payload Reassembly timeLimit (used for aal0_xx only) */
|
|
UINT8 rsvdByte0; /**< Reserved field */
|
|
UINT32 rsvdWord1; /**< Reserved field */
|
|
IX_OSAL_MBUF *pCurrMbuf; /**< Pointer to current mbuf */
|
|
unsigned char *pCurrMbufData; /**< Pointer to current mbuf->data */
|
|
IX_OSAL_MBUF *pNextMbuf; /**< Pointer to next mbuf */
|
|
UINT32 totalLen; /**< Total Length */
|
|
UINT32 aal5CrcResidue; /**< AAL5 CRC Residue */
|
|
} IxNpeA_RxAtmVc;
|
|
|
|
|
|
/**
|
|
* @brief NPE-A AAL Type
|
|
*/
|
|
typedef enum
|
|
{
|
|
IX_NPE_A_AAL_TYPE_INVALID = 0, /**< Invalid AAL type */
|
|
IX_NPE_A_AAL_TYPE_0_48 = 0x1, /**< AAL0 - 48 byte */
|
|
IX_NPE_A_AAL_TYPE_0_52 = 0x2, /**< AAL0 - 52 byte */
|
|
IX_NPE_A_AAL_TYPE_5 = 0x5, /**< AAL5 */
|
|
IX_NPE_A_AAL_TYPE_OAM = 0xF /**< OAM */
|
|
} IxNpeA_AalType;
|
|
|
|
/**
|
|
* @brief NPE-A Payload format 52-bytes & 48-bytes
|
|
*/
|
|
typedef enum
|
|
{
|
|
IX_NPE_A_52_BYTE_PAYLOAD = 0, /**< 52 byte payload */
|
|
IX_NPE_A_48_BYTE_PAYLOAD /**< 48 byte payload */
|
|
} IxNpeA_PayloadFormat;
|
|
|
|
/**
|
|
* @brief HSS Packetized NpePacket Descriptor Structure
|
|
*/
|
|
typedef struct
|
|
{
|
|
UINT8 status; /**< Status of the packet passed to the client */
|
|
UINT8 errorCount; /**< Number of errors */
|
|
UINT8 chainCount; /**< Mbuf chain count e.g. 0 - No mbuf chain */
|
|
UINT8 rsvdByte0; /**< Reserved byte to make the descriptor word align */
|
|
|
|
UINT16 packetLength; /**< Packet Length */
|
|
UINT16 rsvdShort0; /**< Reserved short to make the descriptor a word align */
|
|
|
|
IX_OSAL_MBUF *pRootMbuf; /**< Pointer to Root mbuf */
|
|
IX_OSAL_MBUF *pNextMbuf; /**< Pointer to next mbuf */
|
|
UINT8 *pMbufData; /**< Pointer to the current mbuf->data */
|
|
UINT32 mbufLength; /**< Current mbuf length */
|
|
|
|
} IxNpeA_NpePacketDescriptor;
|
|
|
|
|
|
#endif
|
|
/**
|
|
*@}
|
|
*/
|
|
|
|
#endif /* __doxygen_HIDE */
|