net/dpaa2: support generic flow
Signed-off-by: Sunil Kumar Kori <sunil.kori@nxp.com> Signed-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>
This commit is contained in:
parent
a3a997f02d
commit
fe2b986ac6
@ -33,6 +33,7 @@ CFLAGS += -DALLOW_EXPERIMENTAL_API
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += base/dpaa2_hw_dpni.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_rxtx.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_ethdev.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_flow.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_mux.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += mc/dpni.c
|
||||
SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += mc/dpkg.c
|
||||
|
@ -23,7 +23,7 @@
|
||||
|
||||
#include "../dpaa2_ethdev.h"
|
||||
|
||||
static int
|
||||
int
|
||||
dpaa2_distset_to_dpkg_profile_cfg(
|
||||
uint64_t req_dist_set,
|
||||
struct dpkg_profile_cfg *kg_cfg);
|
||||
@ -170,7 +170,7 @@ int dpaa2_remove_flow_dist(
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int
|
||||
int
|
||||
dpaa2_distset_to_dpkg_profile_cfg(
|
||||
uint64_t req_dist_set,
|
||||
struct dpkg_profile_cfg *kg_cfg)
|
||||
|
@ -17,6 +17,7 @@
|
||||
#include <rte_kvargs.h>
|
||||
#include <rte_dev.h>
|
||||
#include <rte_fslmc.h>
|
||||
#include <rte_flow_driver.h>
|
||||
|
||||
#include "dpaa2_pmd_logs.h"
|
||||
#include <fslmc_vfio.h>
|
||||
@ -83,6 +84,14 @@ static const struct rte_dpaa2_xstats_name_off dpaa2_xstats_strings[] = {
|
||||
{"egress_confirmed_frames", 2, 4},
|
||||
};
|
||||
|
||||
static const enum rte_filter_op dpaa2_supported_filter_ops[] = {
|
||||
RTE_ETH_FILTER_ADD,
|
||||
RTE_ETH_FILTER_DELETE,
|
||||
RTE_ETH_FILTER_UPDATE,
|
||||
RTE_ETH_FILTER_FLUSH,
|
||||
RTE_ETH_FILTER_GET
|
||||
};
|
||||
|
||||
static struct rte_dpaa2_driver rte_dpaa2_pmd;
|
||||
static int dpaa2_dev_uninit(struct rte_eth_dev *eth_dev);
|
||||
static int dpaa2_dev_link_update(struct rte_eth_dev *dev,
|
||||
@ -1892,6 +1901,47 @@ int dpaa2_eth_eventq_detach(const struct rte_eth_dev *dev,
|
||||
return ret;
|
||||
}
|
||||
|
||||
static inline int
|
||||
dpaa2_dev_verify_filter_ops(enum rte_filter_op filter_op)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < RTE_DIM(dpaa2_supported_filter_ops); i++) {
|
||||
if (dpaa2_supported_filter_ops[i] == filter_op)
|
||||
return 0;
|
||||
}
|
||||
return -ENOTSUP;
|
||||
}
|
||||
|
||||
static int
|
||||
dpaa2_dev_flow_ctrl(struct rte_eth_dev *dev,
|
||||
enum rte_filter_type filter_type,
|
||||
enum rte_filter_op filter_op,
|
||||
void *arg)
|
||||
{
|
||||
int ret = 0;
|
||||
|
||||
if (!dev)
|
||||
return -ENODEV;
|
||||
|
||||
switch (filter_type) {
|
||||
case RTE_ETH_FILTER_GENERIC:
|
||||
if (dpaa2_dev_verify_filter_ops(filter_op) < 0) {
|
||||
ret = -ENOTSUP;
|
||||
break;
|
||||
}
|
||||
*(const void **)arg = &dpaa2_flow_ops;
|
||||
dpaa2_filter_type |= filter_type;
|
||||
break;
|
||||
default:
|
||||
RTE_LOG(ERR, PMD, "Filter type (%d) not supported",
|
||||
filter_type);
|
||||
ret = -ENOTSUP;
|
||||
break;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
static struct eth_dev_ops dpaa2_ethdev_ops = {
|
||||
.dev_configure = dpaa2_eth_dev_configure,
|
||||
.dev_start = dpaa2_dev_start,
|
||||
@ -1930,6 +1980,7 @@ static struct eth_dev_ops dpaa2_ethdev_ops = {
|
||||
.mac_addr_set = dpaa2_dev_set_mac_addr,
|
||||
.rss_hash_update = dpaa2_dev_rss_hash_update,
|
||||
.rss_hash_conf_get = dpaa2_dev_rss_hash_conf_get,
|
||||
.filter_ctrl = dpaa2_dev_flow_ctrl,
|
||||
};
|
||||
|
||||
/* Populate the mac address from physically available (u-boot/firmware) and/or
|
||||
@ -2046,7 +2097,7 @@ dpaa2_dev_init(struct rte_eth_dev *eth_dev)
|
||||
struct dpni_attr attr;
|
||||
struct dpaa2_dev_priv *priv = eth_dev->data->dev_private;
|
||||
struct dpni_buffer_layout layout;
|
||||
int ret, hw_id;
|
||||
int ret, hw_id, i;
|
||||
|
||||
PMD_INIT_FUNC_TRACE();
|
||||
|
||||
@ -2102,11 +2153,8 @@ dpaa2_dev_init(struct rte_eth_dev *eth_dev)
|
||||
|
||||
priv->num_rx_tc = attr.num_rx_tcs;
|
||||
|
||||
/* Resetting the "num_rx_queues" to equal number of queues in first TC
|
||||
* as only one TC is supported on Rx Side. Once Multiple TCs will be
|
||||
* in use for Rx processing then this will be changed or removed.
|
||||
*/
|
||||
priv->nb_rx_queues = attr.num_queues;
|
||||
for (i = 0; i < attr.num_rx_tcs; i++)
|
||||
priv->nb_rx_queues += attr.num_queues;
|
||||
|
||||
/* Using number of TX queues as number of TX TCs */
|
||||
priv->nb_tx_queues = attr.num_tx_tcs;
|
||||
@ -2184,6 +2232,26 @@ dpaa2_dev_init(struct rte_eth_dev *eth_dev)
|
||||
}
|
||||
eth_dev->tx_pkt_burst = dpaa2_dev_tx;
|
||||
|
||||
/*Init fields w.r.t. classficaition*/
|
||||
memset(&priv->extract.qos_key_cfg, 0, sizeof(struct dpkg_profile_cfg));
|
||||
priv->extract.qos_extract_param = (size_t)rte_malloc(NULL, 256, 64);
|
||||
if (!priv->extract.qos_extract_param) {
|
||||
DPAA2_PMD_ERR(" Error(%d) in allocation resources for flow "
|
||||
" classificaiton ", ret);
|
||||
goto init_err;
|
||||
}
|
||||
for (i = 0; i < MAX_TCS; i++) {
|
||||
memset(&priv->extract.fs_key_cfg[i], 0,
|
||||
sizeof(struct dpkg_profile_cfg));
|
||||
priv->extract.fs_extract_param[i] =
|
||||
(size_t)rte_malloc(NULL, 256, 64);
|
||||
if (!priv->extract.fs_extract_param[i]) {
|
||||
DPAA2_PMD_ERR(" Error(%d) in allocation resources for flow classificaiton",
|
||||
ret);
|
||||
goto init_err;
|
||||
}
|
||||
}
|
||||
|
||||
RTE_LOG(INFO, PMD, "%s: netdev created\n", eth_dev->data->name);
|
||||
return 0;
|
||||
init_err:
|
||||
@ -2196,7 +2264,7 @@ dpaa2_dev_uninit(struct rte_eth_dev *eth_dev)
|
||||
{
|
||||
struct dpaa2_dev_priv *priv = eth_dev->data->dev_private;
|
||||
struct fsl_mc_io *dpni = (struct fsl_mc_io *)priv->hw;
|
||||
int ret;
|
||||
int i, ret;
|
||||
|
||||
PMD_INIT_FUNC_TRACE();
|
||||
|
||||
@ -2224,6 +2292,14 @@ dpaa2_dev_uninit(struct rte_eth_dev *eth_dev)
|
||||
priv->hw = NULL;
|
||||
rte_free(dpni);
|
||||
|
||||
for (i = 0; i < MAX_TCS; i++) {
|
||||
if (priv->extract.fs_extract_param[i])
|
||||
rte_free((void *)(size_t)priv->extract.fs_extract_param[i]);
|
||||
}
|
||||
|
||||
if (priv->extract.qos_extract_param)
|
||||
rte_free((void *)(size_t)priv->extract.qos_extract_param);
|
||||
|
||||
eth_dev->dev_ops = NULL;
|
||||
eth_dev->rx_pkt_burst = NULL;
|
||||
eth_dev->tx_pkt_burst = NULL;
|
||||
|
@ -89,6 +89,13 @@
|
||||
/* enable timestamp in mbuf*/
|
||||
extern enum pmd_dpaa2_ts dpaa2_enable_ts;
|
||||
|
||||
#define DPAA2_QOS_TABLE_RECONFIGURE 1
|
||||
#define DPAA2_FS_TABLE_RECONFIGURE 2
|
||||
|
||||
/*Externaly defined*/
|
||||
extern const struct rte_flow_ops dpaa2_flow_ops;
|
||||
extern enum rte_filter_type dpaa2_filter_type;
|
||||
|
||||
struct dpaa2_dev_priv {
|
||||
void *hw;
|
||||
int32_t hw_id;
|
||||
@ -107,8 +114,23 @@ struct dpaa2_dev_priv {
|
||||
uint8_t flags; /*dpaa2 config flags */
|
||||
uint8_t en_ordered;
|
||||
uint8_t en_loose_ordered;
|
||||
|
||||
struct pattern_s {
|
||||
uint8_t item_count;
|
||||
uint8_t pattern_type[DPKG_MAX_NUM_OF_EXTRACTS];
|
||||
} pattern[MAX_TCS + 1];
|
||||
|
||||
struct extract_s {
|
||||
struct dpkg_profile_cfg qos_key_cfg;
|
||||
struct dpkg_profile_cfg fs_key_cfg[MAX_TCS];
|
||||
uint64_t qos_extract_param;
|
||||
uint64_t fs_extract_param[MAX_TCS];
|
||||
} extract;
|
||||
};
|
||||
|
||||
int dpaa2_distset_to_dpkg_profile_cfg(uint64_t req_dist_set,
|
||||
struct dpkg_profile_cfg *kg_cfg);
|
||||
|
||||
int dpaa2_setup_flow_dist(struct rte_eth_dev *eth_dev,
|
||||
uint64_t req_dist_set);
|
||||
|
||||
|
1972
drivers/net/dpaa2/dpaa2_flow.c
Normal file
1972
drivers/net/dpaa2/dpaa2_flow.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -1528,6 +1528,248 @@ int dpni_set_tx_confirmation_mode(struct fsl_mc_io *mc_io,
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_set_qos_table() - Set QoS mapping table
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @cfg: QoS table configuration
|
||||
*
|
||||
* This function and all QoS-related functions require that
|
||||
*'max_tcs > 1' was set at DPNI creation.
|
||||
*
|
||||
* warning: Before calling this function, call dpkg_prepare_key_cfg() to
|
||||
* prepare the key_cfg_iova parameter
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_set_qos_table(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_qos_tbl_cfg *cfg)
|
||||
{
|
||||
struct dpni_cmd_set_qos_table *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_SET_QOS_TBL,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_set_qos_table *)cmd.params;
|
||||
cmd_params->default_tc = cfg->default_tc;
|
||||
cmd_params->key_cfg_iova = cpu_to_le64(cfg->key_cfg_iova);
|
||||
dpni_set_field(cmd_params->discard_on_miss,
|
||||
ENABLE,
|
||||
cfg->discard_on_miss);
|
||||
dpni_set_field(cmd_params->discard_on_miss,
|
||||
KEEP_QOS_ENTRIES,
|
||||
cfg->keep_entries);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_add_qos_entry() - Add QoS mapping entry (to select a traffic class)
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @cfg: QoS rule to add
|
||||
* @tc_id: Traffic class selection (0-7)
|
||||
* @index: Location in the QoS table where to insert the entry.
|
||||
* Only relevant if MASKING is enabled for QoS classification on
|
||||
* this DPNI, it is ignored for exact match.
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_add_qos_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_rule_cfg *cfg,
|
||||
uint8_t tc_id,
|
||||
uint16_t index)
|
||||
{
|
||||
struct dpni_cmd_add_qos_entry *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_ADD_QOS_ENT,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_add_qos_entry *)cmd.params;
|
||||
cmd_params->tc_id = tc_id;
|
||||
cmd_params->key_size = cfg->key_size;
|
||||
cmd_params->index = cpu_to_le16(index);
|
||||
cmd_params->key_iova = cpu_to_le64(cfg->key_iova);
|
||||
cmd_params->mask_iova = cpu_to_le64(cfg->mask_iova);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_remove_qos_entry() - Remove QoS mapping entry
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @cfg: QoS rule to remove
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_remove_qos_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_rule_cfg *cfg)
|
||||
{
|
||||
struct dpni_cmd_remove_qos_entry *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_REMOVE_QOS_ENT,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_remove_qos_entry *)cmd.params;
|
||||
cmd_params->key_size = cfg->key_size;
|
||||
cmd_params->key_iova = cpu_to_le64(cfg->key_iova);
|
||||
cmd_params->mask_iova = cpu_to_le64(cfg->mask_iova);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_clear_qos_table() - Clear all QoS mapping entries
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
*
|
||||
* Following this function call, all frames are directed to
|
||||
* the default traffic class (0)
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_clear_qos_table(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token)
|
||||
{
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_CLR_QOS_TBL,
|
||||
cmd_flags,
|
||||
token);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_add_fs_entry() - Add Flow Steering entry for a specific traffic class
|
||||
* (to select a flow ID)
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @tc_id: Traffic class selection (0-7)
|
||||
* @index: Location in the QoS table where to insert the entry.
|
||||
* Only relevant if MASKING is enabled for QoS classification
|
||||
* on this DPNI, it is ignored for exact match.
|
||||
* @cfg: Flow steering rule to add
|
||||
* @action: Action to be taken as result of a classification hit
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_add_fs_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id,
|
||||
uint16_t index,
|
||||
const struct dpni_rule_cfg *cfg,
|
||||
const struct dpni_fs_action_cfg *action)
|
||||
{
|
||||
struct dpni_cmd_add_fs_entry *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_ADD_FS_ENT,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_add_fs_entry *)cmd.params;
|
||||
cmd_params->tc_id = tc_id;
|
||||
cmd_params->key_size = cfg->key_size;
|
||||
cmd_params->index = cpu_to_le16(index);
|
||||
cmd_params->key_iova = cpu_to_le64(cfg->key_iova);
|
||||
cmd_params->mask_iova = cpu_to_le64(cfg->mask_iova);
|
||||
cmd_params->options = cpu_to_le16(action->options);
|
||||
cmd_params->flow_id = cpu_to_le16(action->flow_id);
|
||||
cmd_params->flc = cpu_to_le64(action->flc);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_remove_fs_entry() - Remove Flow Steering entry from a specific
|
||||
* traffic class
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @tc_id: Traffic class selection (0-7)
|
||||
* @cfg: Flow steering rule to remove
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_remove_fs_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id,
|
||||
const struct dpni_rule_cfg *cfg)
|
||||
{
|
||||
struct dpni_cmd_remove_fs_entry *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_REMOVE_FS_ENT,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_remove_fs_entry *)cmd.params;
|
||||
cmd_params->tc_id = tc_id;
|
||||
cmd_params->key_size = cfg->key_size;
|
||||
cmd_params->key_iova = cpu_to_le64(cfg->key_iova);
|
||||
cmd_params->mask_iova = cpu_to_le64(cfg->mask_iova);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_clear_fs_entries() - Clear all Flow Steering entries of a specific
|
||||
* traffic class
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @tc_id: Traffic class selection (0-7)
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpni_clear_fs_entries(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id)
|
||||
{
|
||||
struct dpni_cmd_clear_fs_entries *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_CLR_FS_ENT,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_clear_fs_entries *)cmd.params;
|
||||
cmd_params->tc_id = tc_id;
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_set_congestion_notification() - Set traffic class congestion
|
||||
* notification configuration
|
||||
@ -2064,6 +2306,76 @@ int dpni_get_opr(struct fsl_mc_io *mc_io,
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_set_rx_fs_dist() - Set Rx traffic class FS distribution
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @cfg: Distribution configuration
|
||||
* If the FS is already enabled with a previous call the classification
|
||||
* key will be changed but all the table rules are kept. If the
|
||||
* existing rules do not match the key the results will not be
|
||||
* predictable. It is the user responsibility to keep key integrity
|
||||
* If cfg.enable is set to 1 the command will create a flow steering table
|
||||
* and will classify packets according to this table. The packets
|
||||
* that miss all the table rules will be classified according to
|
||||
* settings made in dpni_set_rx_hash_dist()
|
||||
* If cfg.enable is set to 0 the command will clear flow steering table. The
|
||||
* packets will be classified according to settings made in
|
||||
* dpni_set_rx_hash_dist()
|
||||
*/
|
||||
int dpni_set_rx_fs_dist(struct fsl_mc_io *mc_io, uint32_t cmd_flags,
|
||||
uint16_t token, const struct dpni_rx_dist_cfg *cfg)
|
||||
{
|
||||
struct dpni_cmd_set_rx_fs_dist *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_SET_RX_FS_DIST,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_set_rx_fs_dist *)cmd.params;
|
||||
cmd_params->dist_size = cpu_to_le16(cfg->dist_size);
|
||||
dpni_set_field(cmd_params->enable, RX_FS_DIST_ENABLE, cfg->enable);
|
||||
cmd_params->tc = cfg->tc;
|
||||
cmd_params->miss_flow_id = cpu_to_le16(cfg->fs_miss_flow_id);
|
||||
cmd_params->key_cfg_iova = cpu_to_le64(cfg->key_cfg_iova);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_set_rx_hash_dist() - Set Rx traffic class HASH distribution
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPNI object
|
||||
* @cfg: Distribution configuration
|
||||
* If cfg.enable is set to 1 the packets will be classified using a hash
|
||||
* function based on the key received in cfg.key_cfg_iova parameter
|
||||
* If cfg.enable is set to 0 the packets will be sent to the queue configured in
|
||||
* dpni_set_rx_dist_default_queue() call
|
||||
*/
|
||||
int dpni_set_rx_hash_dist(struct fsl_mc_io *mc_io, uint32_t cmd_flags,
|
||||
uint16_t token, const struct dpni_rx_dist_cfg *cfg)
|
||||
{
|
||||
struct dpni_cmd_set_rx_hash_dist *cmd_params;
|
||||
struct mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPNI_CMDID_SET_RX_HASH_DIST,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpni_cmd_set_rx_hash_dist *)cmd.params;
|
||||
cmd_params->dist_size = cpu_to_le16(cfg->dist_size);
|
||||
dpni_set_field(cmd_params->enable, RX_FS_DIST_ENABLE, cfg->enable);
|
||||
cmd_params->tc_id = cfg->tc;
|
||||
cmd_params->key_cfg_iova = cpu_to_le64(cfg->key_cfg_iova);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpni_add_custom_tpid() - Configures a distinct Ethertype value
|
||||
* (or TPID value) to indicate VLAN tag in addition to the common
|
||||
|
@ -1071,6 +1071,123 @@ int dpni_get_tx_confirmation_mode(struct fsl_mc_io *mc_io,
|
||||
uint16_t token,
|
||||
enum dpni_confirmation_mode *mode);
|
||||
|
||||
/**
|
||||
* struct dpni_qos_tbl_cfg - Structure representing QOS table configuration
|
||||
* @key_cfg_iova: I/O virtual address of 256 bytes DMA-able memory filled with
|
||||
* key extractions to be used as the QoS criteria by calling
|
||||
* dpkg_prepare_key_cfg()
|
||||
* @discard_on_miss: Set to '1' to discard frames in case of no match (miss);
|
||||
* '0' to use the 'default_tc' in such cases
|
||||
* @keep_entries: if set to one will not delele existing table entries. This
|
||||
* option will work properly only for dpni objects created with
|
||||
* DPNI_OPT_HAS_KEY_MASKING option. All previous QoS entries must
|
||||
* be compatible with new key composition rule.
|
||||
* It is the caller's job to delete incompatible entries before
|
||||
* executing this function.
|
||||
* @default_tc: Used in case of no-match and 'discard_on_miss'= 0
|
||||
*/
|
||||
struct dpni_qos_tbl_cfg {
|
||||
uint64_t key_cfg_iova;
|
||||
int discard_on_miss;
|
||||
int keep_entries;
|
||||
uint8_t default_tc;
|
||||
};
|
||||
|
||||
int dpni_set_qos_table(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_qos_tbl_cfg *cfg);
|
||||
|
||||
/**
|
||||
* struct dpni_rule_cfg - Rule configuration for table lookup
|
||||
* @key_iova: I/O virtual address of the key (must be in DMA-able memory)
|
||||
* @mask_iova: I/O virtual address of the mask (must be in DMA-able memory)
|
||||
* @key_size: key and mask size (in bytes)
|
||||
*/
|
||||
struct dpni_rule_cfg {
|
||||
uint64_t key_iova;
|
||||
uint64_t mask_iova;
|
||||
uint8_t key_size;
|
||||
};
|
||||
|
||||
int dpni_add_qos_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_rule_cfg *cfg,
|
||||
uint8_t tc_id,
|
||||
uint16_t index);
|
||||
|
||||
int dpni_remove_qos_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
const struct dpni_rule_cfg *cfg);
|
||||
|
||||
int dpni_clear_qos_table(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token);
|
||||
|
||||
/**
|
||||
* Discard matching traffic. If set, this takes precedence over any other
|
||||
* configuration and matching traffic is always discarded.
|
||||
*/
|
||||
#define DPNI_FS_OPT_DISCARD 0x1
|
||||
|
||||
/**
|
||||
* Set FLC value. If set, flc member of truct dpni_fs_action_cfg is used to
|
||||
* override the FLC value set per queue.
|
||||
* For more details check the Frame Descriptor section in the hardware
|
||||
* documentation.
|
||||
*/
|
||||
#define DPNI_FS_OPT_SET_FLC 0x2
|
||||
|
||||
/*
|
||||
* Indicates whether the 6 lowest significant bits of FLC are used for stash
|
||||
* control. If set, the 6 least significant bits in value are interpreted as
|
||||
* follows:
|
||||
* - bits 0-1: indicates the number of 64 byte units of context that are
|
||||
* stashed. FLC value is interpreted as a memory address in this case,
|
||||
* excluding the 6 LS bits.
|
||||
* - bits 2-3: indicates the number of 64 byte units of frame annotation
|
||||
* to be stashed. Annotation is placed at FD[ADDR].
|
||||
* - bits 4-5: indicates the number of 64 byte units of frame data to be
|
||||
* stashed. Frame data is placed at FD[ADDR] + FD[OFFSET].
|
||||
* This flag is ignored if DPNI_FS_OPT_SET_FLC is not specified.
|
||||
*/
|
||||
#define DPNI_FS_OPT_SET_STASH_CONTROL 0x4
|
||||
|
||||
/**
|
||||
* struct dpni_fs_action_cfg - Action configuration for table look-up
|
||||
* @flc: FLC value for traffic matching this rule. Please check the Frame
|
||||
* Descriptor section in the hardware documentation for more information.
|
||||
* @flow_id: Identifies the Rx queue used for matching traffic. Supported
|
||||
* values are in range 0 to num_queue-1.
|
||||
* @options: Any combination of DPNI_FS_OPT_ values.
|
||||
*/
|
||||
struct dpni_fs_action_cfg {
|
||||
uint64_t flc;
|
||||
uint16_t flow_id;
|
||||
uint16_t options;
|
||||
};
|
||||
|
||||
int dpni_add_fs_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id,
|
||||
uint16_t index,
|
||||
const struct dpni_rule_cfg *cfg,
|
||||
const struct dpni_fs_action_cfg *action);
|
||||
|
||||
int dpni_remove_fs_entry(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id,
|
||||
const struct dpni_rule_cfg *cfg);
|
||||
|
||||
int dpni_clear_fs_entries(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t token,
|
||||
uint8_t tc_id);
|
||||
|
||||
int dpni_get_api_version(struct fsl_mc_io *mc_io,
|
||||
uint32_t cmd_flags,
|
||||
uint16_t *major_ver,
|
||||
@ -1202,6 +1319,43 @@ int dpni_get_opr(struct fsl_mc_io *mc_io,
|
||||
struct opr_cfg *cfg,
|
||||
struct opr_qry *qry);
|
||||
|
||||
/**
|
||||
* When used for queue_idx in function dpni_set_rx_dist_default_queue will
|
||||
* signal to dpni to drop all unclassified frames
|
||||
*/
|
||||
#define DPNI_FS_MISS_DROP ((uint16_t)-1)
|
||||
|
||||
/**
|
||||
* struct dpni_rx_dist_cfg - distribution configuration
|
||||
* @dist_size: distribution size; supported values: 1,2,3,4,6,7,8,
|
||||
* 12,14,16,24,28,32,48,56,64,96,112,128,192,224,256,384,448,
|
||||
* 512,768,896,1024
|
||||
* @key_cfg_iova: I/O virtual address of 256 bytes DMA-able memory filled with
|
||||
* the extractions to be used for the distribution key by calling
|
||||
* dpkg_prepare_key_cfg() relevant only when enable!=0 otherwise
|
||||
* it can be '0'
|
||||
* @enable: enable/disable the distribution.
|
||||
* @tc: TC id for which distribution is set
|
||||
* @fs_miss_flow_id: when packet misses all rules from flow steering table and
|
||||
* hash is disabled it will be put into this queue id; use
|
||||
* DPNI_FS_MISS_DROP to drop frames. The value of this field is
|
||||
* used only when flow steering distribution is enabled and hash
|
||||
* distribution is disabled
|
||||
*/
|
||||
struct dpni_rx_dist_cfg {
|
||||
uint16_t dist_size;
|
||||
uint64_t key_cfg_iova;
|
||||
uint8_t enable;
|
||||
uint8_t tc;
|
||||
uint16_t fs_miss_flow_id;
|
||||
};
|
||||
|
||||
int dpni_set_rx_fs_dist(struct fsl_mc_io *mc_io, uint32_t cmd_flags,
|
||||
uint16_t token, const struct dpni_rx_dist_cfg *cfg);
|
||||
|
||||
int dpni_set_rx_hash_dist(struct fsl_mc_io *mc_io, uint32_t cmd_flags,
|
||||
uint16_t token, const struct dpni_rx_dist_cfg *cfg);
|
||||
|
||||
int dpni_add_custom_tpid(struct fsl_mc_io *mc_io, uint32_t cmd_flags,
|
||||
uint16_t token, uint16_t tpid);
|
||||
|
||||
|
@ -69,6 +69,14 @@
|
||||
|
||||
#define DPNI_CMDID_SET_RX_TC_DIST DPNI_CMD_V3(0x235)
|
||||
|
||||
#define DPNI_CMDID_SET_QOS_TBL DPNI_CMD_V2(0x240)
|
||||
#define DPNI_CMDID_ADD_QOS_ENT DPNI_CMD(0x241)
|
||||
#define DPNI_CMDID_REMOVE_QOS_ENT DPNI_CMD(0x242)
|
||||
#define DPNI_CMDID_CLR_QOS_TBL DPNI_CMD(0x243)
|
||||
#define DPNI_CMDID_ADD_FS_ENT DPNI_CMD(0x244)
|
||||
#define DPNI_CMDID_REMOVE_FS_ENT DPNI_CMD(0x245)
|
||||
#define DPNI_CMDID_CLR_FS_ENT DPNI_CMD(0x246)
|
||||
|
||||
#define DPNI_CMDID_GET_STATISTICS DPNI_CMD_V2(0x25D)
|
||||
#define DPNI_CMDID_RESET_STATISTICS DPNI_CMD(0x25E)
|
||||
#define DPNI_CMDID_GET_QUEUE DPNI_CMD(0x25F)
|
||||
@ -91,6 +99,8 @@
|
||||
#define DPNI_CMDID_GET_TX_CONFIRMATION_MODE DPNI_CMD(0x26D)
|
||||
#define DPNI_CMDID_SET_OPR DPNI_CMD(0x26e)
|
||||
#define DPNI_CMDID_GET_OPR DPNI_CMD(0x26f)
|
||||
#define DPNI_CMDID_SET_RX_FS_DIST DPNI_CMD(0x273)
|
||||
#define DPNI_CMDID_SET_RX_HASH_DIST DPNI_CMD(0x274)
|
||||
#define DPNI_CMDID_ADD_CUSTOM_TPID DPNI_CMD(0x275)
|
||||
#define DPNI_CMDID_REMOVE_CUSTOM_TPID DPNI_CMD(0x276)
|
||||
#define DPNI_CMDID_GET_CUSTOM_TPID DPNI_CMD(0x277)
|
||||
@ -495,6 +505,63 @@ struct dpni_cmd_set_queue {
|
||||
uint64_t user_context;
|
||||
};
|
||||
|
||||
#define DPNI_DISCARD_ON_MISS_SHIFT 0
|
||||
#define DPNI_DISCARD_ON_MISS_SIZE 1
|
||||
#define DPNI_KEEP_QOS_ENTRIES_SHIFT 1
|
||||
#define DPNI_KEEP_QOS_ENTRIES_SIZE 1
|
||||
|
||||
struct dpni_cmd_set_qos_table {
|
||||
uint32_t pad;
|
||||
uint8_t default_tc;
|
||||
/* only the LSB */
|
||||
uint8_t discard_on_miss;
|
||||
uint16_t pad1[21];
|
||||
uint64_t key_cfg_iova;
|
||||
};
|
||||
|
||||
struct dpni_cmd_add_qos_entry {
|
||||
uint16_t pad;
|
||||
uint8_t tc_id;
|
||||
uint8_t key_size;
|
||||
uint16_t index;
|
||||
uint16_t pad2;
|
||||
uint64_t key_iova;
|
||||
uint64_t mask_iova;
|
||||
};
|
||||
|
||||
struct dpni_cmd_remove_qos_entry {
|
||||
uint8_t pad1[3];
|
||||
uint8_t key_size;
|
||||
uint32_t pad2;
|
||||
uint64_t key_iova;
|
||||
uint64_t mask_iova;
|
||||
};
|
||||
|
||||
struct dpni_cmd_add_fs_entry {
|
||||
uint16_t options;
|
||||
uint8_t tc_id;
|
||||
uint8_t key_size;
|
||||
uint16_t index;
|
||||
uint16_t flow_id;
|
||||
uint64_t key_iova;
|
||||
uint64_t mask_iova;
|
||||
uint64_t flc;
|
||||
};
|
||||
|
||||
struct dpni_cmd_remove_fs_entry {
|
||||
uint16_t pad1;
|
||||
uint8_t tc_id;
|
||||
uint8_t key_size;
|
||||
uint32_t pad2;
|
||||
uint64_t key_iova;
|
||||
uint64_t mask_iova;
|
||||
};
|
||||
|
||||
struct dpni_cmd_clear_fs_entries {
|
||||
uint16_t pad;
|
||||
uint8_t tc_id;
|
||||
};
|
||||
|
||||
#define DPNI_DROP_ENABLE_SHIFT 0
|
||||
#define DPNI_DROP_ENABLE_SIZE 1
|
||||
#define DPNI_DROP_UNITS_SHIFT 2
|
||||
@ -692,5 +759,26 @@ struct dpni_rsp_get_custom_tpid {
|
||||
uint16_t tpid2;
|
||||
};
|
||||
|
||||
#define DPNI_RX_FS_DIST_ENABLE_SHIFT 0
|
||||
#define DPNI_RX_FS_DIST_ENABLE_SIZE 1
|
||||
struct dpni_cmd_set_rx_fs_dist {
|
||||
uint16_t dist_size;
|
||||
uint8_t enable;
|
||||
uint8_t tc;
|
||||
uint16_t miss_flow_id;
|
||||
uint16_t pad1;
|
||||
uint64_t key_cfg_iova;
|
||||
};
|
||||
|
||||
#define DPNI_RX_HASH_DIST_ENABLE_SHIFT 0
|
||||
#define DPNI_RX_HASH_DIST_ENABLE_SIZE 1
|
||||
struct dpni_cmd_set_rx_hash_dist {
|
||||
uint16_t dist_size;
|
||||
uint8_t enable;
|
||||
uint8_t tc_id;
|
||||
uint32_t pad;
|
||||
uint64_t key_cfg_iova;
|
||||
};
|
||||
|
||||
#pragma pack(pop)
|
||||
#endif /* _FSL_DPNI_CMD_H */
|
||||
|
@ -11,6 +11,7 @@ deps += ['mempool_dpaa2']
|
||||
sources = files('base/dpaa2_hw_dpni.c',
|
||||
'dpaa2_mux.c',
|
||||
'dpaa2_ethdev.c',
|
||||
'dpaa2_flow.c',
|
||||
'dpaa2_rxtx.c',
|
||||
'mc/dpkg.c',
|
||||
'mc/dpdmux.c',
|
||||
|
Loading…
x
Reference in New Issue
Block a user