提交 68f9f440 编写于 作者: J Jiang Liu 提交者: Thomas Gleixner

x86/irq: Remove function apic_set_affinity()

Now there's no user of apic_set_affinity(), so remove it.  Also rename
vector_set_affinity() to apic_set_affinity() for consistency.
Signed-off-by: NJiang Liu <jiang.liu@linux.intel.com>
Tested-by: NJoerg Roedel <jroedel@suse.de>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Cc: David Cohen <david.a.cohen@linux.intel.com>
Cc: Sander Eikelenboom <linux@eikelenboom.it>
Cc: David Vrabel <david.vrabel@citrix.com>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Joerg Roedel <joro@8bytes.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Rafael J. Wysocki <rjw@rjwysocki.net>
Cc: Randy Dunlap <rdunlap@infradead.org>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Dimitri Sivanich <sivanich@sgi.com>
Link: http://lkml.kernel.org/r/1428978610-28986-25-git-send-email-jiang.liu@linux.intel.comSigned-off-by: NThomas Gleixner <tglx@linutronix.de>
上级 f970510c
...@@ -198,8 +198,6 @@ static inline void irq_complete_move(struct irq_cfg *c) { } ...@@ -198,8 +198,6 @@ static inline void irq_complete_move(struct irq_cfg *c) { }
#endif #endif
extern void apic_ack_edge(struct irq_data *data); extern void apic_ack_edge(struct irq_data *data);
extern int apic_set_affinity(struct irq_data *data, const struct cpumask *mask,
unsigned int *dest_id);
#else /* CONFIG_X86_LOCAL_APIC */ #else /* CONFIG_X86_LOCAL_APIC */
static inline void lock_vector_lock(void) {} static inline void lock_vector_lock(void) {}
static inline void unlock_vector_lock(void) {} static inline void unlock_vector_lock(void) {}
......
...@@ -463,41 +463,7 @@ void apic_ack_edge(struct irq_data *data) ...@@ -463,41 +463,7 @@ void apic_ack_edge(struct irq_data *data)
ack_APIC_irq(); ack_APIC_irq();
} }
/* static int apic_set_affinity(struct irq_data *irq_data,
* Either sets data->affinity to a valid value, and returns
* ->cpu_mask_to_apicid of that in dest_id, or returns -1 and
* leaves data->affinity untouched.
*/
int apic_set_affinity(struct irq_data *data, const struct cpumask *mask,
unsigned int *dest_id)
{
struct irq_cfg *cfg = irqd_cfg(data);
unsigned int irq = data->irq;
int err;
if (!config_enabled(CONFIG_SMP))
return -EPERM;
if (!cpumask_intersects(mask, cpu_online_mask))
return -EINVAL;
err = assign_irq_vector(irq, cfg, mask);
if (err)
return err;
err = apic->cpu_mask_to_apicid_and(mask, cfg->domain, dest_id);
if (err) {
if (assign_irq_vector(irq, cfg, data->affinity))
pr_err("Failed to recover vector for irq %d\n", irq);
return err;
}
cpumask_copy(data->affinity, mask);
return 0;
}
static int vector_set_affinity(struct irq_data *irq_data,
const struct cpumask *dest, bool force) const struct cpumask *dest, bool force)
{ {
struct irq_cfg *cfg = irq_data->chip_data; struct irq_cfg *cfg = irq_data->chip_data;
...@@ -523,7 +489,7 @@ static int vector_set_affinity(struct irq_data *irq_data, ...@@ -523,7 +489,7 @@ static int vector_set_affinity(struct irq_data *irq_data,
static struct irq_chip lapic_controller = { static struct irq_chip lapic_controller = {
.irq_ack = apic_ack_edge, .irq_ack = apic_ack_edge,
.irq_set_affinity = vector_set_affinity, .irq_set_affinity = apic_set_affinity,
.irq_retrigger = apic_retrigger_irq, .irq_retrigger = apic_retrigger_irq,
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册