diff options
author | Jiang Liu <jiang.liu@linux.intel.com> | 2015-04-13 02:11:47 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2015-04-24 09:36:50 -0400 |
commit | 90d84fe95dd6b418383aa0e0e5cace8f1b1e7e30 (patch) | |
tree | 4a7a1264c50e5abdeaf307443dd88d09e55aa13d | |
parent | 68682a2687bf7dbe51309d297757a7ea6a96d312 (diff) |
x86/MSI: Replace msi_update_msg() with irq_chip_compose_msi_msg()
Function irq_chip_compose_msi_msg() can achieve the same goal as
msi_update_msg(), so remove msi_update_msg().
Signed-off-by: Jiang Liu <jiang.liu@linux.intel.com>
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/1428905519-23704-26-git-send-email-jiang.liu@linux.intel.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | arch/x86/kernel/apic/msi.c | 19 |
1 files changed, 2 insertions, 17 deletions
diff --git a/arch/x86/kernel/apic/msi.c b/arch/x86/kernel/apic/msi.c index 87df03ae99ba..5b5ef5bd23f5 100644 --- a/arch/x86/kernel/apic/msi.c +++ b/arch/x86/kernel/apic/msi.c | |||
@@ -53,19 +53,6 @@ static void irq_msi_compose_msg(struct irq_data *data, struct msi_msg *msg) | |||
53 | MSI_DATA_VECTOR(cfg->vector); | 53 | MSI_DATA_VECTOR(cfg->vector); |
54 | } | 54 | } |
55 | 55 | ||
56 | static void msi_update_msg(struct msi_msg *msg, struct irq_data *irq_data) | ||
57 | { | ||
58 | struct irq_cfg *cfg = irqd_cfg(irq_data); | ||
59 | |||
60 | msg->data &= ~MSI_DATA_VECTOR_MASK; | ||
61 | msg->data |= MSI_DATA_VECTOR(cfg->vector); | ||
62 | msg->address_lo &= ~MSI_ADDR_DEST_ID_MASK; | ||
63 | msg->address_lo |= MSI_ADDR_DEST_ID(cfg->dest_apicid); | ||
64 | if (x2apic_enabled()) | ||
65 | msg->address_hi = MSI_ADDR_BASE_HI | | ||
66 | MSI_ADDR_EXT_DEST_ID(cfg->dest_apicid); | ||
67 | } | ||
68 | |||
69 | /* | 56 | /* |
70 | * IRQ Chip for MSI PCI/PCI-X/PCI-Express Devices, | 57 | * IRQ Chip for MSI PCI/PCI-X/PCI-Express Devices, |
71 | * which implement the MSI or MSI-X Capability Structure. | 58 | * which implement the MSI or MSI-X Capability Structure. |
@@ -198,8 +185,7 @@ dmar_msi_set_affinity(struct irq_data *data, const struct cpumask *mask, | |||
198 | 185 | ||
199 | ret = parent->chip->irq_set_affinity(parent, mask, force); | 186 | ret = parent->chip->irq_set_affinity(parent, mask, force); |
200 | if (ret >= 0) { | 187 | if (ret >= 0) { |
201 | dmar_msi_read(data->irq, &msg); | 188 | irq_chip_compose_msi_msg(data, &msg); |
202 | msi_update_msg(&msg, data); | ||
203 | dmar_msi_write(data->irq, &msg); | 189 | dmar_msi_write(data->irq, &msg); |
204 | } | 190 | } |
205 | 191 | ||
@@ -329,8 +315,7 @@ static int hpet_msi_set_affinity(struct irq_data *data, | |||
329 | 315 | ||
330 | ret = parent->chip->irq_set_affinity(parent, mask, force); | 316 | ret = parent->chip->irq_set_affinity(parent, mask, force); |
331 | if (ret >= 0 && ret != IRQ_SET_MASK_OK_DONE) { | 317 | if (ret >= 0 && ret != IRQ_SET_MASK_OK_DONE) { |
332 | hpet_msi_read(data->handler_data, &msg); | 318 | irq_chip_compose_msi_msg(data, &msg); |
333 | msi_update_msg(&msg, data); | ||
334 | hpet_msi_write(data->handler_data, &msg); | 319 | hpet_msi_write(data->handler_data, &msg); |
335 | } | 320 | } |
336 | 321 | ||