From: Paweł Małachowski <pawel.malachow...@atendesoftware.pl> Signed-off-by: Michał Mirosław <michal.miros...@atendesoftware.pl> --- drivers/net/null/rte_eth_null.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-)
diff --git a/drivers/net/null/rte_eth_null.c b/drivers/net/null/rte_eth_null.c index 836d982..c802bc0 100644 --- a/drivers/net/null/rte_eth_null.c +++ b/drivers/net/null/rte_eth_null.c @@ -284,6 +284,9 @@ eth_tx_queue_setup(struct rte_eth_dev *dev, uint16_t tx_queue_id, return 0; } +static void +eth_dev_void_ok(struct rte_eth_dev *dev __rte_unused) { return; } + static void eth_dev_info(struct rte_eth_dev *dev, @@ -304,6 +307,12 @@ eth_dev_info(struct rte_eth_dev *dev, dev_info->pci_dev = NULL; dev_info->reta_size = internals->reta_size; dev_info->flow_type_rss_offloads = internals->flow_type_rss_offloads; + /* We hereby declare we can RX offload VLAN-s out of thin air and update + * checksums and VLANs before sinking packets in /dev/null + */ + dev_info->rx_offload_capa = DEV_RX_OFFLOAD_VLAN_STRIP; + dev_info->tx_offload_capa = DEV_TX_OFFLOAD_VLAN_INSERT | + DEV_TX_OFFLOAD_IPV4_CKSUM; } static void @@ -477,7 +486,12 @@ static const struct eth_dev_ops ops = { .reta_update = eth_rss_reta_update, .reta_query = eth_rss_reta_query, .rss_hash_update = eth_rss_hash_update, - .rss_hash_conf_get = eth_rss_hash_conf_get + .rss_hash_conf_get = eth_rss_hash_conf_get, + /* Fake our capabilities */ + .promiscuous_enable = eth_dev_void_ok, + .promiscuous_disable = eth_dev_void_ok, + .allmulticast_enable = eth_dev_void_ok, + .allmulticast_disable = eth_dev_void_ok }; int -- 2.10.2