Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933685AbaDVSHM (ORCPT ); Tue, 22 Apr 2014 14:07:12 -0400 Received: from terminus.zytor.com ([198.137.202.10]:52666 "EHLO mail.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933214AbaDVSHK (ORCPT ); Tue, 22 Apr 2014 14:07:10 -0400 Message-ID: <5356AF9F.4010301@zytor.com> Date: Tue, 22 Apr 2014 11:06:23 -0700 From: "H. Peter Anvin" User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.4.0 MIME-Version: 1.0 To: Brian Gerst , Andrew Lutomirski CC: Linus Torvalds , Borislav Petkov , "H. Peter Anvin" , Linux Kernel Mailing List , Ingo Molnar , Alexander van Heukelum , Konrad Rzeszutek Wilk , Boris Ostrovsky , Arjan van de Ven , Alexandre Julliard , Andi Kleen , Thomas Gleixner Subject: Re: [PATCH] x86-64: espfix for 64-bit mode *PROTOTYPE* References: <20140422112312.GB15882@pd.tnic> <20140422144659.GF15882@pd.tnic> <53569467.1030809@zytor.com> <5356A70A.5090907@zytor.com> In-Reply-To: X-Enigmail-Version: 1.6 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/22/2014 11:03 AM, Brian Gerst wrote: > > Maybe make the #GP handler check what the previous stack was at the start: > 1) If we came from userspace, switch to the top of the process stack. > 2) If the previous stack was not the espfix stack, switch back to that stack. > 3) Switch to the top of the process stack (espfix case) > > This leaves the IST available for any recursive faults. > Do you actually know what the IST is? If so, you should realize the above is nonsense. The *hardware* switches stack on an exception; if the vector is set up as an IST, then we *always* switch to the IST stack, unconditionally. If the vector is not, then we switch to the process stack if we came from userspace. That is the entry condition that we have to deal with. The fact that the switch to the IST is unconditional is what makes ISTs hard to deal with. -hpa -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/