diff options
Diffstat (limited to 'arch/sparc64/kernel/irq.c')
-rw-r--r-- | arch/sparc64/kernel/irq.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/arch/sparc64/kernel/irq.c b/arch/sparc64/kernel/irq.c index dc51bdf853cd..f8f704524ed9 100644 --- a/arch/sparc64/kernel/irq.c +++ b/arch/sparc64/kernel/irq.c | |||
@@ -122,8 +122,6 @@ static void bucket_set_virt_irq(unsigned long bucket_pa, | |||
122 | "i" (ASI_PHYS_USE_EC)); | 122 | "i" (ASI_PHYS_USE_EC)); |
123 | } | 123 | } |
124 | 124 | ||
125 | #define __irq_ino(irq) \ | ||
126 | (((struct ino_bucket *)(irq)) - &ivector_table[0]) | ||
127 | #define __bucket(irq) ((struct ino_bucket *)(irq)) | 125 | #define __bucket(irq) ((struct ino_bucket *)(irq)) |
128 | #define __irq(bucket) ((unsigned long)(bucket)) | 126 | #define __irq(bucket) ((unsigned long)(bucket)) |
129 | 127 | ||
@@ -136,7 +134,9 @@ static struct { | |||
136 | } virt_to_real_irq_table[NR_IRQS]; | 134 | } virt_to_real_irq_table[NR_IRQS]; |
137 | static DEFINE_SPINLOCK(virt_irq_alloc_lock); | 135 | static DEFINE_SPINLOCK(virt_irq_alloc_lock); |
138 | 136 | ||
139 | unsigned char virt_irq_alloc(unsigned long real_irq) | 137 | unsigned char virt_irq_alloc(unsigned long real_irq, |
138 | unsigned int dev_handle, | ||
139 | unsigned int dev_ino) | ||
140 | { | 140 | { |
141 | unsigned long flags; | 141 | unsigned long flags; |
142 | unsigned char ent; | 142 | unsigned char ent; |
@@ -154,6 +154,8 @@ unsigned char virt_irq_alloc(unsigned long real_irq) | |||
154 | ent = 0; | 154 | ent = 0; |
155 | } else { | 155 | } else { |
156 | virt_to_real_irq_table[ent].irq = real_irq; | 156 | virt_to_real_irq_table[ent].irq = real_irq; |
157 | virt_to_real_irq_table[ent].dev_handle = dev_handle; | ||
158 | virt_to_real_irq_table[ent].dev_ino = dev_ino; | ||
157 | } | 159 | } |
158 | 160 | ||
159 | spin_unlock_irqrestore(&virt_irq_alloc_lock, flags); | 161 | spin_unlock_irqrestore(&virt_irq_alloc_lock, flags); |
@@ -554,11 +556,12 @@ static void sun4v_virq_end(unsigned int virt_irq) | |||
554 | 556 | ||
555 | static void run_pre_handler(unsigned int virt_irq) | 557 | static void run_pre_handler(unsigned int virt_irq) |
556 | { | 558 | { |
557 | struct ino_bucket *bucket = virt_irq_to_bucket(virt_irq); | ||
558 | struct irq_handler_data *data = get_irq_chip_data(virt_irq); | 559 | struct irq_handler_data *data = get_irq_chip_data(virt_irq); |
560 | unsigned int ino; | ||
559 | 561 | ||
562 | ino = virt_to_real_irq_table[virt_irq].dev_ino; | ||
560 | if (likely(data->pre_handler)) { | 563 | if (likely(data->pre_handler)) { |
561 | data->pre_handler(__irq_ino(__irq(bucket)), | 564 | data->pre_handler(ino, |
562 | data->pre_handler_arg1, | 565 | data->pre_handler_arg1, |
563 | data->pre_handler_arg2); | 566 | data->pre_handler_arg2); |
564 | } | 567 | } |
@@ -633,7 +636,7 @@ unsigned int build_irq(int inofixup, unsigned long iclr, unsigned long imap) | |||
633 | bucket = &ivector_table[ino]; | 636 | bucket = &ivector_table[ino]; |
634 | virt_irq = bucket_get_virt_irq(__pa(bucket)); | 637 | virt_irq = bucket_get_virt_irq(__pa(bucket)); |
635 | if (!virt_irq) { | 638 | if (!virt_irq) { |
636 | virt_irq = virt_irq_alloc(__irq(bucket)); | 639 | virt_irq = virt_irq_alloc(__irq(bucket), 0, ino); |
637 | bucket_set_virt_irq(__pa(bucket), virt_irq); | 640 | bucket_set_virt_irq(__pa(bucket), virt_irq); |
638 | set_irq_chip(virt_irq, &sun4u_irq); | 641 | set_irq_chip(virt_irq, &sun4u_irq); |
639 | } | 642 | } |
@@ -668,7 +671,7 @@ static unsigned int sun4v_build_common(unsigned long sysino, | |||
668 | bucket = &ivector_table[sysino]; | 671 | bucket = &ivector_table[sysino]; |
669 | virt_irq = bucket_get_virt_irq(__pa(bucket)); | 672 | virt_irq = bucket_get_virt_irq(__pa(bucket)); |
670 | if (!virt_irq) { | 673 | if (!virt_irq) { |
671 | virt_irq = virt_irq_alloc(__irq(bucket)); | 674 | virt_irq = virt_irq_alloc(__irq(bucket), 0, sysino); |
672 | bucket_set_virt_irq(__pa(bucket), virt_irq); | 675 | bucket_set_virt_irq(__pa(bucket), virt_irq); |
673 | set_irq_chip(virt_irq, chip); | 676 | set_irq_chip(virt_irq, chip); |
674 | } | 677 | } |
@@ -716,7 +719,7 @@ unsigned int sun4v_build_virq(u32 devhandle, unsigned int devino) | |||
716 | ((unsigned long) bucket + | 719 | ((unsigned long) bucket + |
717 | sizeof(struct ino_bucket))); | 720 | sizeof(struct ino_bucket))); |
718 | 721 | ||
719 | virt_irq = virt_irq_alloc(__irq(bucket)); | 722 | virt_irq = virt_irq_alloc(__irq(bucket), devhandle, devino); |
720 | bucket_set_virt_irq(__pa(bucket), virt_irq); | 723 | bucket_set_virt_irq(__pa(bucket), virt_irq); |
721 | set_irq_chip(virt_irq, &sun4v_virq); | 724 | set_irq_chip(virt_irq, &sun4v_virq); |
722 | 725 | ||
@@ -741,9 +744,6 @@ unsigned int sun4v_build_virq(u32 devhandle, unsigned int devino) | |||
741 | prom_halt(); | 744 | prom_halt(); |
742 | } | 745 | } |
743 | 746 | ||
744 | virt_to_real_irq_table[virt_irq].dev_handle = devhandle; | ||
745 | virt_to_real_irq_table[virt_irq].dev_ino = devino; | ||
746 | |||
747 | return virt_irq; | 747 | return virt_irq; |
748 | } | 748 | } |
749 | 749 | ||