Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp303667ybh; Wed, 22 Jul 2020 00:43:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw0zJ+XYIrEiYdafyP+vDrSNTvJCSNcUUl/5Rfb0hKkXOnFOoRWjWq/FjF+KDYYRFq4/jFx X-Received: by 2002:a17:906:35ce:: with SMTP id p14mr26263897ejb.514.1595403812620; Wed, 22 Jul 2020 00:43:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595403812; cv=none; d=google.com; s=arc-20160816; b=0cX3IlmXdyHjnI/TB4CXnVmHiXcyzNXyxazeRkpZWcb6wl3rVJ/0Bqty6EaNJ1M3YW qeoO+I5ELdYFa2oYFNVG1wHH1cmARroT/qVyPPoMH4ycDhNz4/iegHWRb/Z/9Ag/L2yE iKnvJAJqw8dIC5i5gcLcD+I9Dl9nmJ95Hyl+Sa5PxWtvi663A+MOi4QmWPzrivthT+ze gm7Ebp7bc5vwkPB0upeBz2dm2ybD8+BQcTQqDhiqWww634tjr6kvVXPa1feuw2Y6f0cf kvfnw6br49yInZOOVICl8sH1a0I+9B72jpJPqW9IsfqDadWkbHOO/koQvAzlR36MCdk8 UBEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:dkim-signature:dkim-signature:from; bh=Gbqm5K4EGN0XlBTSaGQo9gczmAY+kOjA9eIg/nlo58I=; b=hf2jJGzBv+0f3CRA7WNoKlZuyXSbxglgXLBF2RWAfvhjLO0XU3KmfqHX9wK0R/FGpB beIQqfOWYKq+uHEyNjMxZwvvfvsVtyitoMxsSPE4v8etCO6dNkvD4ITFp+rM7y1kqsBU 29iBSVgo5II0wDeBTtnYhMJ3SptQp7FKF/ScLom06R9rManJjYh8hR3fDJSOTN25HOb9 pN3MHjshcvad5oODC9ugFHvzXDzswkwLs81FGiJYV2tn1cbNqKsBTqmz8Erz80npsJYO dlP5xtP5xjVdTVGQRr5059Qc/I6oQdtLD5jj/qwFHxu4DKM/owwxDk9MPXBhEIJsLlM1 GZxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=jHTSXAQ2; dkim=neutral (no key) header.i=@vger.kernel.org header.b=Iw1xqYRN; 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=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k22si13766937edx.125.2020.07.22.00.43.09; Wed, 22 Jul 2020 00:43:32 -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=@linutronix.de header.s=2020 header.b=jHTSXAQ2; dkim=neutral (no key) header.i=@vger.kernel.org header.b=Iw1xqYRN; 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=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730106AbgGVHkQ (ORCPT + 99 others); Wed, 22 Jul 2020 03:40:16 -0400 Received: from Galois.linutronix.de ([193.142.43.55]:46406 "EHLO galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726821AbgGVHkQ (ORCPT ); Wed, 22 Jul 2020 03:40:16 -0400 From: Thomas Gleixner DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1595403613; 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: in-reply-to:in-reply-to:references:references; bh=Gbqm5K4EGN0XlBTSaGQo9gczmAY+kOjA9eIg/nlo58I=; b=jHTSXAQ2hzzNBS73dgw4hlS6vcHyPMYXKVJqwhTV6nTTCyTm1QY4xPmxoeRZXpxAxbP982 jydheFS6bSNkH73RLfV86zUtuBPB8O1SvG+/s/m+R3pSY/r5+dHdb1tlDPwhboqY6oSHaH 4CyFO/OR31a0731L3brjZ1a1RhaAj1FNSHsw7ATQQJ/pZamyOhRaciJ0FM9j8plVCkZ5uI CMM9Fyj6vZGlYjbzqDQo2363CsZ7X47mYIExCADVAHXaMZnb3fmTh+2eD5KiuvRweRYVuQ fXMj7O+AvEyVChlTGUAF9XPlJP+SeH6SL1q0nGl2vZtMbHlvIBCyyc4GfgsPVQ== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1595403613; 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: in-reply-to:in-reply-to:references:references; bh=Gbqm5K4EGN0XlBTSaGQo9gczmAY+kOjA9eIg/nlo58I=; b=Iw1xqYRNKzkoHluOWDB1up/k8uqfgItJukMm4HyqKZKDnbr1vgs5zoWT36dDKFgk0vVnVi E4sbozZVhjTL2uDQ== To: Sean Christopherson Cc: LKML , x86@kernel.org, linux-arch@vger.kernel.org, Will Deacon , Arnd Bergmann , Mark Rutland , Kees Cook , Keno Fischer , Paolo Bonzini , kvm@vger.kernel.org, Gabriel Krisman Bertazi Subject: Re: [patch V4 15/15] x86/kvm: Use generic exit to guest work function In-Reply-To: <20200721202745.GJ22083@linux.intel.com> References: <20200721105706.030914876@linutronix.de> <20200721110809.855490955@linutronix.de> <20200721202745.GJ22083@linux.intel.com> Date: Wed, 22 Jul 2020 09:40:13 +0200 Message-ID: <87lfjc2e1u.fsf@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Sean Christopherson writes: > On Tue, Jul 21, 2020 at 12:57:21PM +0200, Thomas Gleixner wrote: >> - if (signal_pending(current)) >> + if (__exit_to_guest_mode_work_pending()) > > I whined about this back in v2[*]. "exit to guest mode" is confusing becuase > virt terminology is "enter to guest" and "exit from guest", whereas the > kernel's terminology here is "exit from kernel to guest". > > My past and current self still like XFER_TO_GUEST as the base terminology. > > [*] https://lkml.kernel.org/r/20191023144848.GH329@linux.intel.com Forgot about that, sorry. Will fix. >> @@ -8676,15 +8677,11 @@ static int vcpu_run(struct kvm_vcpu *vcp >> break; >> } >> >> - if (signal_pending(current)) { >> - r = -EINTR; >> - vcpu->run->exit_reason = KVM_EXIT_INTR; >> - ++vcpu->stat.signal_exits; >> - break; >> - } >> - if (need_resched()) { >> + if (exit_to_guest_mode_work_pending()) { >> srcu_read_unlock(&kvm->srcu, vcpu->srcu_idx); >> - cond_resched(); >> + r = exit_to_guest_mode(vcpu); >> + if (r) > > This loses the stat.signal_exits accounting. Maybe this? No, it does not: + if (ti_work & _TIF_SIGPENDING) { + kvm_handle_signal_exit(vcpu); + return -EINTR; + } and +#ifdef CONFIG_KVM_EXIT_TO_GUEST_WORK +static inline void kvm_handle_signal_exit(struct kvm_vcpu *vcpu) +{ + vcpu->run->exit_reason = KVM_EXIT_INTR; + vcpu->stat.signal_exits++; +} +#endif /* CONFIG_KVM_EXIT_TO_GUEST_WORK */ in patch 5/15 Thanks, tglx