On 12/02, Junyu Jiang wrote:
>Enable jumbo frame for VF by configuring DPDK PF.
>
>Signed-off-by: Junyu Jiang <junyux.ji...@intel.com>
>---
> drivers/net/ixgbe/ixgbe_pf.c | 13 +++++++++++++
> 1 file changed, 13 insertions(+)
>
>diff --git a/drivers/net/ixgbe/ixgbe_pf.c b/drivers/net/ixgbe/ixgbe_pf.c
>index d0d85e138..66b856e11 100644
>--- a/drivers/net/ixgbe/ixgbe_pf.c
>+++ b/drivers/net/ixgbe/ixgbe_pf.c
>@@ -544,6 +544,7 @@ ixgbe_set_vf_lpe(struct rte_eth_dev *dev, __rte_unused 
>uint32_t vf, uint32_t *ms
>       struct ixgbe_hw *hw = IXGBE_DEV_PRIVATE_TO_HW(dev->data->dev_private);
>       uint32_t new_mtu = msgbuf[1];
>       uint32_t max_frs;
>+      uint32_t hlreg0;
>       int max_frame = new_mtu + RTE_ETHER_HDR_LEN + RTE_ETHER_CRC_LEN;
> 
>       /* X540 and X550 support jumbo frames in IOV mode */
>@@ -560,6 +561,18 @@ ixgbe_set_vf_lpe(struct rte_eth_dev *dev, __rte_unused 
>uint32_t vf, uint32_t *ms
>       max_frs = (IXGBE_READ_REG(hw, IXGBE_MAXFRS) &
>                  IXGBE_MHADD_MFS_MASK) >> IXGBE_MHADD_MFS_SHIFT;
>       if (max_frs < new_mtu) {
>+              hlreg0 = IXGBE_READ_REG(hw, IXGBE_HLREG0);
>+              if (new_mtu > RTE_ETHER_MAX_LEN) {
>+                      dev->data->dev_conf.rxmode.offloads |=
>+                              DEV_RX_OFFLOAD_JUMBO_FRAME;
>+                      hlreg0 |= IXGBE_HLREG0_JUMBOEN;
>+              } else {
>+                      dev->data->dev_conf.rxmode.offloads &=
>+                              ~DEV_RX_OFFLOAD_JUMBO_FRAME;
>+                      hlreg0 &= ~IXGBE_HLREG0_JUMBOEN;
>+              }
>+              IXGBE_WRITE_REG(hw, IXGBE_HLREG0, hlreg0);
>+
>               max_frs = new_mtu << IXGBE_MHADD_MFS_SHIFT;
>               IXGBE_WRITE_REG(hw, IXGBE_MAXFRS, max_frs);
>       }
>-- 
>2.17.1
>


Applied to dpdk-next-net-intel with wei's ack, Thanks.

Reply via email to