On Fri, Feb 08, 2013 at 11:28:10AM -0800, Yinghai Lu wrote: > Change position only. > > Prepare to update arch_early_irq_init(), it needs call some static functions. ^^-> to > > Signed-off-by: Yinghai Lu <yinghai@xxxxxxxxxx> > Cc: Joerg Roedel <joro@xxxxxxxxxx> > Cc: Konrad Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx> > Cc: Sebastian Andrzej Siewior <sebastian@xxxxxxxxxxxxx> > --- > arch/x86/kernel/apic/io_apic.c | 89 ++++++++++++++++++++-------------------- > 1 file changed, 44 insertions(+), 45 deletions(-) > > diff --git a/arch/x86/kernel/apic/io_apic.c b/arch/x86/kernel/apic/io_apic.c > index 72a1351..deda981 100644 > --- a/arch/x86/kernel/apic/io_apic.c > +++ b/arch/x86/kernel/apic/io_apic.c > @@ -185,51 +185,6 @@ static struct irq_pin_list *alloc_irq_pin_list(int node) > return kzalloc_node(sizeof(struct irq_pin_list), GFP_KERNEL, node); > } > > - > -/* irq_cfg is indexed by the sum of all RTEs in all I/O APICs. */ > -static struct irq_cfg irq_cfgx[NR_IRQS_LEGACY]; > - > -int __init arch_early_irq_init(void) > -{ > - struct irq_cfg *cfg; > - int count, node, i; > - > - if (!legacy_pic->nr_legacy_irqs) > - io_apic_irqs = ~0UL; > - > - for (i = 0; i < nr_ioapics; i++) { > - ioapics[i].saved_registers = > - kzalloc(sizeof(struct IO_APIC_route_entry) * > - ioapics[i].nr_registers, GFP_KERNEL); > - if (!ioapics[i].saved_registers) > - pr_err("IOAPIC %d: suspend/resume impossible!\n", i); > - } > - > - cfg = irq_cfgx; > - count = ARRAY_SIZE(irq_cfgx); > - node = cpu_to_node(0); > - > - /* Make sure the legacy interrupts are marked in the bitmap */ > - irq_reserve_irqs(0, legacy_pic->nr_legacy_irqs); > - > - for (i = 0; i < count; i++) { > - INIT_LIST_HEAD(&cfg[i].irq_2_pin); > - irq_set_chip_data(i, &cfg[i]); > - zalloc_cpumask_var_node(&cfg[i].domain, GFP_KERNEL, node); > - zalloc_cpumask_var_node(&cfg[i].old_domain, GFP_KERNEL, node); > - /* > - * For legacy IRQ's, start with assigning irq0 to irq15 to > - * IRQ0_VECTOR to IRQ15_VECTOR for all cpu's. > - */ > - if (i < legacy_pic->nr_legacy_irqs) { > - cfg[i].vector = IRQ0_VECTOR + i; > - cpumask_setall(cfg[i].domain); > - } > - } > - > - return 0; > -} > - > static struct irq_cfg *irq_cfg(unsigned int irq) > { > return irq_get_chip_data(irq); > @@ -332,6 +287,50 @@ static struct irq_cfg *realloc_irq_and_cfg_at(unsigned int at, int node) > return alloc_irq_and_cfg_at(at, node); > } > > +/* irq_cfg is indexed by the sum of all RTEs in all I/O APICs. */ > +static struct irq_cfg irq_cfgx[NR_IRQS_LEGACY]; > + > +int __init arch_early_irq_init(void) > +{ > + struct irq_cfg *cfg; > + int count, node, i; > + > + if (!legacy_pic->nr_legacy_irqs) > + io_apic_irqs = ~0UL; > + > + for (i = 0; i < nr_ioapics; i++) { > + ioapics[i].saved_registers = > + kzalloc(sizeof(struct IO_APIC_route_entry) * > + ioapics[i].nr_registers, GFP_KERNEL); > + if (!ioapics[i].saved_registers) > + pr_err("IOAPIC %d: suspend/resume impossible!\n", i); > + } > + > + cfg = irq_cfgx; > + count = ARRAY_SIZE(irq_cfgx); > + node = cpu_to_node(0); > + > + /* Make sure the legacy interrupts are marked in the bitmap */ > + irq_reserve_irqs(0, legacy_pic->nr_legacy_irqs); > + > + for (i = 0; i < count; i++) { > + INIT_LIST_HEAD(&cfg[i].irq_2_pin); > + irq_set_chip_data(i, &cfg[i]); > + zalloc_cpumask_var_node(&cfg[i].domain, GFP_KERNEL, node); > + zalloc_cpumask_var_node(&cfg[i].old_domain, GFP_KERNEL, node); > + /* > + * For legacy IRQ's, start with assigning irq0 to irq15 to > + * IRQ0_VECTOR to IRQ15_VECTOR for all cpu's. > + */ > + if (i < legacy_pic->nr_legacy_irqs) { > + cfg[i].vector = IRQ0_VECTOR + i; > + cpumask_setall(cfg[i].domain); > + } > + } > + > + return 0; > +} > + > struct io_apic { > unsigned int index; > unsigned int unused[3]; > -- > 1.7.10.4 > -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html