]> git.kernelconcepts.de Git - karo-tx-linux.git/commit
x86/cpa: make sure cpa is safe to call in lazy mmu mode
authorJeremy Fitzhardinge <jeremy@goop.org>
Wed, 11 Feb 2009 17:32:19 +0000 (09:32 -0800)
committerGreg Kroah-Hartman <gregkh@suse.de>
Fri, 20 Feb 2009 22:40:20 +0000 (14:40 -0800)
commit2cf155b300c4839a7238b825c7c5f417e9d7cc68
tree4ba631b5477c493f661cf3686da01e55821c8542
parent76b275c7a993745069e6d7cae8807ff85d1efbc8
x86/cpa: make sure cpa is safe to call in lazy mmu mode

commit 4f06b0436b2ddbd3b67b10e77098a6862787b3eb upstream.

Impact: fix race leading to crash under KVM and Xen

The CPA code may be called while we're in lazy mmu update mode - for
example, when using DEBUG_PAGE_ALLOC and doing a slab allocation
in an interrupt handler which interrupted a lazy mmu update.  In this
case, the in-memory pagetable state may be out of date due to pending
queued updates.  We need to flush any pending updates before inspecting
the page table.  Similarly, we must explicitly flush any modifications
CPA may have made (which comes down to flushing queued operations when
flushing the TLB).

Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Acked-by: Marcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
arch/x86/mm/pageattr.c