Commit e019c249 authored by Jiang Liu's avatar Jiang Liu Committed by Thomas Gleixner

genirq: Provide and use __irq_can_set_affinity()

Provide a irq_desc based variant of irq_can_set_affinity() to avoid a
redundant lookup for the core code users.

[ tglx: Split out from combo patch ]
Signed-off-by: default avatarJiang Liu <jiang.liu@linux.intel.com>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent 0dcdbc97
...@@ -115,6 +115,14 @@ EXPORT_SYMBOL(synchronize_irq); ...@@ -115,6 +115,14 @@ EXPORT_SYMBOL(synchronize_irq);
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
cpumask_var_t irq_default_affinity; cpumask_var_t irq_default_affinity;
static int __irq_can_set_affinity(struct irq_desc *desc)
{
if (!desc || !irqd_can_balance(&desc->irq_data) ||
!desc->irq_data.chip || !desc->irq_data.chip->irq_set_affinity)
return 0;
return 1;
}
/** /**
* irq_can_set_affinity - Check if the affinity of a given irq can be set * irq_can_set_affinity - Check if the affinity of a given irq can be set
* @irq: Interrupt to check * @irq: Interrupt to check
...@@ -122,13 +130,7 @@ cpumask_var_t irq_default_affinity; ...@@ -122,13 +130,7 @@ cpumask_var_t irq_default_affinity;
*/ */
int irq_can_set_affinity(unsigned int irq) int irq_can_set_affinity(unsigned int irq)
{ {
struct irq_desc *desc = irq_to_desc(irq); return __irq_can_set_affinity(irq_to_desc(irq));
if (!desc || !irqd_can_balance(&desc->irq_data) ||
!desc->irq_data.chip || !desc->irq_data.chip->irq_set_affinity)
return 0;
return 1;
} }
/** /**
...@@ -366,7 +368,7 @@ setup_affinity(unsigned int irq, struct irq_desc *desc, struct cpumask *mask) ...@@ -366,7 +368,7 @@ setup_affinity(unsigned int irq, struct irq_desc *desc, struct cpumask *mask)
int node = irq_desc_get_node(desc); int node = irq_desc_get_node(desc);
/* Excludes PER_CPU and NO_BALANCE interrupts */ /* Excludes PER_CPU and NO_BALANCE interrupts */
if (!irq_can_set_affinity(irq)) if (!__irq_can_set_affinity(desc))
return 0; return 0;
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment