X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=drivers%2Fnet%2Fmlx5%2Fmlx5_trigger.c;h=30addd2d1ea56bb6c8519a80485d816a2727047c;hb=cd89f22a1e9770d312cac03c10705d48e5e36b4b;hp=68e00a0b3d9d7cdf252cbb6826ab77c03682dbc1;hpb=5b45c208f808d854c98d75fabeedabb00780fd4f;p=dpdk.git diff --git a/drivers/net/mlx5/mlx5_trigger.c b/drivers/net/mlx5/mlx5_trigger.c index 68e00a0b3d..30addd2d1e 100644 --- a/drivers/net/mlx5/mlx5_trigger.c +++ b/drivers/net/mlx5/mlx5_trigger.c @@ -33,12 +33,14 @@ /* DPDK headers don't like -pedantic. */ #ifdef PEDANTIC -#pragma GCC diagnostic ignored "-pedantic" +#pragma GCC diagnostic ignored "-Wpedantic" #endif #include #include +#include +#include #ifdef PEDANTIC -#pragma GCC diagnostic error "-pedantic" +#pragma GCC diagnostic error "-Wpedantic" #endif #include "mlx5.h" @@ -62,6 +64,9 @@ mlx5_dev_start(struct rte_eth_dev *dev) struct priv *priv = dev->data->dev_private; int err; + if (mlx5_is_secondary()) + return -E_RTE_SECONDARY; + priv_lock(priv); if (priv->started) { priv_unlock(priv); @@ -70,11 +75,7 @@ mlx5_dev_start(struct rte_eth_dev *dev) DEBUG("%p: allocating and configuring hash RX queues", (void *)dev); err = priv_create_hash_rxqs(priv); if (!err) - err = priv_promiscuous_enable(priv); - if (!err) - err = priv_mac_addrs_enable(priv); - if (!err) - err = priv_allmulticast_enable(priv); + err = priv_rehash_flows(priv); if (!err) priv->started = 1; else { @@ -82,11 +83,15 @@ mlx5_dev_start(struct rte_eth_dev *dev) " %s", (void *)priv, strerror(err)); /* Rollback. */ - priv_allmulticast_disable(priv); - priv_promiscuous_disable(priv); + priv_special_flow_disable_all(priv); priv_mac_addrs_disable(priv); priv_destroy_hash_rxqs(priv); } + if (dev->data->dev_conf.fdir_conf.mode != RTE_FDIR_MODE_NONE) + priv_fdir_enable(priv); + priv_dev_interrupt_handler_install(priv, dev); + err = priv_flow_start(priv); + priv_xstats_init(priv); priv_unlock(priv); return -err; } @@ -104,16 +109,21 @@ mlx5_dev_stop(struct rte_eth_dev *dev) { struct priv *priv = dev->data->dev_private; + if (mlx5_is_secondary()) + return; + priv_lock(priv); if (!priv->started) { priv_unlock(priv); return; } DEBUG("%p: cleaning up and destroying hash RX queues", (void *)dev); - priv_allmulticast_disable(priv); - priv_promiscuous_disable(priv); + priv_special_flow_disable_all(priv); priv_mac_addrs_disable(priv); priv_destroy_hash_rxqs(priv); + priv_fdir_disable(priv); + priv_flow_stop(priv); + priv_dev_interrupt_handler_uninstall(priv, dev); priv->started = 0; priv_unlock(priv); }