• Suresh Siddha's avatar
    [PATCH] mm: fix a race condition under SMC + COW · f7bc3d8e
    Suresh Siddha authored
    Failing context is a multi threaded process context and the failing
    sequence is as follows.
    
    One thread T0 doing self modifying code on page X on processor P0 and
    another thread T1 doing COW (breaking the COW setup as part of just
    happened fork() in another thread T2) on the same page X on processor P1.
    T0 doing SMC can endup modifying the new page Y (allocated by the T1 doing
    COW on P1) but because of different I/D TLB's, P0 ITLB will not see the new
    mapping till the flush TLB IPI from P1 is received.  During this interval,
    if T0 executes the code created by SMC it can result in an app error (as
    ITLB still points to old page X and endup executing the content in page X
    rather than using the content in page Y).
    
    Fix this issue by first clearing the PTE and flushing it, before updating
    it with new entry.
    
    Hugh sayeth:
    
      I was a bit sceptical, in the habit of thinking that Self Modifying Code
      must look such issues itself: but I guess there's nothing it can do to avoid
      this one.
    
      Fair enough, what you're changing it to is pretty much what powerpc and
      s390 were already doing, and is a more robust way of proceeding, consistent
      with how ptes are set everywhere else.
    
      The ptep_clear_flush is a bit heavy-handed (it's anxious to return the pte
      that was atomically cleared), but we'd have to wander through lots of arches
      to get the right minimal behaviour.  It'd also be nice to eliminate
      ptep_establish completely, now only used to define other macros/inlines: it
      always seemed obfuscation to me, what you've got there now is clearer.
      Let's put those cleanups on a TODO list.
    Signed-off-by: default avatarSuresh Siddha <suresh.b.siddha@intel.com>
    Acked-by: default avatar"David S. Miller" <davem@davemloft.net>
    Acked-by: default avatarHugh Dickins <hugh@veritas.com>
    Cc: Nick Piggin <nickpiggin@yahoo.com.au>
    Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
    Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
    Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
    Signed-off-by: default avatarChris Wright <chrisw@sous-sol.org>
    f7bc3d8e
memory.c 67 KB