On 04/26/2016 02:40 AM, Nadav Amit wrote:
Resending with fixed formatting (sorry for that): Can someone please explain why it is ok for native_set_pte to assign the PTE without WRITE_ONCE() ?
You should probably ask also x86 maintainers/list. IMHO you might have a point, but I may be missing something.
Isn't it possible for a PTE write to be torn, and the PTE to be prefetched in between (or even used for translation by another core)? I did not encounter this case, but it seems to me possible according to the documentation: Intel SDM 4.10.2.3 "Detail of TLB Use": "The processor may cache translations required for prefetches and for accesses ... that would never actually occur in the executed code path." Documentation/memory-barriers.txt: "The compiler is within its rights to invent stores to a variable". Thanks, Nadav -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>
-- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>