aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/sparc64/kernel/irq.c32
-rw-r--r--arch/sparc64/kernel/pci_sun4v.c30
2 files changed, 34 insertions, 28 deletions
diff --git a/arch/sparc64/kernel/irq.c b/arch/sparc64/kernel/irq.c
index 51f65054bf18..bcc889a53324 100644
--- a/arch/sparc64/kernel/irq.c
+++ b/arch/sparc64/kernel/irq.c
@@ -303,6 +303,38 @@ out:
303 return __irq(bucket); 303 return __irq(bucket);
304} 304}
305 305
306unsigned int sun4v_build_irq(u32 devhandle, unsigned int devino, int pil, unsigned char flags)
307{
308 struct ino_bucket *bucket;
309 unsigned long sysino;
310
311 sysino = sun4v_devino_to_sysino(devhandle, devino);
312
313 printk(KERN_INFO "sun4v_irq: Mapping ( devh[%08x] devino[%08x] ) "
314 "--> sysino[%016lx]\n", devhandle, devino, sysino);
315
316 bucket = &ivector_table[sysino];
317
318 /* Catch accidental accesses to these things. IMAP/ICLR handling
319 * is done by hypervisor calls on sun4v platforms, not by direct
320 * register accesses.
321 */
322 bucket->imap = ~0UL;
323 bucket->iclr = ~0UL;
324
325 bucket->pil = pil;
326 bucket->flags = flags;
327
328 bucket->irq_info = kmalloc(sizeof(struct irq_desc), GFP_ATOMIC);
329 if (!bucket->irq_info) {
330 prom_printf("IRQ: Error, kmalloc(irq_desc) failed.\n");
331 prom_halt();
332 }
333 memset(bucket->irq_info, 0, sizeof(struct irq_desc));
334
335 return __irq(bucket);
336}
337
306static void atomic_bucket_insert(struct ino_bucket *bucket) 338static void atomic_bucket_insert(struct ino_bucket *bucket)
307{ 339{
308 unsigned long pstate; 340 unsigned long pstate;
diff --git a/arch/sparc64/kernel/pci_sun4v.c b/arch/sparc64/kernel/pci_sun4v.c
index 5174346ce35d..b8846b271f96 100644
--- a/arch/sparc64/kernel/pci_sun4v.c
+++ b/arch/sparc64/kernel/pci_sun4v.c
@@ -644,18 +644,11 @@ static void pci_sun4v_scan_bus(struct pci_controller_info *p)
644 644
645static unsigned int pci_sun4v_irq_build(struct pci_pbm_info *pbm, 645static unsigned int pci_sun4v_irq_build(struct pci_pbm_info *pbm,
646 struct pci_dev *pdev, 646 struct pci_dev *pdev,
647 unsigned int ino) 647 unsigned int devino)
648{ 648{
649 struct ino_bucket *bucket;
650 unsigned long sysino;
651 u32 devhandle = pbm->devhandle; 649 u32 devhandle = pbm->devhandle;
652 int pil; 650 int pil;
653 651
654 sysino = sun4v_devino_to_sysino(devhandle, ino);
655
656 printk(KERN_INFO "pci_irq_buld: Mapping ( devh[%08x] ino[%08x] ) "
657 "--> sysino[%016lx]\n", devhandle, ino, sysino);
658
659 pil = 4; 652 pil = 4;
660 if (pdev) { 653 if (pdev) {
661 switch ((pdev->class >> 16) & 0xff) { 654 switch ((pdev->class >> 16) & 0xff) {
@@ -685,26 +678,7 @@ static unsigned int pci_sun4v_irq_build(struct pci_pbm_info *pbm,
685 } 678 }
686 BUG_ON(PIL_RESERVED(pil)); 679 BUG_ON(PIL_RESERVED(pil));
687 680
688 bucket = &ivector_table[sysino]; 681 return sun4v_build_irq(devhandle, devino, pil, IBF_PCI);
689
690 /* Catch accidental accesses to these things. IMAP/ICLR handling
691 * is done by hypervisor calls on sun4v platforms, not by direct
692 * register accesses.
693 */
694 bucket->imap = ~0UL;
695 bucket->iclr = ~0UL;
696
697 bucket->pil = pil;
698 bucket->flags = IBF_PCI;
699
700 bucket->irq_info = kmalloc(sizeof(struct irq_desc), GFP_ATOMIC);
701 if (!bucket->irq_info) {
702 prom_printf("IRQ: Error, kmalloc(irq_desc) failed.\n");
703 prom_halt();
704 }
705 memset(bucket->irq_info, 0, sizeof(struct irq_desc));
706
707 return __irq(bucket);
708} 682}
709 683
710static void pci_sun4v_base_address_update(struct pci_dev *pdev, int resource) 684static void pci_sun4v_base_address_update(struct pci_dev *pdev, int resource)