Hi

 

I am using dpd19.11 and having error when trying to use sriov vf of a mlx5 100G card

net_mlx5: Unexpected error in DR drop action support detection

 

The same code work for pf

I am not trying to do filtering on nic, but just to read from the port, 1 rx queue, 1 tx queue

 

 

 

Network devices using kernel driver

===================================

0000:0b:00.0 'MT27800 Family [ConnectX-5 Virtual Function] 1018' if=ens192 drv=mlx5_core unused=igb_uio

0000:13:00.0 'VMXNET3 Ethernet Controller 07b0' if=ens224 drv=vmxnet3 unused=igb_uio *Active*

0000:1b:00.0 'VMXNET3 Ethernet Controller 07b0' if=ens256 drv=vmxnet3 unused=igb_uio *Active*

 

ethtool -i ens192

driver: mlx5_core

version: 5.0-0

firmware-version: 16.29.1016 (HPE0000000009)

expansion-rom-version:

bus-info: 0000:0b:00.0

supports-statistics: yes

supports-test: yes

supports-eeprom-access: no

supports-register-dump: no

supports-priv-flags: yes

 

Here is a part of the initialization code

                struct rte_eth_conf port_conf;

                memset(&port_conf, 0, sizeof(port_conf));

                port_conf.link_speeds = ETH_LINK_SPEED_AUTONEG;

                port_conf.rxmode.mq_mode = (pi_nNumRxQueues > 1 ? ETH_MQ_RX_RSS : ETH_MQ_RX_NONE);

                port_conf.rxmode.max_rx_pkt_len = nMaxPacketLen; //only used with jumbo_frame.   For now, only allow packets which fit in mbufs

                port_conf.rxmode.offloads |= DEV_RX_OFFLOAD_JUMBO_FRAME;          //Jumbo Frame Support enabled

                if(pi_sDriverName != "net_ixgbe_vf")//if not sriov

                                port_conf.rxmode.offloads |= DEV_RX_OFFLOAD_KEEP_CRC;      //Don't strip CRC

                port_conf.rxmode.offloads &= pi_devInfo.rx_offload_capa;  //turn off unsupported offloads

                port_conf.rx_adv_conf.rss_conf.rss_key = NULL; //use default RSS key

                port_conf.rx_adv_conf.rss_conf.rss_hf = (pi_nNumRxQueues > 1) ? GetRSSTypes(pi_sDriverName) : 0;

                port_conf.fdir_conf.mode = RTE_FDIR_MODE_NONE; //flow director off

                port_conf.intr_conf.lsc = bLSC ? 1 : 0; //enable link status change interrupt. Without this

                                                                                                                                           

                int ret = rte_eth_dev_configure(pi_nPort, nRxQueues, nTxQueues, &port_conf);

                if (ret < 0)

                                //failure

               

                //Set MTU - needed for some NICs (at least mlx5 and vmxnet3) to receive jumbo packets

                ret = rte_eth_dev_set_mtu(pi_nPort, nMaxPacketLen);

                if (ret < 0)

                                //failure

               

 

                                struct rte_eth_rxconf rx_conf;

                                memset(&rx_conf, 0, sizeof(rx_conf));

                                rx_conf.rx_thresh.pthresh = DPDK_NIC_RX_PTHRESH; //ring prefetch threshold

                                rx_conf.rx_thresh.hthresh = DPDK_NIC_RX_HTHRESH; //ring host threshold

                                rx_conf.rx_thresh.wthresh = DPDK_NIC_RX_WTHRESH; //ring writeback threshold

                                rx_conf.rx_free_thresh = DPDK_NIC_RX_FREE_THRESH;

                                for(RU32 nQueue = 0; nQueue<pi_nNumRxQueues; nQueue++)

                                {                                             

                                                pool = m_memPools[nPool];

                                                int ret = rte_eth_rx_queue_setup(

                                                                pi_nPort,

                                                                nQueue,

                                                                nRingSize,

                                                                socket,

                                                                &rx_conf,

                                                                pool);

}

 

rte_eth_dev_info info;

memset(&info, 0, sizeof(info));

rte_eth_dev_info_get(pi_nPort, &info);

struct rte_eth_txconf tx_conf;

tx_conf = info.default_txconf;

 

for(RU32 nQueue = 0 ;nQueue < pi_nNumTxQueues; nQueue++)

{

                int ret = rte_eth_tx_queue_setup(

                                pi_nPort,

                                nQueue,

                                nRingSize,

                                socket,

                                &tx_conf);

}

 

                               int ret = rte_eth_dev_start(pi_nPort);