hpi_rxdma.h revision fe930412c257f961ae67039de3b164b83717976a
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2008 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _HPI_RXDMA_H
#define _HPI_RXDMA_H
#pragma ident "%Z%%M% %I% %E% SMI"
#ifdef __cplusplus
extern "C" {
#endif
#include <hpi.h>
#include <hxge_defs.h>
#include <hxge_pfc.h>
#include <hxge_pfc_hw.h>
#include <hxge_rdc_hw.h>
#define RXDMA_CFIG2_MBADDR_L_MASK 0x00000000ffffffc0ULL
#define RBR_CFIG_A_STDADDR_MASK 0x000000000003ffc0ULL
#define RBR_CFIG_A_STDADDR_BASE_MASK 0x00000ffffffc0000ULL
#define RCRCFIG_A_STADDR_MASK 0x000000000007FFC0ULL
#define RCRCFIG_A_STADDR_BASE_MASK 0x00000FFFFFF80000ULL
#define RCRCFIG_A_LEN_MASK 0xFFFF000000000000ULL
#define RCR_FLSH_SHIFT 0 /* RW, bit 0:0 */
#define RCR_FLSH_SET 0x0000000000000001ULL
#define RCR_FLSH_MASK 0x0000000000000001ULL
#define RBR_CFIG_A_LEN_MASK 0xFFFF000000000000ULL
/*
* Buffer block descriptor
*/
typedef struct _rx_desc_t {
} rx_desc_t, *p_rx_desc_t;
typedef enum _bsize {
SIZE_0B = 0x0,
} bsize_t;
typedef struct _rdc_desc_cfg_t {
/*
* Register offset (0x800 bytes for each channel) for receive ring registers.
*/
#define HXGE_RXDMA_OFFSET(x, v, channel) (x + \
(!v ? DMC_OFFSET(channel) : \
}
}
/*
* RX HPI error codes
*/
#define RXDMA_ID_SHIFT(n) (n << HPI_PORT_CHAN_SHIFT)
#define HPI_RXDMA_ERROR RXDMA_ER_ST
#define HPI_RXDMA_CHANNEL_INVALID(n) (RXDMA_ID_SHIFT(n) | \
#define HPI_RXDMA_OPCODE_INVALID(n) (RXDMA_ID_SHIFT(n) | \
#define RXDMA_CHANNEL_VALID(rdc) \
((rdc < HXGE_MAX_RDCS))
#define RXDMA_BUFF_OFFSET_VALID(offset) \
((offset == SW_OFFSET_NO_OFFSET) || \
(offset == SW_OFFSET_64) || \
(offset == SW_OFFSET_128))
(RCR_FLSH_SET << RCR_FLSH_SHIFT))
#ifdef __cplusplus
}
#endif
#endif /* _HPI_RXDMA_H */