Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2802584ybl; Mon, 19 Aug 2019 07:44:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqzTx0tAlWjMtSRLIMLrMgJ2XnTXrF6CeybHwU4QUyjWuOmjGKvNDok4C//YRRYXiwJFv/pL X-Received: by 2002:aa7:9516:: with SMTP id b22mr24296389pfp.106.1566225880613; Mon, 19 Aug 2019 07:44:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566225880; cv=none; d=google.com; s=arc-20160816; b=VpE425w/8jfDDpw9rl55EeBFQ4VqZLnqKR7KrFilQVAAD58LwJQnUI51yCqRsGnNNs 0fXyddSrMPmj4/Rt1ch8vUkBeTEtedPv/+zoFas2oGNQMXxi6SFFqrn6SifyIZHz9VjZ eMdJ0CmF3tm9mGPJQbXqTkOHs0An8I1AzViaJNWJjgR//M3A6XdJmTbd3ZCdHWTaE+AQ 3I4z4U7B0QBdMvRDjRSQUT92Usa7rqCuGcRt/UMaa33wyzSVU3hFdUwmXGmnfuRqX1jA 8vmo1fzQ+MSFl4gis48fbccRFmHEDnj+Y+NG9o++jXxAvmlOXQkFBM0OhSZ+ZMKB5gqU SZvQ== 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; bh=Vy5qJGgg/EWAtVC39C9kZNd1jY+63gY/oCqRox6uDxE=; b=qbaEVdiQgN1aWw3JC9v6MXL2lqiJlDA8TNNe+NyOYC3x6XXSIoZL91b/1FrtUH31Dv hXH/cUlENssdJ7Gna/yxOXor2lK47e0MZ1rX0Ou8NzbpqS0sQ93GiT09KqMxuy0yyFMW yfKdRWNCZyrKiHmJWNXOqEfw2whmPRYSLc1E+EaL4uY6D7SGafGFIhTtHkF2MzaSkeVh G0BV/10exc+n17ooHeKHNWcbxf2jjc840HyOdhautxbHMV/3w3fsfhBNcmMaIis/nnJm ehDiXrT0MPZXWi77gr9ET/EvtIV4eMaoFk+ILapfuoCZTI1z2ZzNwUsYY0f352qUOajW +N4Q== 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 b68si165425plb.353.2019.08.19.07.44.25; Mon, 19 Aug 2019 07:44:40 -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 S1726949AbfHSOnb (ORCPT + 99 others); Mon, 19 Aug 2019 10:43:31 -0400 Received: from mx1.redhat.com ([209.132.183.28]:18142 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726627AbfHSOnb (ORCPT ); Mon, 19 Aug 2019 10:43:31 -0400 Received: from mail-wm1-f70.google.com (mail-wm1-f70.google.com [209.85.128.70]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id D7F18C05AA58 for ; Mon, 19 Aug 2019 14:43:30 +0000 (UTC) Received: by mail-wm1-f70.google.com with SMTP id n13so312292wmi.4 for ; Mon, 19 Aug 2019 07:43:30 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=Vy5qJGgg/EWAtVC39C9kZNd1jY+63gY/oCqRox6uDxE=; b=KPxLRI0nh4M7LUHzir23ljmCQAbp9cevw7rwvrHSqJIKd8/VqcqnWfL8qIFw3LgTIm LXc328NhgepbgT8cSeUbSm3/Gfsl41vQDhkSfaHB5Fn+X0UBqF8r1eP1UhhgU6hVCyMo qh4PwPlLJss9rDq15yxHY4iSF7oYGFi3hceVVmgtjZsXtgeaxRXot7Q+PkU9VlhLWo0W acESE8dsTaDGQNapv/rXGNj9dirTaCRgh7LaEnxoao1i9cR7OF64AWS5ECRU3otrM0M0 LwQ/fdFKw4dkBe7FlXL+f7ZcMV9RUrVYIG4ePY3mTXdDNTeB+ravNO5qNN5EP2xopbky Ghow== X-Gm-Message-State: APjAAAWbtG4U4sYPXFXmwWDWUXH1Htk9hozOOOnhnXXYsJ5vbGEUBLIY CCfmQugHYgM0bqs/hSftGGt5BF4jj0YXYzMg2Oj+urAqc7aSevpJrLycmBo5Ihhd+4fg2usHHef PAesoSIu+h7Bag+6gvzRZ4GSM X-Received: by 2002:adf:fc51:: with SMTP id e17mr27848060wrs.348.1566225809326; Mon, 19 Aug 2019 07:43:29 -0700 (PDT) X-Received: by 2002:adf:fc51:: with SMTP id e17mr27848027wrs.348.1566225809018; Mon, 19 Aug 2019 07:43:29 -0700 (PDT) Received: from ?IPv6:2001:b07:6468:f312:8033:56b6:f047:ba4f? ([2001:b07:6468:f312:8033:56b6:f047:ba4f]) by smtp.gmail.com with ESMTPSA id s19sm16503316wrb.94.2019.08.19.07.43.28 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 19 Aug 2019 07:43:28 -0700 (PDT) Subject: Re: [PATCH RESEND v4 7/9] KVM: VMX: Handle SPP induced vmexit and page fault To: Yang Weijiang , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, sean.j.christopherson@intel.com Cc: mst@redhat.com, rkrcmar@redhat.com, jmattson@google.com, yu.c.zhang@intel.com, alazar@bitdefender.com References: <20190814070403.6588-1-weijiang.yang@intel.com> <20190814070403.6588-8-weijiang.yang@intel.com> From: Paolo Bonzini Message-ID: <5f6ba406-17c4-a552-2352-2ff50569aac0@redhat.com> Date: Mon, 19 Aug 2019 16:43:32 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20190814070403.6588-8-weijiang.yang@intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 14/08/19 09:04, Yang Weijiang wrote: > + /* > + * Record write protect fault caused by > + * Sub-page Protection, let VMI decide > + * the next step. > + */ > + if (spte & PT_SPP_MASK) { Should this be "if (spte & PT_WRITABLE_MASK)" instead? That is, if the page is already writable, the fault must be an SPP fault. Paolo > + fault_handled = true; > + vcpu->run->exit_reason = KVM_EXIT_SPP; > + vcpu->run->spp.addr = gva; > + kvm_skip_emulated_instruction(vcpu); > + break; > + } > + > new_spte |= PT_WRITABLE_MASK;