mailbox: Use irq_update_affinity_hint()
The driver uses irq_set_affinity_hint() to: - Set the affinity_hint which is consumed by the userspace for distributing the interrupts - Enforce affinity As per commit6ac17fe8c1
("mailbox: bcm-flexrm-mailbox: Set IRQ affinity hint for FlexRM ring IRQs") the latter is done to ensure that the FlexRM ring interrupts are evenly spread across all available CPUs. However, since commita0c9259dc4
("irq/matrix: Spread interrupts on allocation") the spreading of interrupts is dynamically performed at the time of allocation. Hence, there is no need for the drivers to enforce their own affinity for the spreading of interrupts. Also, irq_set_affinity_hint() applying the provided cpumask as an affinity for the interrupt is an undocumented side effect. To remove this side effect irq_set_affinity_hint() has been marked as deprecated and new interfaces have been introduced. Hence, replace the irq_set_affinity_hint() with the new interface irq_update_affinity_hint() that only sets the affinity_hint pointer. Signed-off-by: Nitesh Narayan Lal <nitesh@redhat.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Acked-by: Jassi Brar <jaswinder.singh@linaro.org> Link: https://lore.kernel.org/r/20210903152430.244937-11-nitesh@redhat.com
This commit is contained in:
parent
cc493264c0
commit
bf886e1ef1
|
@ -1298,7 +1298,7 @@ static int flexrm_startup(struct mbox_chan *chan)
|
|||
val = (num_online_cpus() < val) ? val / num_online_cpus() : 1;
|
||||
cpumask_set_cpu((ring->num / val) % num_online_cpus(),
|
||||
&ring->irq_aff_hint);
|
||||
ret = irq_set_affinity_hint(ring->irq, &ring->irq_aff_hint);
|
||||
ret = irq_update_affinity_hint(ring->irq, &ring->irq_aff_hint);
|
||||
if (ret) {
|
||||
dev_err(ring->mbox->dev,
|
||||
"failed to set IRQ affinity hint for ring%d\n",
|
||||
|
@ -1425,7 +1425,7 @@ static void flexrm_shutdown(struct mbox_chan *chan)
|
|||
|
||||
/* Release IRQ */
|
||||
if (ring->irq_requested) {
|
||||
irq_set_affinity_hint(ring->irq, NULL);
|
||||
irq_update_affinity_hint(ring->irq, NULL);
|
||||
free_irq(ring->irq, ring);
|
||||
ring->irq_requested = false;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue