numam-dpdk/drivers/net/mvpp2/mrvl_ethdev.h
Dana Vardi e622c1a88e net/mvpp2: fix configured state dependency
Need to set configure flag to allow create and commit mrvl tm
hierarchy tree. tm configuration depends on parameters that are
being set in port configure stage, e.g. nb_tx_queues.
This also aligned with the tm api description.

Fixes: 429c394417 ("net/mvpp2: support traffic manager")
Cc: stable@dpdk.org

Signed-off-by: Dana Vardi <danat@marvell.com>
Reviewed-by: Liron Himi <lironh@marvell.com>
2021-07-12 10:31:21 +02:00

253 lines
6.1 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2017 Marvell International Ltd.
* Copyright(c) 2017 Semihalf.
* All rights reserved.
*/
#ifndef _MRVL_ETHDEV_H_
#define _MRVL_ETHDEV_H_
#include <rte_spinlock.h>
#include <rte_flow_driver.h>
#include <rte_mtr_driver.h>
#include <rte_tm_driver.h>
/*
* container_of is defined by both DPDK and MUSDK,
* we'll declare only one version.
*
* Note that it is not used in this PMD anyway.
*/
#ifdef container_of
#undef container_of
#endif
#include <env/mv_autogen_comp_flags.h>
#include <drivers/mv_pp2.h>
#include <drivers/mv_pp2_bpool.h>
#include <drivers/mv_pp2_cls.h>
#include <drivers/mv_pp2_hif.h>
#include <drivers/mv_pp2_ppio.h>
#include "env/mv_common.h" /* for BIT() */
/** Maximum number of rx queues per port */
#define MRVL_PP2_RXQ_MAX 32
/** Maximum number of tx queues per port */
#define MRVL_PP2_TXQ_MAX 8
/** Minimum number of descriptors in tx queue */
#define MRVL_PP2_TXD_MIN 16
/** Maximum number of descriptors in tx queue */
#define MRVL_PP2_TXD_MAX 2048
/** Tx queue descriptors alignment */
#define MRVL_PP2_TXD_ALIGN 16
/** Minimum number of descriptors in rx queue */
#define MRVL_PP2_RXD_MIN 16
/** Maximum number of descriptors in rx queue */
#define MRVL_PP2_RXD_MAX 2048
/** Rx queue descriptors alignment */
#define MRVL_PP2_RXD_ALIGN 16
/** Maximum number of descriptors in tx aggregated queue */
#define MRVL_PP2_AGGR_TXQD_MAX 2048
/** Maximum number of Traffic Classes. */
#define MRVL_PP2_TC_MAX 8
/** Packet offset inside RX buffer. */
#define MRVL_PKT_OFFS 64
/** Maximum number of descriptors in shadow queue. Must be power of 2 */
#define MRVL_PP2_TX_SHADOWQ_SIZE MRVL_PP2_TXD_MAX
/** Shadow queue size mask (since shadow queue size is power of 2) */
#define MRVL_PP2_TX_SHADOWQ_MASK (MRVL_PP2_TX_SHADOWQ_SIZE - 1)
/** Minimum number of sent buffers to release from shadow queue to BM */
#define MRVL_PP2_BUF_RELEASE_BURST_SIZE 64
#define MRVL_PP2_VLAN_TAG_LEN 4
#define MRVL_PP2_ETH_HDRS_LEN (RTE_ETHER_HDR_LEN + RTE_ETHER_CRC_LEN + \
(2 * MRVL_PP2_VLAN_TAG_LEN))
#define MRVL_PP2_HDRS_LEN (MV_MH_SIZE + MRVL_PP2_ETH_HDRS_LEN)
#define MRVL_PP2_MTU_TO_MRU(mtu) ((mtu) + MRVL_PP2_HDRS_LEN)
#define MRVL_PP2_MRU_TO_MTU(mru) ((mru) - MRVL_PP2_HDRS_LEN)
/** Maximum length of a match string */
#define MRVL_MATCH_LEN 16
#define MRVL_BURST_SIZE 64
/** PMD-specific definition of a flow rule handle. */
struct mrvl_mtr;
struct rte_flow {
LIST_ENTRY(rte_flow) next;
struct mrvl_mtr *mtr;
struct pp2_cls_tbl_key table_key;
struct pp2_cls_tbl_rule rule;
struct pp2_cls_cos_desc cos;
struct pp2_cls_tbl_action action;
uint8_t next_udf_id;
};
struct mrvl_mtr_profile {
LIST_ENTRY(mrvl_mtr_profile) next;
uint32_t profile_id;
int refcnt;
struct rte_mtr_meter_profile profile;
};
struct mrvl_mtr {
LIST_ENTRY(mrvl_mtr) next;
uint32_t mtr_id;
int refcnt;
int shared;
int enabled;
int plcr_bit;
struct mrvl_mtr_profile *profile;
struct pp2_cls_plcr *plcr;
};
struct mrvl_tm_shaper_profile {
LIST_ENTRY(mrvl_tm_shaper_profile) next;
uint32_t id;
int refcnt;
struct rte_tm_shaper_params params;
};
enum {
MRVL_NODE_PORT,
MRVL_NODE_QUEUE,
};
struct mrvl_tm_node {
LIST_ENTRY(mrvl_tm_node) next;
uint32_t id;
uint32_t type;
int refcnt;
struct mrvl_tm_node *parent;
struct mrvl_tm_shaper_profile *profile;
uint8_t weight;
uint64_t stats_mask;
};
struct mrvl_priv {
/* Hot fields, used in fast path. */
struct pp2_bpool *bpool; /**< BPool pointer */
struct pp2_ppio *ppio; /**< Port handler pointer */
rte_spinlock_t lock; /**< Spinlock for checking bpool status */
uint16_t bpool_max_size; /**< BPool maximum size */
uint16_t bpool_min_size; /**< BPool minimum size */
uint16_t bpool_init_size; /**< Configured BPool size */
/** Mapping for DPDK rx queue->(TC, MRVL relative inq) */
struct {
uint8_t tc; /**< Traffic Class */
uint8_t inq; /**< Relative in-queue number */
} rxq_map[MRVL_PP2_RXQ_MAX] __rte_cache_aligned;
/* Configuration data, used sporadically. */
uint8_t pp_id;
uint8_t ppio_id;
uint8_t bpool_bit;
uint8_t rss_hf_tcp;
uint8_t uc_mc_flushed;
uint8_t isolated;
uint8_t multiseg;
uint16_t max_mtu;
uint8_t flow_ctrl;
struct rte_eth_fc_conf fc_conf;
struct pp2_ppio_params ppio_params;
struct pp2_cls_qos_tbl_params qos_tbl_params;
struct pp2_cls_tbl *qos_tbl;
uint16_t nb_rx_queues;
struct pp2_cls_tbl_params cls_tbl_params;
struct pp2_cls_tbl *cls_tbl;
LIST_HEAD(mrvl_flows, rte_flow) flows;
struct pp2_cls_plcr *default_policer;
LIST_HEAD(profiles, mrvl_mtr_profile) profiles;
LIST_HEAD(mtrs, mrvl_mtr) mtrs;
uint32_t used_plcrs;
LIST_HEAD(shaper_profiles, mrvl_tm_shaper_profile) shaper_profiles;
LIST_HEAD(nodes, mrvl_tm_node) nodes;
uint64_t rate_max;
uint8_t forward_bad_frames;
uint32_t fill_bpool_buffs;
uint8_t configured; /** indicates if device has been configured */
};
/** Flow operations forward declaration. */
extern const struct rte_flow_ops mrvl_flow_ops;
/** Meter operations forward declaration. */
extern const struct rte_mtr_ops mrvl_mtr_ops;
/** Traffic manager operations forward declaration. */
extern const struct rte_tm_ops mrvl_tm_ops;
/** Current log type. */
extern int mrvl_logtype;
#define MRVL_LOG(level, fmt, args...) \
rte_log(RTE_LOG_ ## level, mrvl_logtype, "%s(): " fmt "\n", \
__func__, ##args)
extern struct pp2_bpool *dummy_pool[PP2_NUM_PKT_PROC];
/**
* Convert string to uint32_t with extra checks for result correctness.
*
* @param string String to convert.
* @param val Conversion result.
* @returns 0 in case of success, negative value otherwise.
*/
static int
get_val_securely(const char *string, uint32_t *val)
{
char *endptr;
size_t len = strlen(string);
if (len == 0)
return -1;
errno = 0;
*val = strtoul(string, &endptr, 0);
if (errno != 0 || RTE_PTR_DIFF(endptr, string) != len)
return -2;
return 0;
}
static int
get_val_securely8(const char *string, uint32_t base, uint8_t *val)
{
char *endptr;
size_t len = strlen(string);
if (len == 0)
return -1;
errno = 0;
*val = (uint8_t)strtoul(string, &endptr, base);
if (errno != 0 || RTE_PTR_DIFF(endptr, string) != len)
return -2;
return 0;
}
#endif /* _MRVL_ETHDEV_H_ */