Received: by 10.213.65.68 with SMTP id h4csp588961imn; Thu, 22 Mar 2018 04:24:42 -0700 (PDT) X-Google-Smtp-Source: AG47ELuF4/ALg2rdRX7DVNdsIha43fvCa+6Zv65EFJ3v6Fu7G7OchwBgSjuApC4nFRV0FYjpMDcG X-Received: by 2002:a17:902:128c:: with SMTP id g12-v6mr24162117pla.98.1521717882695; Thu, 22 Mar 2018 04:24:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521717882; cv=none; d=google.com; s=arc-20160816; b=x1FL8dyifrTQrOGw3vQ8Pe7g9kOR6T6gM10W+XEtA4MimA0YG2rm9btwREgiyrBJxt pJmXtU0ZO+Z8zdgB17GN9PLoVahqSg/UeiIJs1cC7lr1eEfSnf41kXEgloLQ0EC0amuS 5eWZvLZ2AxoirplX3eNhzn5AmMOfS+m22TDKqiIgx8bF1ZRW5S7elohk5w9e76b9HCPl It1gNiD9e3Lntvgtuhczg6pHSxtxEzf0pT7t/DAfwlWAR/zaU+hSTsEXx1t6o/39c91L h/2wX4KaRUp8wXqp14KbYU36xHofE845qXfyB9KihRYPOm2O9aEE/ZDDTBTwZ5gld2W6 8Msw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=c/wCVx73ZzLMg4qjMaHtTQFid5aAWj+5QpDEF9iMw/U=; b=J1LucAunAad5pRat1F+Kf41czZuutMXDwnBSzkUGbYh21u/nDt9+c5d2O0yv1lOFZn IjJMpNaIae5GWJda23KIO31TKQe8CZKjQMrmNueT86xRyNpkxT455yAa8198KYyKUveL FusIMOEcSykwoKKWIgARtVRumIwUUeeGhmODokdmJ6U1r0Nc2KQuWOyv7GqKabb9MFDd QuXUeUcsdjhb2LK2qpqlFcnZjYjy41P/DD5Y7wZ/Yh1hLKke4l8YcrNCxCp15WJ1EpMq HW+h2T4cqXakzFwTLNwfXMfGKCUGATgD1bIwJksYQXmKCFmQyiZoKlouh09ZDd+ZA7S1 X7Bw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z12si4261264pgc.195.2018.03.22.04.24.26; Thu, 22 Mar 2018 04:24:42 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753382AbeCVKHN (ORCPT + 99 others); Thu, 22 Mar 2018 06:07:13 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:51110 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750982AbeCVKHL (ORCPT ); Thu, 22 Mar 2018 06:07:11 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.rdu2.redhat.com [10.11.54.4]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 1D5CB8190293; Thu, 22 Mar 2018 10:07:11 +0000 (UTC) Received: from [10.36.117.117] (ovpn-117-117.ams2.redhat.com [10.36.117.117]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 11EB62026980; Thu, 22 Mar 2018 10:07:09 +0000 (UTC) Subject: Re: [PATCH] KVM: X86: Fix the decoding of segment overrides in 64bit mode To: Wanpeng Li , linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= References: <1521707651-9375-1-git-send-email-wanpengli@tencent.com> From: Paolo Bonzini Message-ID: Date: Thu, 22 Mar 2018 11:07:08 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <1521707651-9375-1-git-send-email-wanpengli@tencent.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.78 on 10.11.54.4 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Thu, 22 Mar 2018 10:07:11 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Thu, 22 Mar 2018 10:07:11 +0000 (UTC) for IP:'10.11.54.4' DOMAIN:'int-mx04.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'pbonzini@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 22/03/2018 09:34, Wanpeng Li wrote: > From: Wanpeng Li > > Explicit segment overides other than %fs and %gs are documented as ignored by > both Intel and AMD. > > In practice, this means that: > > * Explicit uses of %ss don't actually yield #SS[0] for non-canonical > memory references. > * Explicit uses of %{e,c,d}s don't override %rbp/%rsp-based memory references > to yield #GP[0] for non-canonical memory references. > > Cc: Paolo Bonzini > Cc: Radim Krčmář > Signed-off-by: Wanpeng Li > --- > arch/x86/kvm/emulate.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c > index dd88158..5091255 100644 > --- a/arch/x86/kvm/emulate.c > +++ b/arch/x86/kvm/emulate.c > @@ -5148,8 +5148,10 @@ int x86_decode_insn(struct x86_emulate_ctxt *ctxt, void *insn, int insn_len) > case 0x2e: /* CS override */ > case 0x36: /* SS override */ > case 0x3e: /* DS override */ > - has_seg_override = true; > - ctxt->seg_override = (ctxt->b >> 3) & 3; > + if (mode != X86EMUL_MODE_PROT64) { > + has_seg_override = true; > + ctxt->seg_override = (ctxt->b >> 3) & 3; > + } > break; > case 0x64: /* FS override */ > case 0x65: /* GS override */ > Testcase, please... Paolo