x86, irq, trivial: Minor improvements of IRQ related code
1) Kill unused MAX_HARDIRQS_PER_CPU. 2) Improve function prototype declararions. 3) Simple typo fix, change "gsit" to "gsi". 4) Use macro VECTOR_UNDEFINED instead of hard-coded -1. 5) Kill redundant comments. Signed-off-by: Jiang Liu <jiang.liu@linux.intel.com> Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> Cc: Tony Luck <tony.luck@intel.com> Cc: Joerg Roedel <joro@8bytes.org> Cc: Paul Gortmaker <paul.gortmaker@windriver.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Grant Likely <grant.likely@linaro.org> Cc: Rafael J. Wysocki <rjw@rjwysocki.net> Cc: Bjorn Helgaas <bhelgaas@google.com> Cc: Randy Dunlap <rdunlap@infradead.org> Cc: Yinghai Lu <yinghai@kernel.org> Cc: Jiri Kosina <trivial@kernel.org> Link: http://lkml.kernel.org/r/1402302011-23642-11-git-send-email-jiang.liu@linux.intel.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
This commit is contained in:
parent
2e0ad0e2c1
commit
3eb2be5f49
3 changed files with 12 additions and 28 deletions
|
@ -40,9 +40,6 @@ typedef struct {
|
||||||
|
|
||||||
DECLARE_PER_CPU_SHARED_ALIGNED(irq_cpustat_t, irq_stat);
|
DECLARE_PER_CPU_SHARED_ALIGNED(irq_cpustat_t, irq_stat);
|
||||||
|
|
||||||
/* We can have at most NR_VECTORS irqs routed to a cpu at a time */
|
|
||||||
#define MAX_HARDIRQS_PER_CPU NR_VECTORS
|
|
||||||
|
|
||||||
#define __ARCH_IRQ_STAT
|
#define __ARCH_IRQ_STAT
|
||||||
|
|
||||||
#define inc_irq_stat(member) this_cpu_inc(irq_stat.member)
|
#define inc_irq_stat(member) this_cpu_inc(irq_stat.member)
|
||||||
|
|
|
@ -144,12 +144,9 @@ struct io_apic_irq_attr;
|
||||||
struct irq_cfg;
|
struct irq_cfg;
|
||||||
extern int io_apic_set_pci_routing(struct device *dev, int irq,
|
extern int io_apic_set_pci_routing(struct device *dev, int irq,
|
||||||
struct io_apic_irq_attr *irq_attr);
|
struct io_apic_irq_attr *irq_attr);
|
||||||
void setup_IO_APIC_irq_extra(u32 gsi);
|
extern void setup_IO_APIC_irq_extra(u32 gsi);
|
||||||
extern void ioapic_insert_resources(void);
|
extern void ioapic_insert_resources(void);
|
||||||
|
|
||||||
extern int native_setup_ioapic_entry(int, struct IO_APIC_route_entry *,
|
|
||||||
unsigned int, int,
|
|
||||||
struct io_apic_irq_attr *);
|
|
||||||
extern int native_setup_ioapic_entry(int, struct IO_APIC_route_entry *,
|
extern int native_setup_ioapic_entry(int, struct IO_APIC_route_entry *,
|
||||||
unsigned int, int,
|
unsigned int, int,
|
||||||
struct io_apic_irq_attr *);
|
struct io_apic_irq_attr *);
|
||||||
|
@ -159,7 +156,8 @@ extern void native_compose_msi_msg(struct pci_dev *pdev,
|
||||||
unsigned int irq, unsigned int dest,
|
unsigned int irq, unsigned int dest,
|
||||||
struct msi_msg *msg, u8 hpet_id);
|
struct msi_msg *msg, u8 hpet_id);
|
||||||
extern void native_eoi_ioapic_pin(int apic, int pin, int vector);
|
extern void native_eoi_ioapic_pin(int apic, int pin, int vector);
|
||||||
int io_apic_setup_irq_pin_once(unsigned int irq, int node, struct io_apic_irq_attr *attr);
|
extern int io_apic_setup_irq_pin_once(unsigned int irq, int node,
|
||||||
|
struct io_apic_irq_attr *attr);
|
||||||
|
|
||||||
extern int save_ioapic_entries(void);
|
extern int save_ioapic_entries(void);
|
||||||
extern void mask_ioapic_entries(void);
|
extern void mask_ioapic_entries(void);
|
||||||
|
@ -172,11 +170,11 @@ struct mp_ioapic_gsi{
|
||||||
u32 gsi_base;
|
u32 gsi_base;
|
||||||
u32 gsi_end;
|
u32 gsi_end;
|
||||||
};
|
};
|
||||||
extern struct mp_ioapic_gsi mp_gsi_routing[];
|
|
||||||
extern u32 gsi_top;
|
extern u32 gsi_top;
|
||||||
int mp_find_ioapic(u32 gsi);
|
|
||||||
int mp_find_ioapic_pin(int ioapic, u32 gsi);
|
extern int mp_find_ioapic(u32 gsi);
|
||||||
void __init mp_register_ioapic(int id, u32 address, u32 gsi_base);
|
extern int mp_find_ioapic_pin(int ioapic, u32 gsi);
|
||||||
|
extern void __init mp_register_ioapic(int id, u32 address, u32 gsi_base);
|
||||||
extern void __init pre_init_apic_IRQ0(void);
|
extern void __init pre_init_apic_IRQ0(void);
|
||||||
|
|
||||||
extern void mp_save_irq(struct mpc_intsrc *m);
|
extern void mp_save_irq(struct mpc_intsrc *m);
|
||||||
|
|
|
@ -1010,7 +1010,7 @@ int IO_APIC_get_PCI_irq_vector(int bus, int slot, int pin,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (!test_bit(lbus, mp_bus_not_pci) &&
|
if (!test_bit(lbus, mp_bus_not_pci) &&
|
||||||
!mp_irqs[i].irqtype &&
|
mp_irqs[i].irqtype == mp_INT &&
|
||||||
(bus == lbus) &&
|
(bus == lbus) &&
|
||||||
(slot == ((mp_irqs[i].srcbusirq >> 2) & 0x1f))) {
|
(slot == ((mp_irqs[i].srcbusirq >> 2) & 0x1f))) {
|
||||||
int irq = pin_2_irq(i, ioapic_idx, mp_irqs[i].dstirq);
|
int irq = pin_2_irq(i, ioapic_idx, mp_irqs[i].dstirq);
|
||||||
|
@ -1359,7 +1359,7 @@ static void __init __io_apic_setup_irqs(unsigned int ioapic_idx)
|
||||||
|
|
||||||
irq = pin_2_irq(idx, ioapic_idx, pin);
|
irq = pin_2_irq(idx, ioapic_idx, pin);
|
||||||
|
|
||||||
if ((ioapic_idx > 0) && (irq > 16))
|
if ((ioapic_idx > 0) && (irq > NR_IRQS_LEGACY))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1388,7 +1388,7 @@ static void __init setup_IO_APIC_irqs(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* for the gsit that is not in first ioapic
|
* for the gsi that is not in first ioapic
|
||||||
* but could not use acpi_register_gsi()
|
* but could not use acpi_register_gsi()
|
||||||
* like some special sci in IBM x3330
|
* like some special sci in IBM x3330
|
||||||
*/
|
*/
|
||||||
|
@ -2225,7 +2225,7 @@ asmlinkage __visible void smp_irq_move_cleanup_interrupt(void)
|
||||||
apic->send_IPI_self(IRQ_MOVE_CLEANUP_VECTOR);
|
apic->send_IPI_self(IRQ_MOVE_CLEANUP_VECTOR);
|
||||||
goto unlock;
|
goto unlock;
|
||||||
}
|
}
|
||||||
__this_cpu_write(vector_irq[vector], -1);
|
__this_cpu_write(vector_irq[vector], VECTOR_UNDEFINED);
|
||||||
unlock:
|
unlock:
|
||||||
raw_spin_unlock(&desc->lock);
|
raw_spin_unlock(&desc->lock);
|
||||||
}
|
}
|
||||||
|
@ -2514,17 +2514,6 @@ static inline void init_IO_APIC_traps(void)
|
||||||
struct irq_cfg *cfg;
|
struct irq_cfg *cfg;
|
||||||
unsigned int irq;
|
unsigned int irq;
|
||||||
|
|
||||||
/*
|
|
||||||
* NOTE! The local APIC isn't very good at handling
|
|
||||||
* multiple interrupts at the same interrupt level.
|
|
||||||
* As the interrupt level is determined by taking the
|
|
||||||
* vector number and shifting that right by 4, we
|
|
||||||
* want to spread these out a bit so that they don't
|
|
||||||
* all fall in the same interrupt level.
|
|
||||||
*
|
|
||||||
* Also, we've got to be careful not to trash gate
|
|
||||||
* 0x80, because int 0x80 is hm, kind of importantish. ;)
|
|
||||||
*/
|
|
||||||
for_each_active_irq(irq) {
|
for_each_active_irq(irq) {
|
||||||
cfg = irq_get_chip_data(irq);
|
cfg = irq_get_chip_data(irq);
|
||||||
if (IO_APIC_IRQ(irq) && cfg && !cfg->vector) {
|
if (IO_APIC_IRQ(irq) && cfg && !cfg->vector) {
|
||||||
|
@ -3550,7 +3539,7 @@ void __init setup_ioapic_dest(void)
|
||||||
continue;
|
continue;
|
||||||
irq = pin_2_irq(irq_entry, ioapic, pin);
|
irq = pin_2_irq(irq_entry, ioapic, pin);
|
||||||
|
|
||||||
if ((ioapic > 0) && (irq > 16))
|
if ((ioapic > 0) && (irq > NR_IRQS_LEGACY))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
idata = irq_get_irq_data(irq);
|
idata = irq_get_irq_data(irq);
|
||||||
|
|
Loading…
Add table
Reference in a new issue