On Mon, Nov 07, 2011 at 01:14:13PM +0000, Mel Gorman wrote: > I'm tending to agree. The number of cases that must be kept in mind > is getting too tricky. Taking the anon_vma lock may be slower but at > the risk of sounding chicken, it's easier to understand. > > > But I think Mel indicated that anon_vma_locking might be > > harmful to JVM SMP performance. > > How severe you expect this to be, Mel ? > > > > I would only expect it to be a problem during garbage collection when > there is a greater likelihood that mremap is heavily used. While it > would have been nice to avoid additional overhead in mremap, I don't > think the JVM GC case on its own is sufficient justification to avoid > taking the anon_vma lock. Adding one liner in the error path and a bugcheck in the *vmap case, doesn't seem the end of the world compared to my previous fix that you acked. I suspect last friday I was probably confused for a little while because I was recovering from some flu I picked up with the cold weather and the confusion around the vmap case which I assumed as safe (not only if no page was faulted in yet) also didn't help. BTW, with regard to those comments about human brain being all weak, well I doubt monkey brain would work better, so in absence of some alien brain which may work better than ours, we should concentrate and handle it :). The ordering constraints isn't going away no matter what we do in mremap, fork has the exact same issue, except it won't require reordering but my patch documents that. NOTE: f we could remove _all_ the ordering dependencies between the vmas pointed by the anon_vma_chains queued in the same_anon_vma list, and all the rmap_walk then I would be more inclined to agree on keeping the simpler way, because then we would stop playing the ordering games all together, but regardless of mremap, we'll be still playing ordering games with fork vs rmap_walk, so we can exploit that to run a bit faster in mremap too, play the same ordering game (though I admit more complex to play the ordering games in mremap as it requires 2 more function calls for the vma_merge case) but not fundamentally different. -- 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/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>