Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1359248pxb; Wed, 20 Oct 2021 03:34:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxeKdCo9ezRnzhfc9r52JwWiy84Ppfb3HzdBvYWhz4Yq6LZQ9YxYrNbWOnv+eN4BknL6e95 X-Received: by 2002:a17:902:d50f:b0:13f:ac51:29b4 with SMTP id b15-20020a170902d50f00b0013fac5129b4mr22604851plg.51.1634726089055; Wed, 20 Oct 2021 03:34:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634726089; cv=none; d=google.com; s=arc-20160816; b=rD21b3q9w2AztnjfRHHvKPFz/k333a9uJnSGOaurxGBJj1RAa0hxJqf+Toznc5Scpe XJJUdgBYZSZMJSENPr+Q4spkOPD9O+hrr8y+2SW2+AM4i2yj7uS9R3FqRJ//KtsF0W8N AYM74LPRwf8CMnaxm+mPv9bNUJuGU9o6+khu3TEcRqEfp5mv2NoAYi24Mnxy7O7m10tV TzEdKZTXG5z/eTkqMz6tIaRgVlaMqTn4k30ZjPx1zO/vwlPDhiFcnXfaPTMwqEtOlqdP Oj+xalq99IebIWbhASgCjRFM5QUX1zlD/GTH2FYADO/W+GneYmsRUpjTD5R5SnaBMcoQ gfKg== 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=c+6ia2LTxEZdCSQG6Lo1j9cq6FIxE6MAj01YvsoiNsg=; b=aKie3CHyAHlVDiQZQWiCHMH6uOxUVc/U2DSAgnG8i6ItgYZMTzsDa9sS+yCBSRcTzR z/hnQGalQZSzHb+Ah7o6TSsUnxKKc5vf1XcxIcbr/uaBKo5xXpsDtz5+AbpVuXsgZZ2O BEVSdjaB95aHyXgb+WpMS6RBI86v5UDw9JyG84cSK9lCM4oEFs2XlxoGkhh5P7PFZ58y VnyoL3xp869TmKviZPfcbNqKacM0bNi1f4icfLXxUdHhmXPke9DBvAjh23Hui+zlNxrW X+mDCCGYPG+O2gbQAKCA5TH45hecb5XjGB1Ci3kvh0F/eQYaxPbb2CturtdPOtbIGsNX +2lQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=II2Fro2U; 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 z2si2926440pfc.211.2021.10.20.03.34.36; Wed, 20 Oct 2021 03:34:49 -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=II2Fro2U; 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 S230052AbhJTKfw (ORCPT + 99 others); Wed, 20 Oct 2021 06:35:52 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:22102 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229639AbhJTKfu (ORCPT ); Wed, 20 Oct 2021 06:35:50 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1634726016; 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=c+6ia2LTxEZdCSQG6Lo1j9cq6FIxE6MAj01YvsoiNsg=; b=II2Fro2U/K1d4YysqSXDbsLzydByrmVAlOYNzJqsoxwHjlxbVBZogq455bsuXc7/YoSVi4 kVymvWjDvkFvpaHFcOwDEr90CRdrviLbD4/iig57mH52uzT3IIcX6odrcM0t6IWJ1k0k/W K8MsZvRaQmlwkh6akqkvSCs8BElAexg= Received: from mail-ed1-f72.google.com (mail-ed1-f72.google.com [209.85.208.72]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-323-ykYyk44GNCujouIhnBvyGg-1; Wed, 20 Oct 2021 06:33:35 -0400 X-MC-Unique: ykYyk44GNCujouIhnBvyGg-1 Received: by mail-ed1-f72.google.com with SMTP id a3-20020a50da43000000b003dca31dcfc2so4146735edk.14 for ; Wed, 20 Oct 2021 03:33:35 -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=c+6ia2LTxEZdCSQG6Lo1j9cq6FIxE6MAj01YvsoiNsg=; b=HWutVrc4HVdKUcBh94LyN49d5y9Ci4whub3CwOxaIlsBlV8IGRjRkK9oh34Zaxx6Zp KDN9UX184oZsastXDjFzCOsnfCWHaki+O6G64KVjN7F1hbnk+TQyv6bVECLq1rhogcMj CTLiq6T30D/6Yn+jJYibDC2KhcbVit8P25wy/7IJjGgGUuS4Xw5BejrsNNNX45UCGEDA KqjOBVl59aZwLXYMNE9UrrUs6PPGRusvBYe1n0vQPiKfBMytyKWzv0Yk1tDWigcfHseY 08j/bCzMn2aLZ6HJR2X25iG/fRe8vdLvTy/I98OYgEPpz9DwfcWiwKHeRgVKWCO12rDC Ttdw== X-Gm-Message-State: AOAM533VLGilqiWQw9aKYZmjKynWFRqbGilJOwcceudQ3fdVC6ZKJnt2 o41GtHI6qOp0qPsC+z+AcODBJdFrKP6RTCg9Qu73ri4KpfTJHgMJh2i/lpiImygybl8MaF7yMXl mn2YwZCmWckiHtyKJ/aBRj0iJ X-Received: by 2002:aa7:db85:: with SMTP id u5mr61582471edt.234.1634726014091; Wed, 20 Oct 2021 03:33:34 -0700 (PDT) X-Received: by 2002:aa7:db85:: with SMTP id u5mr61582432edt.234.1634726013789; Wed, 20 Oct 2021 03:33:33 -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 z19sm861455ejp.97.2021.10.20.03.33.32 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 20 Oct 2021 03:33:32 -0700 (PDT) Message-ID: <9fdab135-648c-a378-9a64-f069cf6c0eba@redhat.com> Date: Wed, 20 Oct 2021 12:33:31 +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 v3 3/3] KVM: vCPU kick tax cut for running vCPU Content-Language: en-US To: Sean Christopherson Cc: Wanpeng Li , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel References: <1634631160-67276-1-git-send-email-wanpengli@tencent.com> <1634631160-67276-3-git-send-email-wanpengli@tencent.com> <24e67e43-c50c-7e0f-305a-c7f6129f8d70@redhat.com> From: Paolo Bonzini In-Reply-To: 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 19/10/21 19:34, Sean Christopherson wrote: > The intent of the extra check was to avoid the locked instruction that comes with > disabling preemption via rcu_read_lock(). But thinking more, the extra op should > be little more than a basic arithmetic operation in the grand scheme on modern x86 > since the cache line is going to be locked and written no matter what, either > immediately before or immediately after. There should be no locked instructions unless you're using PREEMPT_RT/PREEMPT_RCU, no? The preempt_disable count is in a percpu variable. > > + /* > + * Avoid the moderately expensive "should kick" operation if this pCPU > + * is currently running the target vCPU, in which case it's a KVM bug > + * if the vCPU is in the inner run loop. > + */ > + if (vcpu == __this_cpu_read(kvm_running_vcpu) && > + !WARN_ON_ONCE(vcpu->mode == IN_GUEST_MODE)) > + goto out; > + It should not even be a problem if vcpu->mode == IN_GUEST_MODE, you just set it to EXITING_GUEST_MODE without even the need for atomic_cmpxchg. I'll send a few patches out, since I think I found some related issues. Paolo