return __irq(bucket);
 }
 
+unsigned int sun4v_build_irq(u32 devhandle, unsigned int devino, int pil, unsigned char flags)
+{
+       struct ino_bucket *bucket;
+       unsigned long sysino;
+
+       sysino = sun4v_devino_to_sysino(devhandle, devino);
+
+       printk(KERN_INFO "sun4v_irq: Mapping ( devh[%08x] devino[%08x] ) "
+              "--> sysino[%016lx]\n", devhandle, devino, sysino);
+
+       bucket = &ivector_table[sysino];
+
+       /* Catch accidental accesses to these things.  IMAP/ICLR handling
+        * is done by hypervisor calls on sun4v platforms, not by direct
+        * register accesses.
+        */
+       bucket->imap = ~0UL;
+       bucket->iclr = ~0UL;
+
+       bucket->pil = pil;
+       bucket->flags = flags;
+
+       bucket->irq_info = kmalloc(sizeof(struct irq_desc), GFP_ATOMIC);
+       if (!bucket->irq_info) {
+               prom_printf("IRQ: Error, kmalloc(irq_desc) failed.\n");
+               prom_halt();
+       }
+       memset(bucket->irq_info, 0, sizeof(struct irq_desc));
+
+       return __irq(bucket);
+}
+
 static void atomic_bucket_insert(struct ino_bucket *bucket)
 {
        unsigned long pstate;
 
 
 static unsigned int pci_sun4v_irq_build(struct pci_pbm_info *pbm,
                                        struct pci_dev *pdev,
-                                       unsigned int ino)
+                                       unsigned int devino)
 {
-       struct ino_bucket *bucket;
-       unsigned long sysino;
        u32 devhandle = pbm->devhandle;
        int pil;
 
-       sysino = sun4v_devino_to_sysino(devhandle, ino);
-
-       printk(KERN_INFO "pci_irq_buld: Mapping ( devh[%08x] ino[%08x] ) "
-              "--> sysino[%016lx]\n", devhandle, ino, sysino);
-
        pil = 4;
        if (pdev) {
                switch ((pdev->class >> 16) & 0xff) {
        }
        BUG_ON(PIL_RESERVED(pil));
 
-       bucket = &ivector_table[sysino];
-
-       /* Catch accidental accesses to these things.  IMAP/ICLR handling
-        * is done by hypervisor calls on sun4v platforms, not by direct
-        * register accesses.
-        */
-       bucket->imap = ~0UL;
-       bucket->iclr = ~0UL;
-
-       bucket->pil = pil;
-       bucket->flags = IBF_PCI;
-
-       bucket->irq_info = kmalloc(sizeof(struct irq_desc), GFP_ATOMIC);
-       if (!bucket->irq_info) {
-               prom_printf("IRQ: Error, kmalloc(irq_desc) failed.\n");
-               prom_halt();
-       }
-       memset(bucket->irq_info, 0, sizeof(struct irq_desc));
-
-       return __irq(bucket);
+       return sun4v_build_irq(devhandle, devino, pil, IBF_PCI);
 }
 
 static void pci_sun4v_base_address_update(struct pci_dev *pdev, int resource)
 
 #define disable_irq_nosync disable_irq
 extern void enable_irq(unsigned int);
 extern unsigned int build_irq(int pil, int inofixup, unsigned long iclr, unsigned long imap);
+extern unsigned int sun4v_build_irq(u32 devhandle, unsigned int devino, int pil, unsigned char flags);
 extern unsigned int sbus_build_irq(void *sbus, unsigned int ino);
 
 static __inline__ void set_softint(unsigned long bits)