|
|
|
|
|
|
|
|
|
|
xen-devel
Re: [Xen-devel] [PATCH] i386 linux: make 32-bit PAE kernel work when bui
On 13 Mar 2006, at 16:40, Jan Beulich wrote:
The compiler isn't required to order the two stores
ptep_get_and_clear_full() in any particular way, and we saw cases
where the upper 32 bits get stored before the lower ones, which causes
the access to fail (page-fault propagated out of
Xen).
Jan,
Isn't this patch needed for native also? Even though this fastpath is
(I think) only called from exit_mmap(), processors may still be running
on those pagetables at that point (e.g., due to lazy switching). So
what if:
1. Compiler causes high to be cleared before low.
2. This causes an invalid PTE (e.g., pointing into an uncacheable I/O
region)
3. A processor speculatively loads the PTE into its TLB
4. A processor speculatively fetches a cacheline from the bogus area
5. You get a bug like the old AMD GART hang, where the CPU writes back
the cache line at an inopportune moment, when it should never have been
cached in the first place.
??
-- Keir
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel
|
<Prev in Thread] |
Current Thread |
[Next in Thread>
|
Re: [Xen-devel] [PATCH] i386 linux: make 32-bit PAE kernel work when built with newer gcc,
Keir Fraser <=
|
|
|
|
|