From: Eric W. Biederman <ebiederm@xmission.com>
Date: Fri, 23 Feb 2007 11:23:52 +0000 (-0700)
Subject: [PATCH] x86_64 irq: In __DO_ACTION perform the FINAL action for every entry.
X-Git-Tag: firefly_0821_release~31005
X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=f45bcd7022a46de48cc414e3ea3a5b9b4de318ec;p=firefly-linux-kernel-4.4.55.git

[PATCH] x86_64 irq: In __DO_ACTION perform the FINAL action for every entry.

If we have an irq that comes from multiple io_apic pins the FINAL action
(which is io_apic_sync or nothing) needs to be called for every entry or
else if the two pins come from different io_apics we may not wait until
after the action happens on the io_apic.

Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
---

diff --git a/arch/x86_64/kernel/io_apic.c b/arch/x86_64/kernel/io_apic.c
index 74671defbbe3..52fc19ba2b98 100644
--- a/arch/x86_64/kernel/io_apic.c
+++ b/arch/x86_64/kernel/io_apic.c
@@ -149,11 +149,11 @@ static inline void io_apic_sync(unsigned int apic)
 		reg = io_apic_read(entry->apic, 0x10 + R + pin*2);	\
 		reg ACTION;						\
 		io_apic_modify(entry->apic, reg);			\
+		FINAL;							\
 		if (!entry->next)					\
 			break;						\
 		entry = irq_2_pin + entry->next;			\
 	}								\
-	FINAL;								\
 }
 
 union entry_union {