pci: intr_remap: Use irq_data
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / drivers / pci / intr_remapping.c
index 87ec390e10df3f21ff1f7e671e7ef5d553c45e83..cb625298854613171846048eb1775a5b6e401eb8 100644 (file)
@@ -54,45 +54,22 @@ struct irq_2_iommu {
 };
 
 #ifdef CONFIG_GENERIC_HARDIRQS
-static struct irq_2_iommu *get_one_free_irq_2_iommu(int node)
-{
-       struct irq_2_iommu *iommu;
-
-       iommu = kzalloc_node(sizeof(*iommu), GFP_ATOMIC, node);
-       printk(KERN_DEBUG "alloc irq_2_iommu on node %d\n", node);
-
-       return iommu;
-}
-
 static struct irq_2_iommu *irq_2_iommu(unsigned int irq)
 {
-       struct irq_desc *desc;
-
-       desc = irq_to_desc(irq);
-
-       if (WARN_ON_ONCE(!desc))
-               return NULL;
-
-       return desc->irq_2_iommu;
+       return get_irq_iommu(irq);
 }
 
 static struct irq_2_iommu *irq_2_iommu_alloc(unsigned int irq)
 {
-       struct irq_desc *desc;
-       struct irq_2_iommu *irq_iommu;
+       struct irq_data *data = irq_get_irq_data(irq);
 
-       desc = irq_to_desc(irq);
-       if (!desc) {
-               printk(KERN_INFO "can not get irq_desc for %d\n", irq);
-               return NULL;
-       }
-
-       irq_iommu = desc->irq_2_iommu;
-
-       if (!irq_iommu)
-               desc->irq_2_iommu = get_one_free_irq_2_iommu(irq_node(irq));
+       if (WARN_ONCE(data->irq_2_iommu,
+                     KERN_DEBUG "irq_2_iommu!=NULL irq %u\n", irq))
+               return data->irq_2_iommu;
 
-       return desc->irq_2_iommu;
+       data->irq_2_iommu = kzalloc_node(sizeof(*data->irq_2_iommu),
+                                        GFP_ATOMIC, data->node);
+       return data->irq_2_iommu;
 }
 
 static void irq_2_iommu_free(unsigned int irq)