const __be32 *match_array = initial_match_array;
        const __be32 *tmp, *imap, *imask, dummy_imask[] = { [0 ... MAX_PHANDLE_ARGS] = ~0 };
        u32 intsize = 1, addrsize, newintsize = 0, newaddrsize = 0;
-       int imaplen, match, i;
+       int imaplen, match, i, rc = -EINVAL;
 
 #ifdef DEBUG
        of_print_phandle_args("of_irq_parse_raw: ", out_irq);
        pr_debug("of_irq_parse_raw: ipar=%s, size=%d\n", of_node_full_name(ipar), intsize);
 
        if (out_irq->args_count != intsize)
-               return -EINVAL;
+               goto fail;
 
        /* Look for this #address-cells. We have to implement the old linux
         * trick of looking for the parent here as some device-trees rely on it
        pr_debug(" -> addrsize=%d\n", addrsize);
 
        /* Range check so that the temporary buffer doesn't overflow */
-       if (WARN_ON(addrsize + intsize > MAX_PHANDLE_ARGS))
+       if (WARN_ON(addrsize + intsize > MAX_PHANDLE_ARGS)) {
+               rc = -EFAULT;
                goto fail;
+       }
 
        /* Precalculate the match array - this simplifies match loop */
        for (i = 0; i < addrsize; i++)
                            newintsize, newaddrsize);
 
                        /* Check for malformed properties */
-                       if (WARN_ON(newaddrsize + newintsize > MAX_PHANDLE_ARGS))
-                               goto fail;
-                       if (imaplen < (newaddrsize + newintsize))
+                       if (WARN_ON(newaddrsize + newintsize > MAX_PHANDLE_ARGS)
+                           || (imaplen < (newaddrsize + newintsize))) {
+                               rc = -EFAULT;
                                goto fail;
+                       }
 
                        imap += newaddrsize + newintsize;
                        imaplen -= newaddrsize + newintsize;
                ipar = newpar;
                newpar = NULL;
        }
+       rc = -ENOENT; /* No interrupt-map found */
+
  fail:
        of_node_put(ipar);
        of_node_put(newpar);
 
-       return -EINVAL;
+       return rc;
 }
 EXPORT_SYMBOL_GPL(of_irq_parse_raw);
 
 
                goto err;
        return 0;
 err:
-       dev_err(&pdev->dev, "of_irq_parse_pci() failed with rc=%d\n", rc);
+       if (rc == -ENOENT) {
+               dev_warn(&pdev->dev,
+                       "%s: no interrupt-map found, INTx interrupts not available\n",
+                       __func__);
+               pr_warn_once("%s: possibly some PCI slots don't have level triggered interrupts capability\n",
+                       __func__);
+       } else {
+               dev_err(&pdev->dev, "%s: failed with rc=%d\n", __func__, rc);
+       }
        return rc;
 }
 EXPORT_SYMBOL_GPL(of_irq_parse_pci);