Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp15959pxb; Fri, 20 Aug 2021 17:07:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzSr9KYFgcrtYEuMzp2l+0BJpfBGOZfDvS7Xj+nv60LmLXx41/SftCPcRGeQJnQGM5CCaWy X-Received: by 2002:a6b:f817:: with SMTP id o23mr17940857ioh.205.1629504459577; Fri, 20 Aug 2021 17:07:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629504459; cv=none; d=google.com; s=arc-20160816; b=xyPneLG8lMMnP7wAL/3/DMSNX7omWlNB6IK79p9qY2vdNUeoJDIL7A7jZw+pVpX8ih 5rnizWseaBiC5t5HvtH2YBeHWV7kIBwTaQivSVSsTZFKJZw7WmMlR6NSao54/h2Qcqf7 c43P/WwS4dnsaYOGEQdDTFVn6NNGtVEnCkl1YJ6iRdpu+gwGN3IP0tQp+8PCFIZ86JGr y4RXeNxBHED22PSnfs+0RnXAFeLLsay9/5tQU5fjZZDLFiShFoQik2T05PcH7Lhgvdxs eVna8L2zjt5wFjCNEhAODFnPTAaehabuMjMA1SZcVRAieiyLQhCqrO/xG/9lhB4QMqbM Up5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:reply-to:dkim-signature; bh=54uWzZ0QiUh7LTT7cDKnUdwo+y1GGb5heMjjM1DQHz8=; b=Y4gxn6dZXFWJjkCYeIgcKOYCb1wq5Hntm6Ps0Oro3YzKk7uAPAa6RjFlR46cCv0HgY FjO8pq72fTbHMRpqXRQmMzfoN3XfW7jlfBPEkoL52F/zsnixEgI9Rk06mYmOg1POflaF 83+uGX58t54jCL5hrodfvklYbDMAuBnvxcg2CuYZkTVJtcXBcD0L7QuXLiLK53+RNYMW sw0SGI5vyEhL5msvrmgJBKZ2EszLRTq2VeuV/9ZnUN2A43iM/rH/cjxnwyy6/yIs+1iP EwxBZjDEMvw8yZou0LT5OSVTxNpkxT4RpJe7+6WW7YoA27b7VWC0PkH0mLYcJmuWKfhm qVGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="QuIJU/m6"; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n2si9354009jaj.0.2021.08.20.17.07.28; Fri, 20 Aug 2021 17:07:39 -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=@google.com header.s=20161025 header.b="QuIJU/m6"; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240951AbhHUAFz (ORCPT + 99 others); Fri, 20 Aug 2021 20:05:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54462 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240668AbhHUAFt (ORCPT ); Fri, 20 Aug 2021 20:05:49 -0400 Received: from mail-yb1-xb4a.google.com (mail-yb1-xb4a.google.com [IPv6:2607:f8b0:4864:20::b4a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F3B19C06175F for ; Fri, 20 Aug 2021 17:05:10 -0700 (PDT) Received: by mail-yb1-xb4a.google.com with SMTP id f64-20020a2538430000b0290593bfc4b046so11177985yba.9 for ; Fri, 20 Aug 2021 17:05:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=reply-to:date:in-reply-to:message-id:mime-version:references :subject:from:to:cc; bh=54uWzZ0QiUh7LTT7cDKnUdwo+y1GGb5heMjjM1DQHz8=; b=QuIJU/m6yr7P7ZfLNtjrp+hIPsQn15KcSx30QYnMYc696QV4CagBH1JTiIXWDUxjru a8GUH9i9PTbP5j03MbPTUYRMv/iL4uMXUwLV9dkPe0lh43QzHOHwdYlHZgZBG1DprbLR AOGyQL8wUDJNU4QdsK4LjdePpZn1MR9k+sHHUD1kL/cXFBpIB6U0uqXz/me445ZhdKVw Rk0ZIcMg21zoCyBXSQL+PLnBgPBnIYmkepCRDn1wsmDcoD1nUwJ6yOMYxsCNPBZU+br4 eD5ZFLCnTCt4JyuzwkFWLuhDkcLmXWOY22mCqAJTV7a+in3aD/vASl8vCzRLzD4z1Vl7 d90Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:reply-to:date:in-reply-to:message-id :mime-version:references:subject:from:to:cc; bh=54uWzZ0QiUh7LTT7cDKnUdwo+y1GGb5heMjjM1DQHz8=; b=keBz++ccLU3q56LxlRXRi4TpzPciFrpRIFBxP4dUr9e1jv77dn0hYXocEsUdhuvGoL wDg6+igUefGeVbYLiHXf1E/oa/dj+snWefE0KSim+EP8JjGhM26jgphDVGY08eG4dwMo 9PdZTXKpZ/a3DJdsZQmnoR27wOwarXgucdojn3Ss3cffH8icgCrvsPOKTIpXMnFpSyy/ 5omdHu6alJ3LlU2Lu2n00sdHHVkTCB8lbtuVfT6BMBTXCmAmxAddVfGVkH5rp1HxbvGq QX0w5Hwz85HrUA2XnblMr2Fy50cdABVDvrYBA6DGZX4VTq2zsfXn2t/OEAd1ALmBo7cs 2ubg== X-Gm-Message-State: AOAM530YcdwGSt/HFRWklFFY7lPVtflBhW7XnUr9YVSzaA6FvGkBIb1J +vKM0RTm6yC7bjrytclalmoz/HvgHng= X-Received: from seanjc798194.pdx.corp.google.com ([2620:15c:90:200:f11d:a281:af9b:5de6]) (user=seanjc job=sendgmr) by 2002:a25:8c4:: with SMTP id 187mr27225917ybi.369.1629504310265; Fri, 20 Aug 2021 17:05:10 -0700 (PDT) Reply-To: Sean Christopherson Date: Fri, 20 Aug 2021 17:05:01 -0700 In-Reply-To: <20210821000501.375978-1-seanjc@google.com> Message-Id: <20210821000501.375978-3-seanjc@google.com> Mime-Version: 1.0 References: <20210821000501.375978-1-seanjc@google.com> X-Mailer: git-send-email 2.33.0.rc2.250.ged5fa647cd-goog Subject: [PATCH 2/2] KVM: Guard cpusmask NULL check with CONFIG_CPUMASK_OFFSTACK From: Sean Christopherson To: Paolo Bonzini Cc: kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Venkatesh Srinivas , Vitaly Kuznetsov , Sean Christopherson Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Check for a NULL cpumask_var_t when kicking multiple vCPUs if and only if cpumasks are configured to be allocated off-stack. This is a meaningless optimization, e.g. avoids a TEST+Jcc and TEST+CMOV on x86, but more importantly helps document that the NULL check is necessary even though all callers pass in a local variable. No functional change intended. Signed-off-by: Sean Christopherson --- virt/kvm/kvm_main.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 786b914db98f..82c5280dd5ce 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c @@ -247,7 +247,7 @@ static void ack_flush(void *_completed) static inline bool kvm_kick_many_cpus(const struct cpumask *cpus, bool wait) { - if (unlikely(!cpus)) + if (IS_ENABLED(CONFIG_CPUMASK_OFFSTACK) && unlikely(!cpus)) cpus = cpu_online_mask; if (cpumask_empty(cpus)) @@ -277,6 +277,14 @@ bool kvm_make_vcpus_request_mask(struct kvm *kvm, unsigned int req, if (!(req & KVM_REQUEST_NO_WAKEUP) && kvm_vcpu_wake_up(vcpu)) continue; + /* + * tmp can be NULL if cpumasks are allocated off stack, as + * allocation of the mask is deliberately not fatal and is + * handled by falling back to kicking all online CPUs. + */ + if (IS_ENABLED(CONFIG_CPUMASK_OFFSTACK) && !tmp) + continue; + /* * Note, the vCPU could get migrated to a different pCPU at any * point after kvm_request_needs_ipi(), which could result in @@ -288,7 +296,7 @@ bool kvm_make_vcpus_request_mask(struct kvm *kvm, unsigned int req, * were reading SPTEs _before_ any changes were finalized. See * kvm_vcpu_kick() for more details on handling requests. */ - if (tmp != NULL && kvm_request_needs_ipi(vcpu, req)) { + if (kvm_request_needs_ipi(vcpu, req)) { cpu = READ_ONCE(vcpu->cpu); if (cpu != -1 && cpu != me) __cpumask_set_cpu(cpu, tmp); -- 2.33.0.rc2.250.ged5fa647cd-goog