net/ixgbe: support committing TM hierarchy
Add the support of the Traffic Management API, rte_tm_hierarchy_commit. When calling this API, the driver tries to enable the TM configuration on HW. Signed-off-by: Wenzhuo Lu <wenzhuo.lu@intel.com>
This commit is contained in:
parent
cb2ffec595
commit
5713ade697
@ -304,9 +304,6 @@ static void ixgbe_set_ivar_map(struct ixgbe_hw *hw, int8_t direction,
|
||||
uint8_t queue, uint8_t msix_vector);
|
||||
static void ixgbe_configure_msix(struct rte_eth_dev *dev);
|
||||
|
||||
static int ixgbe_set_queue_rate_limit(struct rte_eth_dev *dev,
|
||||
uint16_t queue_idx, uint16_t tx_rate);
|
||||
|
||||
static int ixgbevf_add_mac_addr(struct rte_eth_dev *dev,
|
||||
struct ether_addr *mac_addr,
|
||||
uint32_t index, uint32_t pool);
|
||||
@ -2503,6 +2500,8 @@ ixgbe_dev_start(struct rte_eth_dev *dev)
|
||||
int status;
|
||||
uint16_t vf, idx;
|
||||
uint32_t *link_speeds;
|
||||
struct ixgbe_tm_conf *tm_conf =
|
||||
IXGBE_DEV_PRIVATE_TO_TM_CONF(dev->data->dev_private);
|
||||
|
||||
PMD_INIT_FUNC_TRACE();
|
||||
|
||||
@ -2693,6 +2692,11 @@ skip_link_setup:
|
||||
ixgbe_l2_tunnel_conf(dev);
|
||||
ixgbe_filter_restore(dev);
|
||||
|
||||
if (!tm_conf->committed)
|
||||
PMD_DRV_LOG(WARNING,
|
||||
"please call hierarchy_commit() "
|
||||
"before starting the port");
|
||||
|
||||
return 0;
|
||||
|
||||
error:
|
||||
@ -5733,8 +5737,9 @@ ixgbe_configure_msix(struct rte_eth_dev *dev)
|
||||
IXGBE_WRITE_REG(hw, IXGBE_EIAC, mask);
|
||||
}
|
||||
|
||||
static int ixgbe_set_queue_rate_limit(struct rte_eth_dev *dev,
|
||||
uint16_t queue_idx, uint16_t tx_rate)
|
||||
int
|
||||
ixgbe_set_queue_rate_limit(struct rte_eth_dev *dev,
|
||||
uint16_t queue_idx, uint16_t tx_rate)
|
||||
{
|
||||
struct ixgbe_hw *hw = IXGBE_DEV_PRIVATE_TO_HW(dev->data->dev_private);
|
||||
uint32_t rf_dec, rf_int;
|
||||
|
@ -742,6 +742,8 @@ bool is_ixgbe_supported(struct rte_eth_dev *dev);
|
||||
int ixgbe_tm_ops_get(struct rte_eth_dev *dev, void *ops);
|
||||
void ixgbe_tm_conf_init(struct rte_eth_dev *dev);
|
||||
void ixgbe_tm_conf_uninit(struct rte_eth_dev *dev);
|
||||
int ixgbe_set_queue_rate_limit(struct rte_eth_dev *dev, uint16_t queue_idx,
|
||||
uint16_t tx_rate);
|
||||
|
||||
static inline int
|
||||
ixgbe_ethertype_filter_lookup(struct ixgbe_filter_info *filter_info,
|
||||
|
@ -62,6 +62,9 @@ static int ixgbe_node_capabilities_get(struct rte_eth_dev *dev,
|
||||
uint32_t node_id,
|
||||
struct rte_tm_node_capabilities *cap,
|
||||
struct rte_tm_error *error);
|
||||
static int ixgbe_hierarchy_commit(struct rte_eth_dev *dev,
|
||||
int clear_on_fail,
|
||||
struct rte_tm_error *error);
|
||||
|
||||
const struct rte_tm_ops ixgbe_tm_ops = {
|
||||
.capabilities_get = ixgbe_tm_capabilities_get,
|
||||
@ -72,6 +75,7 @@ const struct rte_tm_ops ixgbe_tm_ops = {
|
||||
.node_type_get = ixgbe_node_type_get,
|
||||
.level_capabilities_get = ixgbe_level_capabilities_get,
|
||||
.node_capabilities_get = ixgbe_node_capabilities_get,
|
||||
.hierarchy_commit = ixgbe_hierarchy_commit,
|
||||
};
|
||||
|
||||
int
|
||||
@ -974,3 +978,68 @@ ixgbe_node_capabilities_get(struct rte_eth_dev *dev,
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
ixgbe_hierarchy_commit(struct rte_eth_dev *dev,
|
||||
int clear_on_fail,
|
||||
struct rte_tm_error *error)
|
||||
{
|
||||
struct ixgbe_tm_conf *tm_conf =
|
||||
IXGBE_DEV_PRIVATE_TO_TM_CONF(dev->data->dev_private);
|
||||
struct ixgbe_tm_node *tm_node;
|
||||
uint64_t bw;
|
||||
int ret;
|
||||
|
||||
if (!error)
|
||||
return -EINVAL;
|
||||
|
||||
/* check the setting */
|
||||
if (!tm_conf->root)
|
||||
goto done;
|
||||
|
||||
/* not support port max bandwidth yet */
|
||||
if (tm_conf->root->shaper_profile->profile.peak.rate) {
|
||||
error->type = RTE_TM_ERROR_TYPE_SHAPER_PROFILE;
|
||||
error->message = "no port max bandwidth";
|
||||
goto fail_clear;
|
||||
}
|
||||
|
||||
/* HW not support TC max bandwidth */
|
||||
TAILQ_FOREACH(tm_node, &tm_conf->tc_list, node) {
|
||||
if (tm_node->shaper_profile->profile.peak.rate) {
|
||||
error->type = RTE_TM_ERROR_TYPE_SHAPER_PROFILE;
|
||||
error->message = "no TC max bandwidth";
|
||||
goto fail_clear;
|
||||
}
|
||||
}
|
||||
|
||||
/* queue max bandwidth */
|
||||
TAILQ_FOREACH(tm_node, &tm_conf->queue_list, node) {
|
||||
bw = tm_node->shaper_profile->profile.peak.rate;
|
||||
if (bw) {
|
||||
/* interpret Bps to Mbps */
|
||||
bw = bw * 8 / 1000 / 1000;
|
||||
ret = ixgbe_set_queue_rate_limit(dev, tm_node->no, bw);
|
||||
if (ret) {
|
||||
error->type = RTE_TM_ERROR_TYPE_SHAPER_PROFILE;
|
||||
error->message =
|
||||
"failed to set queue max bandwidth";
|
||||
goto fail_clear;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
goto done;
|
||||
|
||||
done:
|
||||
tm_conf->committed = true;
|
||||
return 0;
|
||||
|
||||
fail_clear:
|
||||
/* clear all the traffic manager configuration */
|
||||
if (clear_on_fail) {
|
||||
ixgbe_tm_conf_uninit(dev);
|
||||
ixgbe_tm_conf_init(dev);
|
||||
}
|
||||
return -EINVAL;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user