Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2927630pxb; Mon, 18 Oct 2021 05:00:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyXftcXIaxuJUSB6OBCOuVxX/+lor56XDwD9kAh3+vGkcYOhC7CDcSyNcEc+IqL+OcYIrPU X-Received: by 2002:a17:907:7752:: with SMTP id kx18mr29401926ejc.276.1634558418019; Mon, 18 Oct 2021 05:00:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634558418; cv=none; d=google.com; s=arc-20160816; b=KMkzNo4Goziv06RNNbqFa96cv2dyCe26kEn2jcDN1wpe+KCigO2aZSzMqMh2OzX4Ar qvq0+08v1P/No7gLACSkQii/XUwfwEqW31z6wLLGgSXjIx1qOhoRVf6IKbg0+/T6I6jQ 07Etg9A2KOhldgXRMsqiEnrlbOvTklGMnD91K1tX7KjwHN6WTOO2FM5h0YBCUlcysyVp D4mqaKhxXX8S9LMraerbDnYUSUqPfXrbOi9SOAuUf8tJ24obXZRzfij+qPqahSt9Yi5h W8AY0NXd1y1sn9URqhRMEI4J4crRMKkqu2oeaqKYy/PCCzt45r8uYprcHe5kZbfwPvfe beOA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=fCM/GUGbXTstduw5A7ZtGYQzITbTV7AQFdkBboCynIE=; b=terGDR3Ec1DUmpLeaskum12tEwiVVZRCzl0YJDKuu5wAnr6NS+ZQw5TE7KzaEcMdqu Q8yh++XwnAJGXIn1X1oPf8PP3kklDxJwyekpgBDJOuTZqRNVN+WjrRf+yO1ZJSGB/C7p q+wL4ztxl/FKlG8qVnpjAUsqoNz2TN6i/JNakqIvEW08BQvs1ENiMtdjLGyEha9ww+CO Hz8yQKZEPOu3AJCllpTlf27apgHW7B8S2RsWgK/snloDlfjMmMncuJ8h3mfzLoYs4B5p jt506JESiu6VhxkrB3kb7qA11yVPaRysN8hqxsvnAhBUmzja2UPtuK4Hp04FujGlytZW UgKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=fatAZExH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dt9si28817233ejc.675.2021.10.18.04.59.54; Mon, 18 Oct 2021 05:00:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=fatAZExH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231618AbhJRL6O (ORCPT + 99 others); Mon, 18 Oct 2021 07:58:14 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:48528 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231623AbhJRL6I (ORCPT ); Mon, 18 Oct 2021 07:58:08 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1634558157; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=fCM/GUGbXTstduw5A7ZtGYQzITbTV7AQFdkBboCynIE=; b=fatAZExHlkYvjov0gS602mfrLcbtAWjSCRMszS/Y814ERwhnT9Yt4LdLP85Lh4PVChBkJZ XcZbMu5UZhqYK3zl/JJY3k1SgcbYYwGz6YoQboekVBLlDxA5KebRhUcec46gck5Q41aYDn zoI/Dr0RJGnGCFNTxsWdIuYWTG85HIA= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-443-W4gMF3P6NvCD9oNC0c803A-1; Mon, 18 Oct 2021 07:55:56 -0400 X-MC-Unique: W4gMF3P6NvCD9oNC0c803A-1 Received: by mail-wr1-f70.google.com with SMTP id l8-20020a5d6d88000000b001611b5de796so8757246wrs.10 for ; Mon, 18 Oct 2021 04:55:56 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=fCM/GUGbXTstduw5A7ZtGYQzITbTV7AQFdkBboCynIE=; b=HtDz3fzTpqFBB+QgL+8+LaJFeK5bnbDrCnoS3nc6z8mU/EPwAydDZf17D5TA9slgq2 rby7et3+7TsjIRUgWssV4/0eNNyQb5utoRfjvrD6BoJrG+T67Ql6pOs3ZYtwtj2PUqoT lc3JDja5SymXHgFkR+AoZl/60j4cOoBCxOVLM895eGE2obNvfPk0cJrllu4/CuT42CUL 1B44ISaC5Vdtt9nxbze0jPnGobBSEeU3bBFsk13mLSmXpXa5MFjgPnBtqRjbBMGROzMb lWSpmEbGe0mKmnWn2wFTfH6aAkgqdiQJoXHCD0QcTmHKV22xQ0tAoy/YcNVhTJCqDlXm ZzXA== X-Gm-Message-State: AOAM533Zo3bn66nDNbcN48DTst4d+T/vLgbcvJHh81KwfEkMng+nNw8I WP2RIpMemPjEpWlQIre/q7DyLFGh8XmK5ZxRHWeFwhwjM6YzcE0ykjZ8NcW123KLgiAm3KuJ6GI j8FcCVPmWvq/QycDBbyBbz/LW X-Received: by 2002:a5d:598a:: with SMTP id n10mr34535608wri.93.1634558155065; Mon, 18 Oct 2021 04:55:55 -0700 (PDT) X-Received: by 2002:a5d:598a:: with SMTP id n10mr34535587wri.93.1634558154877; Mon, 18 Oct 2021 04:55:54 -0700 (PDT) Received: from ?IPV6:2001:b07:6468:f312:c8dd:75d4:99ab:290a? ([2001:b07:6468:f312:c8dd:75d4:99ab:290a]) by smtp.gmail.com with ESMTPSA id x7sm12108195wrq.69.2021.10.18.04.55.53 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 18 Oct 2021 04:55:54 -0700 (PDT) Message-ID: Date: Mon, 18 Oct 2021 13:55:53 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.1.0 Subject: Re: [patch 3/4] x86/kvm: Convert FPU handling to a single swap buffer Content-Language: en-US To: Thomas Gleixner , LKML Cc: x86@kernel.org, "Liu, Jing2" , "Bae, Chang Seok" , Dave Hansen , Arjan van de Ven , kvm@vger.kernel.org, "Nakajima, Jun" , Sean Christopherson References: <20211017151447.829495362@linutronix.de> <20211017152048.666354328@linutronix.de> From: Paolo Bonzini In-Reply-To: <20211017152048.666354328@linutronix.de> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17/10/21 19:03, Thomas Gleixner wrote: > */ > - fpu_swap_kvm_fpu(vcpu->arch.user_fpu, vcpu->arch.guest_fpu, > - ~XFEATURE_MASK_PKRU); > + fpu_swap_kvm_fpstate(&vcpu->arch.guest_fpu, true, ~XFEATURE_MASK_PKRU); > trace_kvm_fpu(1); > } > > /* When vcpu_run ends, restore user space FPU context. */ > static void kvm_put_guest_fpu(struct kvm_vcpu *vcpu) > { > - /* > - * Guests with protected state have guest_fpu == NULL which makes > - * swap only restore the host state. > - */ > - fpu_swap_kvm_fpu(vcpu->arch.guest_fpu, vcpu->arch.user_fpu, ~0ULL); > + fpu_swap_kvm_fpstate(&vcpu->arch.guest_fpu, false, ~0ULL); The restore mask can be ~XFEATURE_MASK_PKRU in this case tool this way it's constant and you can drop the third argument to the function. Also perhaps it could be useful to add an if (WARN_ON_ONCE(cur_fps->is_guest == enter_guest)) return; at the top of fpu_swap_kvm_fpstate, since the is_guest member (at least for now?) is only used for such kind of assertion. Paolo