An application may want to manipulate the MTU settings of
a device without having to start the device first.
In order to remove the need to start the device the
ixgbe/ixgbevf drivers need to initialize the scattered_rx
value during dev_configure.

Signed-off-by: David Harton <dhar...@cisco.com>
---
 drivers/net/ixgbe/ixgbe_ethdev.c | 14 ++++++++++++++
 1 file changed, 14 insertions(+)

diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c b/drivers/net/ixgbe/ixgbe_ethdev.c
index 22171d8..e85bdb4 100644
--- a/drivers/net/ixgbe/ixgbe_ethdev.c
+++ b/drivers/net/ixgbe/ixgbe_ethdev.c
@@ -2372,6 +2372,13 @@ static int eth_ixgbevf_pci_remove(struct rte_pci_device 
*pci_dev)
        intr->flags |= IXGBE_FLAG_NEED_LINK_UPDATE;
 
        /*
+        * Update scattered_rx so we can update MTU immediately
+        * following configure without having to start the device
+        */
+       if (dev->data->dev_conf.rxmode.enable_scatter)
+               dev->data->scattered_rx = 1;
+
+       /*
         * Initialize to TRUE. If any of Rx queues doesn't meet the bulk
         * allocation or vector Rx preconditions we will reset it.
         */
@@ -4949,6 +4956,13 @@ static int ixgbevf_dev_xstats_get_names(__rte_unused 
struct rte_eth_dev *dev,
 #endif
 
        /*
+        * Update scattered_rx so we can update MTU immediately
+        * following configure without having to start the device
+        */
+       if (dev->data->dev_conf.rxmode.enable_scatter)
+               dev->data->scattered_rx = 1;
+
+       /*
         * Initialize to TRUE. If any of Rx queues doesn't meet the bulk
         * allocation or vector Rx preconditions we will reset it.
         */
-- 
1.8.3.1

Reply via email to