aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/apic
diff options
context:
space:
mode:
authorFeng Tang <feng.tang@intel.com>2010-12-08 02:18:57 -0500
committerThomas Gleixner <tglx@linutronix.de>2010-12-09 15:52:06 -0500
commit0e3fa13f4ee110de007bca3bf395b77997319fc8 (patch)
tree801ee02881f6619822fae46e7ce52317d14d19d9 /arch/x86/kernel/apic
parent2d8009ba67f9503ceadf9d5a3b5637cee291ea8d (diff)
x86: Further simplify mp_irq info handling
assign_to_mp_irq() is copying the struct mpc_intsrc members one by one. That's silly. Use memcpy() and let the compiler figure it out. Same for the identical function assign_to_mpc_intsrc() mp_irq_mpc_intsrc_cmp() is comparing the struct members one by one, but no caller ever checks the different return codes. Use memcmp() instead. Remove the extra printk in MP_ioapic_info() Signed-off-by: Feng Tang <feng.tang@linux.intel.com> Cc: Yinghai Lu <yinghai@kernel.org> Cc: "Alan Cox <alan@linux.intel.com> Cc: Len Brown <len.brown@intel.com> LKML-Reference: <20101208151857.212f0018@feng-i7> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86/kernel/apic')
-rw-r--r--arch/x86/kernel/apic/io_apic.c37
1 files changed, 2 insertions, 35 deletions
diff --git a/arch/x86/kernel/apic/io_apic.c b/arch/x86/kernel/apic/io_apic.c
index c6b44f78ac14..bb61a552d8c6 100644
--- a/arch/x86/kernel/apic/io_apic.c
+++ b/arch/x86/kernel/apic/io_apic.c
@@ -126,39 +126,6 @@ static int __init parse_noapic(char *str)
126} 126}
127early_param("noapic", parse_noapic); 127early_param("noapic", parse_noapic);
128 128
129static void assign_to_mp_irq(struct mpc_intsrc *m,
130 struct mpc_intsrc *mp_irq)
131{
132 mp_irq->dstapic = m->dstapic;
133 mp_irq->type = m->type;
134 mp_irq->irqtype = m->irqtype;
135 mp_irq->irqflag = m->irqflag;
136 mp_irq->srcbus = m->srcbus;
137 mp_irq->srcbusirq = m->srcbusirq;
138 mp_irq->dstirq = m->dstirq;
139}
140
141static int mp_irq_mpc_intsrc_cmp(struct mpc_intsrc *mp_irq,
142 struct mpc_intsrc *m)
143{
144 if (mp_irq->dstapic != m->dstapic)
145 return 1;
146 if (mp_irq->type != m->type)
147 return 2;
148 if (mp_irq->irqtype != m->irqtype)
149 return 3;
150 if (mp_irq->irqflag != m->irqflag)
151 return 4;
152 if (mp_irq->srcbus != m->srcbus)
153 return 5;
154 if (mp_irq->srcbusirq != m->srcbusirq)
155 return 6;
156 if (mp_irq->dstirq != m->dstirq)
157 return 7;
158
159 return 0;
160}
161
162/* Will be called in mpparse/acpi/sfi codes for saving IRQ info */ 129/* Will be called in mpparse/acpi/sfi codes for saving IRQ info */
163void mp_save_irq(struct mpc_intsrc *m) 130void mp_save_irq(struct mpc_intsrc *m)
164{ 131{
@@ -170,11 +137,11 @@ void mp_save_irq(struct mpc_intsrc *m)
170 m->srcbusirq, m->dstapic, m->dstirq); 137 m->srcbusirq, m->dstapic, m->dstirq);
171 138
172 for (i = 0; i < mp_irq_entries; i++) { 139 for (i = 0; i < mp_irq_entries; i++) {
173 if (!mp_irq_mpc_intsrc_cmp(&mp_irqs[i], m)) 140 if (!memcmp(&mp_irqs[i], m, sizeof(*m)))
174 return; 141 return;
175 } 142 }
176 143
177 assign_to_mp_irq(m, &mp_irqs[mp_irq_entries]); 144 memcpy(&mp_irqs[mp_irq_entries], m, sizeof(*m));
178 if (++mp_irq_entries == MAX_IRQ_SOURCES) 145 if (++mp_irq_entries == MAX_IRQ_SOURCES)
179 panic("Max # of irq sources exceeded!!\n"); 146 panic("Max # of irq sources exceeded!!\n");
180} 147}