soc: ti: ti_sci_inta_msi: Get rid of ti_sci_inta_msi_get_virq()

Just use the core function msi_get_virq().

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Tested-by: Nishanth Menon <nm@ti.com>
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: Vinod Koul <vkoul@kernel.org>
Acked-by: Nishanth Menon <nm@ti.com>
Link: https://lore.kernel.org/r/20211210221815.269468319@linutronix.de
This commit is contained in:
Thomas Gleixner 2021-12-10 23:19:35 +01:00
parent d86a6d47bc
commit 89e0032ec2
5 changed files with 7 additions and 24 deletions

View File

@ -168,8 +168,7 @@ int xudma_pktdma_tflow_get_irq(struct udma_dev *ud, int udma_tflow_id)
{ {
const struct udma_oes_offsets *oes = &ud->soc_data->oes; const struct udma_oes_offsets *oes = &ud->soc_data->oes;
return ti_sci_inta_msi_get_virq(ud->dev, udma_tflow_id + return msi_get_virq(ud->dev, udma_tflow_id + oes->pktdma_tchan_flow);
oes->pktdma_tchan_flow);
} }
EXPORT_SYMBOL(xudma_pktdma_tflow_get_irq); EXPORT_SYMBOL(xudma_pktdma_tflow_get_irq);
@ -177,7 +176,6 @@ int xudma_pktdma_rflow_get_irq(struct udma_dev *ud, int udma_rflow_id)
{ {
const struct udma_oes_offsets *oes = &ud->soc_data->oes; const struct udma_oes_offsets *oes = &ud->soc_data->oes;
return ti_sci_inta_msi_get_virq(ud->dev, udma_rflow_id + return msi_get_virq(ud->dev, udma_rflow_id + oes->pktdma_rchan_flow);
oes->pktdma_rchan_flow);
} }
EXPORT_SYMBOL(xudma_pktdma_rflow_get_irq); EXPORT_SYMBOL(xudma_pktdma_rflow_get_irq);

View File

@ -2313,8 +2313,7 @@ static int udma_alloc_chan_resources(struct dma_chan *chan)
/* Event from UDMA (TR events) only needed for slave TR mode channels */ /* Event from UDMA (TR events) only needed for slave TR mode channels */
if (is_slave_direction(uc->config.dir) && !uc->config.pkt_mode) { if (is_slave_direction(uc->config.dir) && !uc->config.pkt_mode) {
uc->irq_num_udma = ti_sci_inta_msi_get_virq(ud->dev, uc->irq_num_udma = msi_get_virq(ud->dev, irq_udma_idx);
irq_udma_idx);
if (uc->irq_num_udma <= 0) { if (uc->irq_num_udma <= 0) {
dev_err(ud->dev, "Failed to get udma irq (index: %u)\n", dev_err(ud->dev, "Failed to get udma irq (index: %u)\n",
irq_udma_idx); irq_udma_idx);
@ -2486,7 +2485,7 @@ static int bcdma_alloc_chan_resources(struct dma_chan *chan)
uc->psil_paired = true; uc->psil_paired = true;
} }
uc->irq_num_ring = ti_sci_inta_msi_get_virq(ud->dev, irq_ring_idx); uc->irq_num_ring = msi_get_virq(ud->dev, irq_ring_idx);
if (uc->irq_num_ring <= 0) { if (uc->irq_num_ring <= 0) {
dev_err(ud->dev, "Failed to get ring irq (index: %u)\n", dev_err(ud->dev, "Failed to get ring irq (index: %u)\n",
irq_ring_idx); irq_ring_idx);
@ -2503,8 +2502,7 @@ static int bcdma_alloc_chan_resources(struct dma_chan *chan)
/* Event from BCDMA (TR events) only needed for slave channels */ /* Event from BCDMA (TR events) only needed for slave channels */
if (is_slave_direction(uc->config.dir)) { if (is_slave_direction(uc->config.dir)) {
uc->irq_num_udma = ti_sci_inta_msi_get_virq(ud->dev, uc->irq_num_udma = msi_get_virq(ud->dev, irq_udma_idx);
irq_udma_idx);
if (uc->irq_num_udma <= 0) { if (uc->irq_num_udma <= 0) {
dev_err(ud->dev, "Failed to get bcdma irq (index: %u)\n", dev_err(ud->dev, "Failed to get bcdma irq (index: %u)\n",
irq_udma_idx); irq_udma_idx);
@ -2672,7 +2670,7 @@ static int pktdma_alloc_chan_resources(struct dma_chan *chan)
uc->psil_paired = true; uc->psil_paired = true;
uc->irq_num_ring = ti_sci_inta_msi_get_virq(ud->dev, irq_ring_idx); uc->irq_num_ring = msi_get_virq(ud->dev, irq_ring_idx);
if (uc->irq_num_ring <= 0) { if (uc->irq_num_ring <= 0) {
dev_err(ud->dev, "Failed to get ring irq (index: %u)\n", dev_err(ud->dev, "Failed to get ring irq (index: %u)\n",
irq_ring_idx); irq_ring_idx);

View File

@ -647,7 +647,7 @@ int k3_ringacc_get_ring_irq_num(struct k3_ring *ring)
if (!ring) if (!ring)
return -EINVAL; return -EINVAL;
irq_num = ti_sci_inta_msi_get_virq(ring->parent->dev, ring->ring_id); irq_num = msi_get_virq(ring->parent->dev, ring->ring_id);
if (irq_num <= 0) if (irq_num <= 0)
irq_num = -EINVAL; irq_num = -EINVAL;
return irq_num; return irq_num;

View File

@ -148,15 +148,3 @@ void ti_sci_inta_msi_domain_free_irqs(struct device *dev)
ti_sci_inta_msi_free_descs(dev); ti_sci_inta_msi_free_descs(dev);
} }
EXPORT_SYMBOL_GPL(ti_sci_inta_msi_domain_free_irqs); EXPORT_SYMBOL_GPL(ti_sci_inta_msi_domain_free_irqs);
unsigned int ti_sci_inta_msi_get_virq(struct device *dev, u32 dev_index)
{
struct msi_desc *desc;
for_each_msi_entry(desc, dev)
if (desc->msi_index == dev_index)
return desc->irq;
return -ENODEV;
}
EXPORT_SYMBOL_GPL(ti_sci_inta_msi_get_virq);

View File

@ -18,6 +18,5 @@ struct irq_domain
struct irq_domain *parent); struct irq_domain *parent);
int ti_sci_inta_msi_domain_alloc_irqs(struct device *dev, int ti_sci_inta_msi_domain_alloc_irqs(struct device *dev,
struct ti_sci_resource *res); struct ti_sci_resource *res);
unsigned int ti_sci_inta_msi_get_virq(struct device *dev, u32 index);
void ti_sci_inta_msi_domain_free_irqs(struct device *dev); void ti_sci_inta_msi_domain_free_irqs(struct device *dev);
#endif /* __INCLUDE_LINUX_IRQCHIP_TI_SCI_INTA_H */ #endif /* __INCLUDE_LINUX_IRQCHIP_TI_SCI_INTA_H */