diff options
author | David S. Miller <davem@davemloft.net> | 2006-06-20 04:23:32 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2006-06-20 04:23:32 -0400 |
commit | e18e2a00efc8352c131eb8d5a460149fb5776f1c (patch) | |
tree | bee6e965d77f4289c37300714d7976c3e19f2994 /arch/sparc64/kernel/pci_schizo.c | |
parent | 8047e247c899f80c33a23ad7e9e250224f0d26a5 (diff) |
[SPARC64]: Move over to GENERIC_HARDIRQS.
This is the long overdue conversion of sparc64 over to
the generic IRQ layer.
The kernel image is slightly larger, but the BSS is ~60K
smaller due to the reduced size of struct ino_bucket.
A lot of IRQ implementation details, including ino_bucket,
were moved out of asm-sparc64/irq.h and are now private to
arch/sparc64/kernel/irq.c, and most of the code in irq.c
totally disappeared.
One thing that's different at the moment is IRQ distribution,
we do it at enable_irq() time. If the cpu mask is ALL then
we round-robin using a global rotating cpu counter, else
we pick the first cpu in the mask to support single cpu
targetting. This is similar to what powerpc's XICS IRQ
support code does.
This works fine on my UP SB1000, and the SMP build goes
fine and runs on that machine, but lots of testing on
different setups is needed.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc64/kernel/pci_schizo.c')
-rw-r--r-- | arch/sparc64/kernel/pci_schizo.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/arch/sparc64/kernel/pci_schizo.c b/arch/sparc64/kernel/pci_schizo.c index 0c400b5fa5bd..cc662e915d32 100644 --- a/arch/sparc64/kernel/pci_schizo.c +++ b/arch/sparc64/kernel/pci_schizo.c | |||
@@ -232,10 +232,10 @@ static unsigned long schizo_iclr_offset(unsigned long ino) | |||
232 | return SCHIZO_ICLR_BASE + (ino * 8UL); | 232 | return SCHIZO_ICLR_BASE + (ino * 8UL); |
233 | } | 233 | } |
234 | 234 | ||
235 | static void tomatillo_wsync_handler(struct ino_bucket *bucket, void *_arg1, void *_arg2) | 235 | static void tomatillo_wsync_handler(unsigned int ino, void *_arg1, void *_arg2) |
236 | { | 236 | { |
237 | unsigned long sync_reg = (unsigned long) _arg2; | 237 | unsigned long sync_reg = (unsigned long) _arg2; |
238 | u64 mask = 1UL << (__irq_ino(__irq(bucket)) & IMAP_INO); | 238 | u64 mask = 1UL << (ino & IMAP_INO); |
239 | u64 val; | 239 | u64 val; |
240 | int limit; | 240 | int limit; |
241 | 241 | ||
@@ -313,7 +313,7 @@ static unsigned int schizo_irq_build(struct pci_pbm_info *pbm, | |||
313 | ign_fixup = (1 << 6); | 313 | ign_fixup = (1 << 6); |
314 | } | 314 | } |
315 | 315 | ||
316 | virt_irq = build_irq(ign_fixup, iclr, imap, IBF_PCI); | 316 | virt_irq = build_irq(ign_fixup, iclr, imap); |
317 | 317 | ||
318 | if (pdev && pbm->chip_type == PBM_CHIP_TYPE_TOMATILLO) { | 318 | if (pdev && pbm->chip_type == PBM_CHIP_TYPE_TOMATILLO) { |
319 | irq_install_pre_handler(virt_irq, | 319 | irq_install_pre_handler(virt_irq, |