On Tue, 29 Jan 2008, Andrea Arcangeli wrote: > > It seems to be okay to invalidate range if you hold mmap_sem writably. In > > that case no additional faults can happen that would create new ptes. > > In that place the mmap_sem is taken but in readonly mode. I never rely > on the mmap_sem in the mmu notifier methods. Not invoking the notifier
Well it seems that we have to rely on mmap_sem otherwise concurrent faults can occur. The mmap_sem seems to be acquired for write there. if (!has_write_lock) { up_read(&mm->mmap_sem); down_write(&mm->mmap_sem); has_write_lock = 1; goto retry; } > before releasing the PT lock adds quite some uncertainty on the smp > safety of the spte invalidates, because the pte may be unmapped and > remapped by a minor fault before invalidate_range is invoked, but I > didn't figure out a kernel crashing race yet thanks to the pin we take > through get_user_pages (and only thanks to it). The requirement is > that invalidate_range is invoked after the last ptep_clear_flush or it > leaks pins that's why I had to move it at the end. So "pins" means a reference count right? I still do not get why you have refcount problems. You take a refcount when you export the page through KVM and then drop the refcount in invalidate page right? So you walk through the KVM ptes and drop the refcount for each spte you encounter? -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/