Lines Matching full:irqs
96 * struct vmd_irq_list - list of driver requested IRQs mapping to a VMD vector
99 * @count: number of child IRQs assigned to this vector; used to track
115 struct vmd_irq_list *irqs; member
131 struct vmd_irq_list *irqs) in index_from_irqs() argument
133 return irqs - vmd->irqs; in index_from_irqs()
137 * Drivers managing a device in a VMD domain allocate their own IRQs as before,
222 return &vmd->irqs[vmd->first_vec]; in vmd_next_irq()
232 return &vmd->irqs[vmd->first_vec]; in vmd_next_irq()
238 if (vmd->irqs[i].count < vmd->irqs[best].count) in vmd_next_irq()
240 vmd->irqs[best].count++; in vmd_next_irq()
243 return &vmd->irqs[best]; in vmd_next_irq()
614 struct vmd_irq_list *irqs = data; in vmd_irq() local
618 idx = srcu_read_lock(&irqs->srcu); in vmd_irq()
619 list_for_each_entry_rcu(vmdirq, &irqs->irq_list, node) in vmd_irq()
621 srcu_read_unlock(&irqs->srcu, idx); in vmd_irq()
640 vmd->irqs = devm_kcalloc(&dev->dev, vmd->msix_count, sizeof(*vmd->irqs), in vmd_alloc_irqs()
642 if (!vmd->irqs) in vmd_alloc_irqs()
646 err = init_srcu_struct(&vmd->irqs[i].srcu); in vmd_alloc_irqs()
650 INIT_LIST_HEAD(&vmd->irqs[i].irq_list); in vmd_alloc_irqs()
653 "vmd", &vmd->irqs[i]); in vmd_alloc_irqs()
869 cleanup_srcu_struct(&vmd->irqs[i].srcu); in vmd_cleanup_srcu()
892 devm_free_irq(dev, pci_irq_vector(pdev, i), &vmd->irqs[i]); in vmd_suspend()
906 "vmd", &vmd->irqs[i]); in vmd_resume()