]> git.droids-corp.org - dpdk.git/commitdiff
kni: fix build with Linux 5.18
authorJiri Slaby <jslaby@suse.cz>
Wed, 1 Jun 2022 06:53:58 +0000 (08:53 +0200)
committerAndrew Rybchenko <andrew.rybchenko@oktetlabs.ru>
Sun, 5 Jun 2022 08:04:53 +0000 (10:04 +0200)
Since commit 2655926aea9b (net: Remove netif_rx_any_context() and
netif_rx_ni().) in 5.18, netif_rx_ni() no longer exists as netif_rx()
can be called from any context. So define HAVE_NETIF_RX_NI for older
releases and call the appropriate function in kni_net.

netif_rx_ni() must be used on older kernel since netif_rx() might
might lead to deadlocks or other problems there.

Cc: stable@dpdk.org
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Reviewed-by: Andrew Rybchenko <andrew.rybchenko@oktetlabs.ru>
kernel/linux/kni/compat.h
kernel/linux/kni/kni_net.c

index 664785674ff1cc79dbcd8b3ef30d169cd5732d7f..0db29a4a6f618808dd4ac4d552d64417e375cc66 100644 (file)
 #if KERNEL_VERSION(5, 9, 0) > LINUX_VERSION_CODE
 #define HAVE_TSK_IN_GUP
 #endif
+
+#if KERNEL_VERSION(5, 18, 0) > LINUX_VERSION_CODE
+#define HAVE_NETIF_RX_NI
+#endif
index 29e5b9e21f9e88c646b183d881fa98413b65a3c6..a8b092b7567dd687108c2062aafdeb3e011f59af 100644 (file)
@@ -441,7 +441,11 @@ kni_net_rx_normal(struct kni_dev *kni)
                skb->ip_summed = CHECKSUM_UNNECESSARY;
 
                /* Call netif interface */
+#ifdef HAVE_NETIF_RX_NI
                netif_rx_ni(skb);
+#else
+               netif_rx(skb);
+#else
 
                /* Update statistics */
                dev->stats.rx_bytes += len;