[dpdk-dev] [PATCH v2] net/ixgbe: remove MTU setting limitation when port's stopped

Xing, Beilei beilei.xing at intel.com
Thu Jul 6 05:23:21 CEST 2017



> -----Original Message-----
> From: dev [mailto:dev-bounces at dpdk.org] On Behalf Of Ferruh Yigit
> Sent: Wednesday, July 5, 2017 10:00 PM
> To: Xing, Beilei <beilei.xing at intel.com>; Lu, Wenzhuo
> <wenzhuo.lu at intel.com>
> Cc: dev at dpdk.org
> Subject: Re: [dpdk-dev] [PATCH v2] net/ixgbe: remove MTU setting
> limitation when port's stopped
> 
> On 7/5/2017 3:33 AM, Beilei Xing wrote:
> > Currently, setting MTU will fail if MTU requires the support of
> > scattered packets before scatter is enabled.
> > This patch allows setting this special MTU when device is stopped,
> > cause scatter will be re-configured during starting port.
> >
> > Signed-off-by: Beilei Xing <beilei.xing at intel.com>
> > ---
> > v2 changes:
> >  - change commit log
> >
> >  drivers/net/ixgbe/ixgbe_ethdev.c | 11 +++++++----
> >  1 file changed, 7 insertions(+), 4 deletions(-)
> >
> > diff --git a/drivers/net/ixgbe/ixgbe_ethdev.c
> > b/drivers/net/ixgbe/ixgbe_ethdev.c
> > index fb5574e..ece5d6c 100644
> > --- a/drivers/net/ixgbe/ixgbe_ethdev.c
> > +++ b/drivers/net/ixgbe/ixgbe_ethdev.c
> > @@ -4812,6 +4812,7 @@ ixgbe_dev_mtu_set(struct rte_eth_dev *dev,
> uint16_t mtu)
> >  	struct rte_eth_dev_info dev_info;
> >  	uint32_t frame_size = mtu + ETHER_HDR_LEN + ETHER_CRC_LEN;
> >  	struct rte_eth_rxmode *rx_conf = &dev->data->dev_conf.rxmode;
> > +	struct rte_eth_dev_data *dev_data = dev->data;
> >
> >  	ixgbe_dev_info_get(dev, &dev_info);
> >
> > @@ -4819,13 +4820,15 @@ ixgbe_dev_mtu_set(struct rte_eth_dev *dev,
> uint16_t mtu)
> >  	if ((mtu < ETHER_MIN_MTU) || (frame_size >
> dev_info.max_rx_pktlen))
> >  		return -EINVAL;
> >
> > -	/* refuse mtu that requires the support of scattered packets when
> this
> > -	 * feature has not been enabled before.
> > +	/* If device is started, refuse mtu that requires the support of
> > +	 * scattered packets when this feature has not been enabled before.
> >  	 */
> > -	if (!rx_conf->enable_scatter &&
> > +	if (dev_data->dev_started && !rx_conf->enable_scatter &&
> 
> Should dev->data->scattered_rx be used here?

Agree, I missed this case: if launch testpmd with max_pkt_len bigger than mbuf.
Thanks.

> 
> rx_conf->enable_scatter is configuration value provided by user, but
> dev->data->scattered_rx keeps the actual status of the feature.
> Driver may decide to enable scattered rx even tough configuration didn't
> asked for it, this behavior is what this patch relies on.
> 
> Can you confirm that there is no other case that can prevent enabling
> scattered rx?

I checked that scattered_rx is disabled only when device is stopped.

> Otherwise this patch will let setting MTU bigger than mbuf and if somehow
> scattered rx is not enabled, this may break the Rx path I guess.
> 
> >  	    (frame_size + 2 * IXGBE_VLAN_TAG_SIZE >
> > -	     dev->data->min_rx_buf_size - RTE_PKTMBUF_HEADROOM))
> > +	     dev->data->min_rx_buf_size - RTE_PKTMBUF_HEADROOM)) {
> > +		PMD_INIT_LOG(ERR, "Stop port first.");
> >  		return -EINVAL;
> > +	}
> >
> >  	hw = IXGBE_DEV_PRIVATE_TO_HW(dev->data->dev_private);
> >  	hlreg0 = IXGBE_READ_REG(hw, IXGBE_HLREG0);
> >



More information about the dev mailing list