Hi,
I got same result in VMware Workstation environment.
At least in my environment, INTX toggle check is not work with VMware
E1000 Ethernet.
Please try attached patch.

2014-10-17 3:04 GMT+09:00 Raghav K <rghvk at outlook.com>:
> Hey,
> I observe continuous burst of I/O Errors, as indicated below, with the 
> testpmd application with DPDK 1.7.1.This seems to originate from 
> eal_intr_process_interrupts() function. I seemed to have setup the DPDK 
> prerequisites alright.
> Another recent post seemed to suggest moving back to 1.7.0, however I would 
> like to persist with 1.7.1.
> Any help/pointers in resolving this would be greatly appreciated.
> Much thanks,Raghav
> root at sys6-vm6:/home/rghv/dpdk/dpdk-1.7.1/x86_64-native-linuxapp-gcc/app# 
> ./testpmd -c 0xf -n3 -- -i --nb-cores=3 --nb-ports=2
> EAL: Error reading from file descriptor 21: Input/output errorEAL: Error 
> reading from file descriptor 21: Input/output errorEAL: Error reading from 
> file descriptor 21: Input/output errorEAL: Error reading from file descriptor 
> 21: Input/output errorEAL: Error reading from file descriptor 21: 
> Input/output errorEAL: Error reading from file descriptor 21: Input/output 
> errorEAL: Error reading from file descriptor 21: Input/output errorEAL: Error 
> reading from file descriptor 21: Input/output errorEAL: Error reading from 
> file descriptor 21: Input/output errorEAL: Error reading from file descriptor 
> 21: Input/output errorEAL: Error reading from file descriptor 21: 
> Input/output errorEAL: Error reading from file descriptor 21: Input/output 
> errorEAL: Error reading from file descriptor 21: Input/output errorEAL: Error 
> reading from file descriptor 21: Input/output errorEAL: Error reading from 
> file descriptor 21: Input/output errorEAL: Error reading from file descriptor 
> 21: Input/output error
> ----
> root at sys6-vm6:/home/rghv/dpdk/dpdk-1.7.1# ./tools/dpdk_nic_bind.py --status
> Network devices using DPDK-compatible 
> driver============================================0000:02:01.0 '82545EM 
> Gigabit Ethernet Controller (Copper)' drv=igb_uio unused=e10000000:02:02.0 
> '82545EM Gigabit Ethernet Controller (Copper)' drv=igb_uio unused=e1000
> Network devices using kernel 
> driver===================================0000:02:00.0 '82545EM Gigabit 
> Ethernet Controller (Copper)' if=eth0 drv=e1000 unused=igb_uio 
> *Active*0000:02:03.0 '82545EM Gigabit Ethernet Controller (Copper)' if=eth3 
> drv=e1000 unused=igb_uio 0000:02:05.0 '82545EM Gigabit Ethernet Controller 
> (Copper)' if=eth4 drv=e1000 unused=igb_uio 0000:02:06.0 '82545EM Gigabit 
> Ethernet Controller (Copper)' if=eth5 drv=e1000 unused=igb_uio
> Other network devices=====================<none>
-------------- next part --------------
diff --git a/lib/librte_eal/linuxapp/igb_uio/igb_uio.c 
b/lib/librte_eal/linuxapp/igb_uio/igb_uio.c
index d1ca26e..c46a00f 100644
--- a/lib/librte_eal/linuxapp/igb_uio/igb_uio.c
+++ b/lib/librte_eal/linuxapp/igb_uio/igb_uio.c
@@ -505,14 +505,11 @@ igbuio_pci_probe(struct pci_dev *dev, const struct 
pci_device_id *id)
                }
                /* fall back to INTX */
        case RTE_INTR_MODE_LEGACY:
-               if (pci_intx_mask_supported(dev)) {
-                       dev_dbg(&dev->dev, "using INTX");
-                       udev->info.irq_flags = IRQF_SHARED;
-                       udev->info.irq = dev->irq;
-                       udev->mode = RTE_INTR_MODE_LEGACY;
-                       break;
-               }
-               dev_notice(&dev->dev, "PCI INTX mask not supported\n");
+               dev_dbg(&dev->dev, "using INTX");
+               udev->info.irq_flags = IRQF_SHARED;
+               udev->info.irq = dev->irq;
+               udev->mode = RTE_INTR_MODE_LEGACY;
+               break;
                /* fall back to no IRQ */
        case RTE_INTR_MODE_NONE:
                udev->mode = RTE_INTR_MODE_NONE;

Reply via email to