mirror of https://gitee.com/openkylin/linux.git
x86, io-apic: Move CONFIG_IRQ_REMAP code out of x86 core
Move all the code to either to the header file asm/irq_remapping.h or to drivers/iommu/. Signed-off-by: Joerg Roedel <joro@8bytes.org> Acked-by: Sebastian Andrzej Siewior <sebastian@breakpoint.cc> Reviewed-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
This commit is contained in:
parent
819508d302
commit
9b1b0e42f5
|
@ -127,6 +127,7 @@ struct irq_cfg {
|
||||||
u8 vector;
|
u8 vector;
|
||||||
u8 move_in_progress : 1;
|
u8 move_in_progress : 1;
|
||||||
#ifdef CONFIG_IRQ_REMAP
|
#ifdef CONFIG_IRQ_REMAP
|
||||||
|
u8 remapped : 1;
|
||||||
union {
|
union {
|
||||||
struct irq_2_iommu irq_2_iommu;
|
struct irq_2_iommu irq_2_iommu;
|
||||||
struct irq_2_irte irq_2_irte;
|
struct irq_2_irte irq_2_irte;
|
||||||
|
|
|
@ -144,6 +144,7 @@ extern int timer_through_8259;
|
||||||
(mp_irq_entries && !skip_ioapic_setup && io_apic_irqs)
|
(mp_irq_entries && !skip_ioapic_setup && io_apic_irqs)
|
||||||
|
|
||||||
struct io_apic_irq_attr;
|
struct io_apic_irq_attr;
|
||||||
|
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);
|
void setup_IO_APIC_irq_extra(u32 gsi);
|
||||||
|
@ -152,6 +153,10 @@ extern void ioapic_insert_resources(void);
|
||||||
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 *);
|
||||||
|
extern int native_setup_ioapic_entry(int, struct IO_APIC_route_entry *,
|
||||||
|
unsigned int, int,
|
||||||
|
struct io_apic_irq_attr *);
|
||||||
|
extern void eoi_ioapic_irq(unsigned int irq, struct irq_cfg *cfg);
|
||||||
|
|
||||||
int io_apic_setup_irq_pin_once(unsigned int irq, int node, struct io_apic_irq_attr *attr);
|
int io_apic_setup_irq_pin_once(unsigned int irq, int node, struct io_apic_irq_attr *attr);
|
||||||
|
|
||||||
|
|
|
@ -45,6 +45,13 @@ extern void compose_remapped_msi_msg(struct pci_dev *pdev,
|
||||||
extern int setup_hpet_msi_remapped(unsigned int irq, unsigned int id);
|
extern int setup_hpet_msi_remapped(unsigned int irq, unsigned int id);
|
||||||
extern void panic_if_irq_remap(const char *msg);
|
extern void panic_if_irq_remap(const char *msg);
|
||||||
|
|
||||||
|
static inline bool irq_remapped(struct irq_cfg *cfg)
|
||||||
|
{
|
||||||
|
return (cfg->remapped == 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void irq_remap_modify_chip_defaults(struct irq_chip *chip);
|
||||||
|
|
||||||
#else /* CONFIG_IRQ_REMAP */
|
#else /* CONFIG_IRQ_REMAP */
|
||||||
|
|
||||||
static inline void setup_irq_remapping_ops(void) { }
|
static inline void setup_irq_remapping_ops(void) { }
|
||||||
|
@ -76,6 +83,16 @@ static inline int setup_hpet_msi_remapped(unsigned int irq, unsigned int id)
|
||||||
static inline void panic_if_irq_remap(const char *msg)
|
static inline void panic_if_irq_remap(const char *msg)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline bool irq_remapped(struct irq_cfg *cfg)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void irq_remap_modify_chip_defaults(struct irq_chip *chip)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_IRQ_REMAP */
|
#endif /* CONFIG_IRQ_REMAP */
|
||||||
|
|
||||||
#endif /* __X86_IRQ_REMAPPING_H */
|
#endif /* __X86_IRQ_REMAPPING_H */
|
||||||
|
|
|
@ -68,22 +68,6 @@
|
||||||
#define for_each_irq_pin(entry, head) \
|
#define for_each_irq_pin(entry, head) \
|
||||||
for (entry = head; entry; entry = entry->next)
|
for (entry = head; entry; entry = entry->next)
|
||||||
|
|
||||||
#ifdef CONFIG_IRQ_REMAP
|
|
||||||
static void irq_remap_modify_chip_defaults(struct irq_chip *chip);
|
|
||||||
static inline bool irq_remapped(struct irq_cfg *cfg)
|
|
||||||
{
|
|
||||||
return cfg->irq_2_iommu.iommu != NULL;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
static inline bool irq_remapped(struct irq_cfg *cfg)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
static inline void irq_remap_modify_chip_defaults(struct irq_chip *chip)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Is the SiS APIC rmw bug present ?
|
* Is the SiS APIC rmw bug present ?
|
||||||
* -1 = don't know, 0 = no, 1 = yes
|
* -1 = don't know, 0 = no, 1 = yes
|
||||||
|
@ -606,7 +590,7 @@ static void __eoi_ioapic_pin(int apic, int pin, int vector, struct irq_cfg *cfg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void eoi_ioapic_irq(unsigned int irq, struct irq_cfg *cfg)
|
void eoi_ioapic_irq(unsigned int irq, struct irq_cfg *cfg)
|
||||||
{
|
{
|
||||||
struct irq_pin_list *entry;
|
struct irq_pin_list *entry;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
@ -2542,32 +2526,6 @@ static void ack_apic_level(struct irq_data *data)
|
||||||
ioapic_irqd_unmask(data, cfg, masked);
|
ioapic_irqd_unmask(data, cfg, masked);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_IRQ_REMAP
|
|
||||||
static void ir_ack_apic_edge(struct irq_data *data)
|
|
||||||
{
|
|
||||||
ack_APIC_irq();
|
|
||||||
}
|
|
||||||
|
|
||||||
static void ir_ack_apic_level(struct irq_data *data)
|
|
||||||
{
|
|
||||||
ack_APIC_irq();
|
|
||||||
eoi_ioapic_irq(data->irq, data->chip_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void ir_print_prefix(struct irq_data *data, struct seq_file *p)
|
|
||||||
{
|
|
||||||
seq_printf(p, " IR-%s", data->chip->name);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void irq_remap_modify_chip_defaults(struct irq_chip *chip)
|
|
||||||
{
|
|
||||||
chip->irq_print_chip = ir_print_prefix;
|
|
||||||
chip->irq_ack = ir_ack_apic_edge;
|
|
||||||
chip->irq_eoi = ir_ack_apic_level;
|
|
||||||
chip->irq_set_affinity = x86_io_apic_ops.set_affinity;
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_IRQ_REMAP */
|
|
||||||
|
|
||||||
static struct irq_chip ioapic_chip __read_mostly = {
|
static struct irq_chip ioapic_chip __read_mostly = {
|
||||||
.name = "IO-APIC",
|
.name = "IO-APIC",
|
||||||
.irq_startup = startup_ioapic_irq,
|
.irq_startup = startup_ioapic_irq,
|
||||||
|
|
|
@ -4017,10 +4017,10 @@ static int alloc_irq_index(struct irq_cfg *cfg, u16 devid, int count)
|
||||||
|
|
||||||
index -= count - 1;
|
index -= count - 1;
|
||||||
|
|
||||||
|
cfg->remapped = 1;
|
||||||
irte_info = &cfg->irq_2_iommu;
|
irte_info = &cfg->irq_2_iommu;
|
||||||
irte_info->sub_handle = devid;
|
irte_info->sub_handle = devid;
|
||||||
irte_info->irte_index = index;
|
irte_info->irte_index = index;
|
||||||
irte_info->iommu = (void *)cfg;
|
|
||||||
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -4127,9 +4127,9 @@ static int setup_ioapic_entry(int irq, struct IO_APIC_route_entry *entry,
|
||||||
index = attr->ioapic_pin;
|
index = attr->ioapic_pin;
|
||||||
|
|
||||||
/* Setup IRQ remapping info */
|
/* Setup IRQ remapping info */
|
||||||
|
cfg->remapped = 1;
|
||||||
irte_info->sub_handle = devid;
|
irte_info->sub_handle = devid;
|
||||||
irte_info->irte_index = index;
|
irte_info->irte_index = index;
|
||||||
irte_info->iommu = (void *)cfg;
|
|
||||||
|
|
||||||
/* Setup IRTE for IOMMU */
|
/* Setup IRTE for IOMMU */
|
||||||
irte.val = 0;
|
irte.val = 0;
|
||||||
|
@ -4288,9 +4288,9 @@ static int msi_setup_irq(struct pci_dev *pdev, unsigned int irq,
|
||||||
devid = get_device_id(&pdev->dev);
|
devid = get_device_id(&pdev->dev);
|
||||||
irte_info = &cfg->irq_2_iommu;
|
irte_info = &cfg->irq_2_iommu;
|
||||||
|
|
||||||
|
cfg->remapped = 1;
|
||||||
irte_info->sub_handle = devid;
|
irte_info->sub_handle = devid;
|
||||||
irte_info->irte_index = index + offset;
|
irte_info->irte_index = index + offset;
|
||||||
irte_info->iommu = (void *)cfg;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -4314,9 +4314,9 @@ static int setup_hpet_msi(unsigned int irq, unsigned int id)
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
return index;
|
return index;
|
||||||
|
|
||||||
|
cfg->remapped = 1;
|
||||||
irte_info->sub_handle = devid;
|
irte_info->sub_handle = devid;
|
||||||
irte_info->irte_index = index;
|
irte_info->irte_index = index;
|
||||||
irte_info->iommu = (void *)cfg;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,6 +68,7 @@ static int alloc_irte(struct intel_iommu *iommu, int irq, u16 count)
|
||||||
{
|
{
|
||||||
struct ir_table *table = iommu->ir_table;
|
struct ir_table *table = iommu->ir_table;
|
||||||
struct irq_2_iommu *irq_iommu = irq_2_iommu(irq);
|
struct irq_2_iommu *irq_iommu = irq_2_iommu(irq);
|
||||||
|
struct irq_cfg *cfg = irq_get_chip_data(irq);
|
||||||
u16 index, start_index;
|
u16 index, start_index;
|
||||||
unsigned int mask = 0;
|
unsigned int mask = 0;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
@ -115,6 +116,7 @@ static int alloc_irte(struct intel_iommu *iommu, int irq, u16 count)
|
||||||
for (i = index; i < index + count; i++)
|
for (i = index; i < index + count; i++)
|
||||||
table->base[i].present = 1;
|
table->base[i].present = 1;
|
||||||
|
|
||||||
|
cfg->remapped = 1;
|
||||||
irq_iommu->iommu = iommu;
|
irq_iommu->iommu = iommu;
|
||||||
irq_iommu->irte_index = index;
|
irq_iommu->irte_index = index;
|
||||||
irq_iommu->sub_handle = 0;
|
irq_iommu->sub_handle = 0;
|
||||||
|
@ -155,6 +157,7 @@ static int map_irq_to_irte_handle(int irq, u16 *sub_handle)
|
||||||
static int set_irte_irq(int irq, struct intel_iommu *iommu, u16 index, u16 subhandle)
|
static int set_irte_irq(int irq, struct intel_iommu *iommu, u16 index, u16 subhandle)
|
||||||
{
|
{
|
||||||
struct irq_2_iommu *irq_iommu = irq_2_iommu(irq);
|
struct irq_2_iommu *irq_iommu = irq_2_iommu(irq);
|
||||||
|
struct irq_cfg *cfg = irq_get_chip_data(irq);
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
if (!irq_iommu)
|
if (!irq_iommu)
|
||||||
|
@ -162,6 +165,7 @@ static int set_irte_irq(int irq, struct intel_iommu *iommu, u16 index, u16 subha
|
||||||
|
|
||||||
raw_spin_lock_irqsave(&irq_2_ir_lock, flags);
|
raw_spin_lock_irqsave(&irq_2_ir_lock, flags);
|
||||||
|
|
||||||
|
cfg->remapped = 1;
|
||||||
irq_iommu->iommu = iommu;
|
irq_iommu->iommu = iommu;
|
||||||
irq_iommu->irte_index = index;
|
irq_iommu->irte_index = index;
|
||||||
irq_iommu->sub_handle = subhandle;
|
irq_iommu->sub_handle = subhandle;
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include <linux/seq_file.h>
|
||||||
#include <linux/cpumask.h>
|
#include <linux/cpumask.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
|
@ -327,3 +328,27 @@ void panic_if_irq_remap(const char *msg)
|
||||||
if (irq_remapping_enabled)
|
if (irq_remapping_enabled)
|
||||||
panic(msg);
|
panic(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ir_ack_apic_edge(struct irq_data *data)
|
||||||
|
{
|
||||||
|
ack_APIC_irq();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ir_ack_apic_level(struct irq_data *data)
|
||||||
|
{
|
||||||
|
ack_APIC_irq();
|
||||||
|
eoi_ioapic_irq(data->irq, data->chip_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ir_print_prefix(struct irq_data *data, struct seq_file *p)
|
||||||
|
{
|
||||||
|
seq_printf(p, " IR-%s", data->chip->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void irq_remap_modify_chip_defaults(struct irq_chip *chip)
|
||||||
|
{
|
||||||
|
chip->irq_print_chip = ir_print_prefix;
|
||||||
|
chip->irq_ack = ir_ack_apic_edge;
|
||||||
|
chip->irq_eoi = ir_ack_apic_level;
|
||||||
|
chip->irq_set_affinity = x86_io_apic_ops.set_affinity;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue