On Tue, Apr 22, 2014 at 10:00 AM, Andrew Lutomirski <aml...@gmail.com> wrote: > > My point is that it may be safe to remove the special espfix fixup > from #PF, which is probably the most performance-critical piece here, > aside from iret itself.
Actually, even that is unsafe. Why? The segment table is shared for a process. So you can have one thread doing a load_ldt() that invalidates a segment, while another thread is busy taking a page fault. The segment was valid at page fault time and is saved on the kernel stack, but by the time the page fault returns, it is no longer valid and the iretq will fault. Anyway, if done correctly, this whole espfix should be totally free for normal processes, since it should only trigger if SS is a LDT entry (bit #2 set in the segment descriptor). So the normal fast-path should just have a simple test for that. And if you have a SS that is a descriptor in the LDT, nobody cares about performance any more. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/