Commit 19eadf98 authored by Rusty Russell's avatar Rusty Russell Committed by Linus Torvalds

[PATCH] x86: increase interrupt vector range

Remove the limit of 256 interrupt vectors by changing the value stored in
orig_{e,r}ax to be the complemented interrupt vector.  The orig_{e,r}ax
needs to be < 0 to allow the signal code to distinguish between return from
interrupt and return from syscall.  With this change applied, NR_IRQS can
be > 256.

Xen extends the IRQ numbering space to include room for dynamically
allocated virtual interrupts (in the range 256-511), which requires a more
permissive interface to do_IRQ.
Signed-off-by: default avatarIan Pratt <ian.pratt@xensource.com>
Signed-off-by: default avatarChristian Limpach <Christian.Limpach@cl.cam.ac.uk>
Signed-off-by: default avatarChris Wright <chrisw@sous-sol.org>
Signed-off-by: default avatarRusty Russell <rusty@rustcorp.com.au>
Cc: "Protasevich, Natalie" <Natalie.Protasevich@UNISYS.com>
Cc: Andi Kleen <ak@muc.de>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent bd9e0b74
...@@ -515,7 +515,7 @@ ENTRY(irq_entries_start) ...@@ -515,7 +515,7 @@ ENTRY(irq_entries_start)
.if vector .if vector
CFI_ADJUST_CFA_OFFSET -4 CFI_ADJUST_CFA_OFFSET -4
.endif .endif
1: pushl $vector-256 1: pushl $~(vector)
CFI_ADJUST_CFA_OFFSET 4 CFI_ADJUST_CFA_OFFSET 4
jmp common_interrupt jmp common_interrupt
.data .data
...@@ -535,7 +535,7 @@ common_interrupt: ...@@ -535,7 +535,7 @@ common_interrupt:
#define BUILD_INTERRUPT(name, nr) \ #define BUILD_INTERRUPT(name, nr) \
ENTRY(name) \ ENTRY(name) \
RING0_INT_FRAME; \ RING0_INT_FRAME; \
pushl $nr-256; \ pushl $~(nr); \
CFI_ADJUST_CFA_OFFSET 4; \ CFI_ADJUST_CFA_OFFSET 4; \
SAVE_ALL; \ SAVE_ALL; \
movl %esp,%eax; \ movl %esp,%eax; \
......
...@@ -53,8 +53,8 @@ static union irq_ctx *softirq_ctx[NR_CPUS] __read_mostly; ...@@ -53,8 +53,8 @@ static union irq_ctx *softirq_ctx[NR_CPUS] __read_mostly;
*/ */
fastcall unsigned int do_IRQ(struct pt_regs *regs) fastcall unsigned int do_IRQ(struct pt_regs *regs)
{ {
/* high bits used in ret_from_ code */ /* high bit used in ret_from_ code */
int irq = regs->orig_eax & 0xff; int irq = ~regs->orig_eax;
#ifdef CONFIG_4KSTACKS #ifdef CONFIG_4KSTACKS
union irq_ctx *curctx, *irqctx; union irq_ctx *curctx, *irqctx;
u32 *isp; u32 *isp;
......
...@@ -588,7 +588,7 @@ END(common_interrupt) ...@@ -588,7 +588,7 @@ END(common_interrupt)
*/ */
.macro apicinterrupt num,func .macro apicinterrupt num,func
INTR_FRAME INTR_FRAME
pushq $\num-256 pushq $~(\num)
CFI_ADJUST_CFA_OFFSET 8 CFI_ADJUST_CFA_OFFSET 8
interrupt \func interrupt \func
jmp ret_from_intr jmp ret_from_intr
......
...@@ -115,8 +115,8 @@ int show_interrupts(struct seq_file *p, void *v) ...@@ -115,8 +115,8 @@ int show_interrupts(struct seq_file *p, void *v)
*/ */
asmlinkage unsigned int do_IRQ(struct pt_regs *regs) asmlinkage unsigned int do_IRQ(struct pt_regs *regs)
{ {
/* high bits used in ret_from_ code */ /* high bit used in ret_from_ code */
unsigned irq = regs->orig_rax & 0xff; unsigned irq = ~regs->orig_rax;
exit_idle(); exit_idle();
irq_enter(); irq_enter();
......
...@@ -135,10 +135,10 @@ asmlinkage void smp_invalidate_interrupt(struct pt_regs *regs) ...@@ -135,10 +135,10 @@ asmlinkage void smp_invalidate_interrupt(struct pt_regs *regs)
cpu = smp_processor_id(); cpu = smp_processor_id();
/* /*
* orig_rax contains the interrupt vector - 256. * orig_rax contains the negated interrupt vector.
* Use that to determine where the sender put the data. * Use that to determine where the sender put the data.
*/ */
sender = regs->orig_rax + 256 - INVALIDATE_TLB_VECTOR_START; sender = ~regs->orig_rax - INVALIDATE_TLB_VECTOR_START;
f = &per_cpu(flush_state, sender); f = &per_cpu(flush_state, sender);
if (!cpu_isset(cpu, f->flush_cpumask)) if (!cpu_isset(cpu, f->flush_cpumask))
......
...@@ -124,7 +124,7 @@ asmlinkage void IRQ_NAME(nr); \ ...@@ -124,7 +124,7 @@ asmlinkage void IRQ_NAME(nr); \
__asm__( \ __asm__( \
"\n.p2align\n" \ "\n.p2align\n" \
"IRQ" #nr "_interrupt:\n\t" \ "IRQ" #nr "_interrupt:\n\t" \
"push $" #nr "-256 ; " \ "push $~(" #nr ") ; " \
"jmp common_interrupt"); "jmp common_interrupt");
#if defined(CONFIG_X86_IO_APIC) #if defined(CONFIG_X86_IO_APIC)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment