Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755144AbdDGKrx (ORCPT ); Fri, 7 Apr 2017 06:47:53 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:34106 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752982AbdDGKrp (ORCPT ); Fri, 7 Apr 2017 06:47:45 -0400 Subject: Re: [PATCH RFC 1/6] KVM: fix guest_mode optimization in kvm_make_all_cpus_request() To: =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= , linux-kernel@vger.kernel.org, kvm@vger.kernel.org References: <20170406202056.18379-1-rkrcmar@redhat.com> <20170406202056.18379-2-rkrcmar@redhat.com> Cc: Christoffer Dall , Andrew Jones , Marc Zyngier , Paolo Bonzini , Cornelia Huck , James Hogan , Paul Mackerras From: Christian Borntraeger Date: Fri, 7 Apr 2017 12:47:38 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.8.0 MIME-Version: 1.0 In-Reply-To: <20170406202056.18379-2-rkrcmar@redhat.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 x-cbid: 17040710-0056-0000-0000-000003321674 X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00006892; HX=3.00000240; KW=3.00000007; PH=3.00000004; SC=3.00000208; SDB=6.00844228; UDB=6.00416122; IPR=6.00622526; BA=6.00005275; NDR=6.00000001; ZLA=6.00000005; ZF=6.00000009; ZB=6.00000000; ZP=6.00000000; ZH=6.00000000; ZU=6.00000002; MB=3.00014947; XFM=3.00000013; UTC=2017-04-07 10:47:43 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17040710-0057-0000-0000-000007681A9A Message-Id: <2edb5eb1-f67e-eeea-a478-008fcb92a812@de.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-04-07_10:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=0 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1702020001 definitions=main-1704070090 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2370 Lines: 58 On 04/06/2017 10:20 PM, Radim Krčmář wrote: > We have kvm_arch_vcpu_should_kick() to decide whether the target cpu > needs to be kicked. The previous condition was wrong, because > architectures that don't use vcpu->mode would not get interrupts and > also suboptimal, because it sent IPI in cases where none was necessary. > > The situation is even more convoluted. MIPS and POWERPC return 1 from > kvm_arch_vcpu_should_kick(), but implement vcpu->mode for some reason, > so now they might kick uselessly. This is not a huge problem. > > s390, on the other hand, never changed vcpu->mode, so it would always be > OUTSIDE_GUEST_MODE before and therefore didn't send IPIs. > I don't see a reason why s390 had kvm_make_all_cpus_request() that did > nothing but set the bit in vcpu->request, so the new behavior seems > better. As on s390 nobody ever called kvm_make_all_cpus_request this patch should be fine for s390. But even if somebody would start calling kvm_make_all_cpus_requests this should do what we want (as long as we do not need the special "make sure to be really out of guest" thing). Not sure about the x86 things that James mentioned. > > Signed-off-by: Radim Krčmář > --- > arch/s390/kvm/kvm-s390.c | 4 +--- > virt/kvm/kvm_main.c | 2 +- > 2 files changed, 2 insertions(+), 4 deletions(-) > > diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c > index fd6cd05bb6a7..45b6d9ca5d24 100644 > --- a/arch/s390/kvm/kvm-s390.c > +++ b/arch/s390/kvm/kvm-s390.c > @@ -2130,9 +2130,7 @@ static void kvm_gmap_notifier(struct gmap *gmap, unsigned long start, > > int kvm_arch_vcpu_should_kick(struct kvm_vcpu *vcpu) > { > - /* kvm common code refers to this, but never calls it */ > - BUG(); > - return 0; > + return 1; > } > > static int kvm_arch_vcpu_ioctl_get_one_reg(struct kvm_vcpu *vcpu, > diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c > index f489167839c4..2389e9c41cd2 100644 > --- a/virt/kvm/kvm_main.c > +++ b/virt/kvm/kvm_main.c > @@ -187,7 +187,7 @@ bool kvm_make_all_cpus_request(struct kvm *kvm, unsigned int req) > smp_mb__after_atomic(); > > if (cpus != NULL && cpu != -1 && cpu != me && > - kvm_vcpu_exiting_guest_mode(vcpu) != OUTSIDE_GUEST_MODE) > + kvm_arch_vcpu_should_kick(vcpu)) > cpumask_set_cpu(cpu, cpus); > } > if (unlikely(cpus == NULL)) >