2014-06-04 18:08:19 +00:00
|
|
|
/*-
|
|
|
|
* BSD LICENSE
|
|
|
|
*
|
|
|
|
* Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * 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.
|
|
|
|
* * Neither the name of 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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __INCLUDE_RTE_PORT_H__
|
|
|
|
#define __INCLUDE_RTE_PORT_H__
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* RTE Port
|
|
|
|
*
|
2016-02-08 10:30:07 +00:00
|
|
|
* This tool is part of the DPDK Packet Framework tool suite and provides
|
2014-06-04 18:08:19 +00:00
|
|
|
* a standard interface to implement different types of packet ports.
|
|
|
|
*
|
|
|
|
***/
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <rte_mbuf.h>
|
|
|
|
|
2014-09-17 16:11:12 +00:00
|
|
|
/**@{
|
2014-09-11 13:15:41 +00:00
|
|
|
* Macros to allow accessing metadata stored in the mbuf headroom
|
|
|
|
* just beyond the end of the mbuf data structure returned by a port
|
|
|
|
*/
|
|
|
|
#define RTE_MBUF_METADATA_UINT8_PTR(mbuf, offset) \
|
2015-09-11 13:35:45 +00:00
|
|
|
(&((uint8_t *)(mbuf))[offset])
|
2014-09-11 13:15:41 +00:00
|
|
|
#define RTE_MBUF_METADATA_UINT16_PTR(mbuf, offset) \
|
2015-06-05 14:55:10 +00:00
|
|
|
((uint16_t *) RTE_MBUF_METADATA_UINT8_PTR(mbuf, offset))
|
2014-09-11 13:15:41 +00:00
|
|
|
#define RTE_MBUF_METADATA_UINT32_PTR(mbuf, offset) \
|
2015-06-05 14:55:10 +00:00
|
|
|
((uint32_t *) RTE_MBUF_METADATA_UINT8_PTR(mbuf, offset))
|
2014-09-11 13:15:41 +00:00
|
|
|
#define RTE_MBUF_METADATA_UINT64_PTR(mbuf, offset) \
|
2015-06-05 14:55:10 +00:00
|
|
|
((uint64_t *) RTE_MBUF_METADATA_UINT8_PTR(mbuf, offset))
|
|
|
|
|
|
|
|
#define RTE_MBUF_METADATA_UINT8(mbuf, offset) \
|
|
|
|
(*RTE_MBUF_METADATA_UINT8_PTR(mbuf, offset))
|
|
|
|
#define RTE_MBUF_METADATA_UINT16(mbuf, offset) \
|
|
|
|
(*RTE_MBUF_METADATA_UINT16_PTR(mbuf, offset))
|
|
|
|
#define RTE_MBUF_METADATA_UINT32(mbuf, offset) \
|
|
|
|
(*RTE_MBUF_METADATA_UINT32_PTR(mbuf, offset))
|
|
|
|
#define RTE_MBUF_METADATA_UINT64(mbuf, offset) \
|
|
|
|
(*RTE_MBUF_METADATA_UINT64_PTR(mbuf, offset))
|
2014-09-17 16:11:12 +00:00
|
|
|
/**@}*/
|
2014-09-11 13:15:41 +00:00
|
|
|
|
2014-06-04 18:08:19 +00:00
|
|
|
/*
|
|
|
|
* Port IN
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
/** Maximum number of packets read from any input port in a single burst.
|
|
|
|
Cannot be changed. */
|
|
|
|
#define RTE_PORT_IN_BURST_SIZE_MAX 64
|
|
|
|
|
2015-06-19 09:41:13 +00:00
|
|
|
/** Input port statistics */
|
|
|
|
struct rte_port_in_stats {
|
|
|
|
uint64_t n_pkts_in;
|
|
|
|
uint64_t n_pkts_drop;
|
|
|
|
};
|
|
|
|
|
2014-06-04 18:08:19 +00:00
|
|
|
/**
|
|
|
|
* Input port create
|
|
|
|
*
|
|
|
|
* @param params
|
|
|
|
* Parameters for input port creation
|
|
|
|
* @param socket_id
|
|
|
|
* CPU socket ID (e.g. for memory allocation purpose)
|
|
|
|
* @return
|
|
|
|
* Handle to input port instance
|
|
|
|
*/
|
|
|
|
typedef void* (*rte_port_in_op_create)(void *params, int socket_id);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Input port free
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to input port instance
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_in_op_free)(void *port);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Input port packet burst RX
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to input port instance
|
|
|
|
* @param pkts
|
|
|
|
* Burst of input packets
|
|
|
|
* @param n_pkts
|
|
|
|
* Number of packets in the input burst
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_in_op_rx)(
|
|
|
|
void *port,
|
|
|
|
struct rte_mbuf **pkts,
|
|
|
|
uint32_t n_pkts);
|
|
|
|
|
2015-06-19 09:41:13 +00:00
|
|
|
/**
|
|
|
|
* Input port stats get
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @param stats
|
|
|
|
* Handle to port_in stats struct to copy data
|
|
|
|
* @param clear
|
|
|
|
* Flag indicating that stats should be cleared after read
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* Error code or 0 on success.
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_in_op_stats_read)(
|
|
|
|
void *port,
|
|
|
|
struct rte_port_in_stats *stats,
|
|
|
|
int clear);
|
|
|
|
|
2014-06-04 18:08:19 +00:00
|
|
|
/** Input port interface defining the input port operation */
|
|
|
|
struct rte_port_in_ops {
|
2015-06-19 09:41:13 +00:00
|
|
|
rte_port_in_op_create f_create; /**< Create */
|
|
|
|
rte_port_in_op_free f_free; /**< Free */
|
|
|
|
rte_port_in_op_rx f_rx; /**< Packet RX (packet burst) */
|
|
|
|
rte_port_in_op_stats_read f_stats; /**< Stats */
|
2014-06-04 18:08:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Port OUT
|
|
|
|
*
|
|
|
|
*/
|
2015-06-19 09:41:13 +00:00
|
|
|
/** Output port statistics */
|
|
|
|
struct rte_port_out_stats {
|
|
|
|
uint64_t n_pkts_in;
|
|
|
|
uint64_t n_pkts_drop;
|
|
|
|
};
|
|
|
|
|
2014-06-04 18:08:19 +00:00
|
|
|
/**
|
|
|
|
* Output port create
|
|
|
|
*
|
|
|
|
* @param params
|
|
|
|
* Parameters for output port creation
|
|
|
|
* @param socket_id
|
|
|
|
* CPU socket ID (e.g. for memory allocation purpose)
|
|
|
|
* @return
|
|
|
|
* Handle to output port instance
|
|
|
|
*/
|
|
|
|
typedef void* (*rte_port_out_op_create)(void *params, int socket_id);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output port free
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_out_op_free)(void *port);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output port single packet TX
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @param pkt
|
|
|
|
* Input packet
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_out_op_tx)(
|
|
|
|
void *port,
|
|
|
|
struct rte_mbuf *pkt);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output port packet burst TX
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @param pkts
|
|
|
|
* Burst of input packets specified as array of up to 64 pointers to struct
|
|
|
|
* rte_mbuf
|
|
|
|
* @param pkts_mask
|
|
|
|
* 64-bit bitmask specifying which packets in the input burst are valid. When
|
|
|
|
* pkts_mask bit n is set, then element n of pkts array is pointing to a
|
|
|
|
* valid packet. Otherwise, element n of pkts array will not be accessed.
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_out_op_tx_bulk)(
|
|
|
|
void *port,
|
|
|
|
struct rte_mbuf **pkt,
|
|
|
|
uint64_t pkts_mask);
|
|
|
|
|
|
|
|
/**
|
2014-07-15 14:06:03 +00:00
|
|
|
* Output port flush
|
2014-06-04 18:08:19 +00:00
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @return
|
|
|
|
* 0 on success, error code otherwise
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_out_op_flush)(void *port);
|
|
|
|
|
2015-06-19 09:41:13 +00:00
|
|
|
/**
|
|
|
|
* Output port stats read
|
|
|
|
*
|
|
|
|
* @param port
|
|
|
|
* Handle to output port instance
|
|
|
|
* @param stats
|
|
|
|
* Handle to port_out stats struct to copy data
|
|
|
|
* @param clear
|
|
|
|
* Flag indicating that stats should be cleared after read
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* Error code or 0 on success.
|
|
|
|
*/
|
|
|
|
typedef int (*rte_port_out_op_stats_read)(
|
|
|
|
void *port,
|
|
|
|
struct rte_port_out_stats *stats,
|
|
|
|
int clear);
|
|
|
|
|
2014-06-04 18:08:19 +00:00
|
|
|
/** Output port interface defining the output port operation */
|
|
|
|
struct rte_port_out_ops {
|
2015-06-19 09:41:13 +00:00
|
|
|
rte_port_out_op_create f_create; /**< Create */
|
|
|
|
rte_port_out_op_free f_free; /**< Free */
|
|
|
|
rte_port_out_op_tx f_tx; /**< Packet TX (single packet) */
|
|
|
|
rte_port_out_op_tx_bulk f_tx_bulk; /**< Packet TX (packet burst) */
|
|
|
|
rte_port_out_op_flush f_flush; /**< Flush */
|
|
|
|
rte_port_out_op_stats_read f_stats; /**< Stats */
|
2014-06-04 18:08:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|