Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp29842365rwd; Wed, 5 Jul 2023 19:07:10 -0700 (PDT) X-Google-Smtp-Source: APBJJlG86+vqhSaS3nThDan6sALUR3KSlStyDhihtatd7PO+mBmy8ic68p5eZkRJ+Sg2UofHOfxv X-Received: by 2002:a05:6358:27a3:b0:134:c279:c829 with SMTP id l35-20020a05635827a300b00134c279c829mr545601rwb.18.1688609229934; Wed, 05 Jul 2023 19:07:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688609229; cv=none; d=google.com; s=arc-20160816; b=mblgq7QmYYEGzFD37pSg2V+XRFctKcDu0jSSGw0Czfn6gT7lwfsqUS4HBA8Ndbf/+8 bdZCzCkSGXapkZ1k1AeP3NPY6O3PtcDRjcM42keVbfhKEriCbgdLXbKyE97nGB6DqiRO /kGLwxrEv+S1elsnpyxZOioiuRw1o7iJGYkGeVv7nC4DpWmRUWvkQP/VHp56wd+JD1Fz b50fhq95gKKdrkHVnGIuWcagHPVflORLIXioN6kXOnxfoZr28ZOz1j0Uz3M0HeuIJVfR ziOr9XcHPaxSlLNpudj97q4cVbVcRDrkdpnkkTttzLBRIr1WFoHMX4nuQA5jMm9eFpSf mUrQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=1R7giHFFm9lzKa2KFRVnvuXui30YgtW+mLiZpS636v4=; fh=8yXeLIi7OMsMjSMMvlw/YYJRx0eUTCbkmpTgIokzWfw=; b=htvDgwh9a6gB5MExzYBHzYb74qX3L/Wki8lP3IXaKlJIHmqV/Mo/X5bXEG7LOkEwTY tjhm1oQkvxeckEUBAgfjJtcXrkYtgrdwJgcLf+Jg7eII79UQ1UMj06oyCGSJrguQGutY 5fowKCHeglUmmycMtPXcvBK7aQCBqg4+diDdZtQy6AZsb4CqXPy3HIaqqYXdeM5p1s5r AQLhg8O1dhEsXuTXyObjC1nj7wEoAxmdMMIxXRPMPLjO3iApkxyFGiTlPLWndiq4YGng cQpl+JnO7kl4KJDwziX5JcttxeAD5QtdGpoZCrwwAFoLTxNXMFdzCyMFktU7o4fjtcNe zPKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=DVvGohzI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d2-20020a655882000000b0053fe93b2d33si460838pgu.201.2023.07.05.19.06.55; Wed, 05 Jul 2023 19:07:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=DVvGohzI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232446AbjGFBy5 (ORCPT + 99 others); Wed, 5 Jul 2023 21:54:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51530 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232048AbjGFBy4 (ORCPT ); Wed, 5 Jul 2023 21:54:56 -0400 Received: from mail-ot1-x334.google.com (mail-ot1-x334.google.com [IPv6:2607:f8b0:4864:20::334]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 22725E57; Wed, 5 Jul 2023 18:54:53 -0700 (PDT) Received: by mail-ot1-x334.google.com with SMTP id 46e09a7af769-6b71cdb47e1so169604a34.2; Wed, 05 Jul 2023 18:54:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1688608492; x=1691200492; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=1R7giHFFm9lzKa2KFRVnvuXui30YgtW+mLiZpS636v4=; b=DVvGohzInocB2G0CE5BHhj00dNWqGoqrHPqrt2G17lPCsMUYKKsSVbf/v2qs4vd+BH TVAuRlrgj7qFdyc7ySUeR1ptkT6VqY8g0PcTuoGbfj+zpJtxWVA3ExnG9inRg72NB8ya 97PvzrwpvZTE/IpWdnMQdtsBQKUgGylnqxFb0d+ku33oYPoxzLJqPitoAXs7P6qyNyOu WBvlYk74ZsB1GmBvxmmGoVL2B7UDS4BtOjPnsr9uMZp+cLqX2sFGbdLdIRNR0a2Ixofc kvxyXlICSAK6MZrMjNfH4kDVoONsBeKJXmSqNW6LuF2yi5fD78o/J6TRC+FmmtIvuU18 uIdQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688608492; x=1691200492; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=1R7giHFFm9lzKa2KFRVnvuXui30YgtW+mLiZpS636v4=; b=j/MGsMJJLe0Q95Q2o3uKUD632R6UGGASrXKP9myUS+ki8aMAc1BNuLusR/Kwyr17UQ 4Hw4e7V4YjhrmlXZxc1JTadYAF16tRw7gXDH7XdSYw2gt1XmxkYs1vjKy+asRBs5ekZ0 nZGBA6hA2yRcxegkJas0XPy5B6gqLuxJA9cQzlZXd03nyiVfhyyrv32C1SVJGLsebilp dAWhW39uC7pPNPUPHc8xK+8VJE9oKyJ0mPRdSgp1gz0Em9aIqSnlBAoPNYrwmNx5Cp2d MXl5fW8reR7PAMx4GnM9tCu8yUp0TW29RiedLOn/A/zDjOBi5drwMsRGt2EyjTOmxu3i ikcA== X-Gm-Message-State: ABy/qLbNZaao0U/UGORBcYfVTWZTtkU8iSJdhOJeUb/F0S0Anqyr0tAS hAQJ6RuBAhq1D2+LL6qCvMw= X-Received: by 2002:a05:6358:98a2:b0:134:c530:c2fa with SMTP id q34-20020a05635898a200b00134c530c2famr436044rwa.30.1688608491138; Wed, 05 Jul 2023 18:54:51 -0700 (PDT) Received: from localhost ([192.55.54.50]) by smtp.gmail.com with ESMTPSA id e16-20020a17090301d000b001a5fccab02dsm122674plh.177.2023.07.05.18.54.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 05 Jul 2023 18:54:50 -0700 (PDT) Date: Wed, 5 Jul 2023 18:54:49 -0700 From: Isaku Yamahata To: David Stevens Cc: Sean Christopherson , Marc Zyngier , Michael Ellerman , Peter Xu , linux-arm-kernel@lists.infradead.org, kvmarm@lists.linux.dev, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, kvm@vger.kernel.org, isaku.yamahata@gmail.com Subject: Re: [PATCH v7 4/8] KVM: x86/mmu: Migrate to __kvm_follow_pfn Message-ID: <20230706015449.GB3894444@ls.amr.corp.intel.com> References: <20230704075054.3344915-1-stevensd@google.com> <20230704075054.3344915-5-stevensd@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20230704075054.3344915-5-stevensd@google.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 04, 2023 at 04:50:49PM +0900, David Stevens wrote: > From: David Stevens > > Migrate from __gfn_to_pfn_memslot to __kvm_follow_pfn. > > Signed-off-by: David Stevens > --- > arch/x86/kvm/mmu/mmu.c | 35 +++++++++++++++++++++++++---------- > 1 file changed, 25 insertions(+), 10 deletions(-) > > diff --git a/arch/x86/kvm/mmu/mmu.c b/arch/x86/kvm/mmu/mmu.c > index ec169f5c7dce..e44ab512c3a1 100644 > --- a/arch/x86/kvm/mmu/mmu.c > +++ b/arch/x86/kvm/mmu/mmu.c > @@ -4296,7 +4296,12 @@ void kvm_arch_async_page_ready(struct kvm_vcpu *vcpu, struct kvm_async_pf *work) > static int __kvm_faultin_pfn(struct kvm_vcpu *vcpu, struct kvm_page_fault *fault) > { > struct kvm_memory_slot *slot = fault->slot; > - bool async; > + struct kvm_follow_pfn foll = { > + .slot = slot, > + .gfn = fault->gfn, > + .flags = FOLL_GET | (fault->write ? FOLL_WRITE : 0), > + .allow_write_mapping = true, > + }; > > /* > * Retry the page fault if the gfn hit a memslot that is being deleted > @@ -4325,12 +4330,14 @@ static int __kvm_faultin_pfn(struct kvm_vcpu *vcpu, struct kvm_page_fault *fault > return RET_PF_EMULATE; > } > > - async = false; > - fault->pfn = __gfn_to_pfn_memslot(slot, fault->gfn, false, false, &async, > - fault->write, &fault->map_writable, > - &fault->hva); > - if (!async) > - return RET_PF_CONTINUE; /* *pfn has correct page already */ > + foll.flags |= FOLL_NOWAIT; > + fault->pfn = __kvm_follow_pfn(&foll); > + > + if (!is_error_noslot_pfn(fault->pfn)) We have pfn in struct kvm_follow_pfn as output. Can we make __kvm_follow_pfn() return int instead of kvm_pfn_t? KVM_PFN_* seems widely used, though. > + goto success; > + > + if (fault->pfn != KVM_PFN_ERR_NEEDS_IO) > + return RET_PF_CONTINUE; > > if (!fault->prefetch && kvm_can_do_async_pf(vcpu)) { > trace_kvm_try_async_get_page(fault->addr, fault->gfn); > @@ -4348,9 +4355,17 @@ static int __kvm_faultin_pfn(struct kvm_vcpu *vcpu, struct kvm_page_fault *fault > * to wait for IO. Note, gup always bails if it is unable to quickly > * get a page and a fatal signal, i.e. SIGKILL, is pending. > */ > - fault->pfn = __gfn_to_pfn_memslot(slot, fault->gfn, false, true, NULL, > - fault->write, &fault->map_writable, > - &fault->hva); > + foll.flags |= FOLL_INTERRUPTIBLE; > + foll.flags &= ~FOLL_NOWAIT; > + fault->pfn = __kvm_follow_pfn(&foll); > + > + if (!is_error_noslot_pfn(fault->pfn)) > + goto success; > + > + return RET_PF_CONTINUE; > +success: > + fault->hva = foll.hva; > + fault->map_writable = foll.writable; > return RET_PF_CONTINUE; > } > > -- > 2.41.0.255.g8b1d071c50-goog > -- Isaku Yamahata