n Jan 5, 2015 6:08 AM, "Peter Zijlstra" <pet...@infradead.org> wrote: > > On Sun, Jan 04, 2015 at 10:36:19AM -0800, Andy Lutomirski wrote: > > On x86_64, at least, task_pt_regs may be only partially initialized > > in many contexts, so x86_64 should not use it without extra care > > from interrupt context, let alone NMI context. > > > > This will allow x86_64 to override the logic and will supply some > > scratch space to use to make a cleaner copy of user regs. > > Just wondering how bad it would be to fill out the actual pt_regs that > was previously partially initialized?
Bad, for at least two reasons. One is that we don't actually know which regs are initialized. bx, bp, r12 etc are particularly bad in this regard, due to the FORK_LIKE mechanism and similar optimizations. The other is that the uninitialized part of task_pt_regs can be used for something else entirely. If we have a syscall instruction immediately followed by a regular interrupt, then the interrupt's hardware frame will overlap task_pt_regs. (I'm not going to claim that this design is sensible, but it is what it is. IIRC Denys Vlasenko had some patches to partially clean this up.) It would be possible to rework the code to avoid an extra pt_regs copy, but I don't see an obvious way to do it cleanly. --Andy -- 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/