pci_enable_msix_range's return value has a different meaning than what
was previously returned by pci_enable_msix.

"It returns a negative errno if an error occurs. If it succeeds, it
returns the actual number of interrupts allocated and indicates the
successful configuration of MSI-X capability structure with new
allocated MSI-X interrupts."

The following commit introduced pci_enable_msix_range:
dpdk: 9fb3cd2c ("kni: fix ethtool build with kernel 4.11")
http://dpdk.org/dev/patchwork/patch/24076/

Signed-off-by: Andy Roulin <arou...@cumulusnetworks.com>
---
 lib/librte_eal/linuxapp/kni/ethtool/igb/igb_main.c | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/lib/librte_eal/linuxapp/kni/ethtool/igb/igb_main.c 
b/lib/librte_eal/linuxapp/kni/ethtool/igb/igb_main.c
index e0f427a..32ef3b9 100644
--- a/lib/librte_eal/linuxapp/kni/ethtool/igb/igb_main.c
+++ b/lib/librte_eal/linuxapp/kni/ethtool/igb/igb_main.c
@@ -1043,14 +1043,16 @@ static void igb_set_interrupt_capability(struct 
igb_adapter *adapter, bool msix)
 #ifdef HAVE_PCI_ENABLE_MSIX
                        err = pci_enable_msix(pdev,
                                              adapter->msix_entries, numvecs);
+                       if (err == 0)
+                               break;
 #else
                        err = pci_enable_msix_range(pdev,
                                        adapter->msix_entries,
                                        numvecs,
                                        numvecs);
-#endif
-                       if (err == 0)
+                       if (err < 0)
                                break;
+#endif
                }
                /* MSI-X failed, so fall through and try MSI */
                dev_warn(pci_dev_to_dev(pdev), "Failed to initialize MSI-X 
interrupts. "
-- 
2.1.4

Reply via email to