}
#ifdef XEN
-int request_irq_vector(unsigned int vector,
+int __init request_irq_vector(unsigned int vector,
void (*handler)(int, void *, struct cpu_user_regs *),
unsigned long irqflags, const char * devname, void *dev_id)
{
}
__initcall(irq_ratelimit_init);
-int request_irq(unsigned int irq,
+int __init request_irq(unsigned int irq,
void (*handler)(int, void *, struct cpu_user_regs *),
unsigned long irqflags, const char * devname, void *dev_id)
{
spin_unlock_irqrestore(&iommu->lock, flags);
}
-static int set_iommu_interrupt_handler(struct amd_iommu *iommu)
+static int __init set_iommu_interrupt_handler(struct amd_iommu *iommu)
{
int irq, ret;
.set_affinity = dma_msi_set_affinity,
};
-static int iommu_set_interrupt(struct iommu *iommu)
+static int __init iommu_set_interrupt(struct iommu *iommu)
{
int irq, ret;
struct acpi_drhd_unit *drhd;
struct iommu *iommu;
struct iommu_flush *flush = NULL;
- int irq;
int ret;
unsigned long flags;
struct irq_cfg *cfg;
for_each_drhd_unit ( drhd )
{
iommu = drhd->iommu;
- if ( iommu->irq < 0 )
- {
- irq = iommu_set_interrupt(iommu);
- if ( irq < 0 )
- {
- dprintk(XENLOG_ERR VTDPREFIX, "IOMMU: interrupt setup failed\n");
- return irq;
- }
- iommu->irq = irq;
- }
cfg = irq_cfg(iommu->irq);
dma_msi_set_affinity(iommu->irq, cfg->cpu_mask);
{
struct acpi_drhd_unit *drhd;
struct iommu *iommu;
+ int ret;
if ( list_empty(&acpi_drhd_units) )
return -ENODEV;
if ( iommu_intremap && !ecap_intr_remap(iommu->ecap) )
iommu_intremap = 0;
+
+ ret = iommu_set_interrupt(iommu);
+ if ( ret < 0 )
+ {
+ dprintk(XENLOG_ERR VTDPREFIX, "IOMMU: interrupt setup failed\n");
+ goto error;
+ }
+ iommu->irq = ret;
}
if ( !iommu_qinval && iommu_intremap )
scan_pci_devices();
- if ( init_vtd_hw() )
+ ret = init_vtd_hw();
+ if ( ret )
goto error;
register_keyhandler('V', &dump_iommu_info_keyhandler);
iommu_passthrough = 0;
iommu_qinval = 0;
iommu_intremap = 0;
- return -ENOMEM;
+ return ret;
}
/*