From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id B1FE9C4332F for ; Thu, 10 Nov 2022 17:00:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=LTUVVN/rAx3gwNDzC3/WMq+Nj6+fLVjNVNVRC4KWvEk=; b=vKvf7PQFwWwYPj 6tttCKhqBKdxMPonxhP/16A4HrNJkeCzxhAAQ8q1VZ31ns1jQrhSuhoG+0JFpFH9uYUYgoveKDgIZ ZgL01afaOqyS/MV5z8IqWlSE1CKXlf8lCyN8nAMIoLuS93O2c0sDPKYE0/upqWQCpm21FwQ7LC9Gy EAMkNQTF5Ibe2/B+tGPTP7rONGC3H901JS8Lpr0v+t6P5vC0Dmas+wHIOhEMhlDiFfPquB7wbznaT vbBF36orTQpojieha85orTKdaiUpg4rrv6wM6NquwSPshAMtus/yYHotlv8lqo19u8JAH7/h+nVMQ xLHjb+1j8C+zcCTBO3DA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1otAtQ-007PLk-8p; Thu, 10 Nov 2022 16:59:08 +0000 Received: from mail-pj1-x102b.google.com ([2607:f8b0:4864:20::102b]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1otAtK-007PHE-Fc for linux-arm-kernel@lists.infradead.org; Thu, 10 Nov 2022 16:59:05 +0000 Received: by mail-pj1-x102b.google.com with SMTP id gw22so2021619pjb.3 for ; Thu, 10 Nov 2022 08:59:01 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date:from:to :cc:subject:date:message-id:reply-to; bh=++qaNnNL5OJX09F4SmymJbSNGTe4YNGKf8knlNeZLIM=; b=LnpIznW50UbJYIR0PEtWeJYNJ+5rH6MIlZozMzFMTwSQvTcP33ucW9c9lQSevvLDXI QyB5+yXhMZUDNlkwdSbDFjM7JR9S8ttOodJeLQApsp/g1X2g7iaiRMpztbbtLirGmHXP Ok5MPlCZ4tZXNzdoN/5EaAFNU5i/kMEU+Pj6UbsvHwVNko95a9bIdjWXiNhQrkyCMZcF 1gbXxHeTac5BLcvPalQHTWFwjbFrO0re69/ZDM4/c7ATiGknmYZEnSteDE0eFOsuiUGv o02wNWrUZNQBtGle02WgOsPhE6Inb5/XeEtyenAcor9m9bnEppDYL8UdqJt6p1agDB2o ED2w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=++qaNnNL5OJX09F4SmymJbSNGTe4YNGKf8knlNeZLIM=; b=R6+VkPq2ApL5+ckJDfQ9mhe9Sfq02nAieGt6BCZvkmEXX4FulfVxEQSnQY0Q3OnCCC Z41Th8gsflyJASMYHz3Pmo6U8gAGvf9DnjDy06lJCDZp6wItlLRmpss+U60VpJQj2FYE BJpdyTovy4V70gwFF8itqOySIaSdwiMlGDxpAd97ckgIfrz8oKDUCvWZFc9f69M3a4hJ UzDD7iXBI7w0er3O1pAUXIR32BdiT2rh4V/l7s2LfDlnOzjOafakXtu+K/NXQyC+yhXF Y3r0hXuwgsR0hs3cuKAN/zyl3XPp9fRmz5ffNbJVFUnRoJyFj2kfDx7r7mptX73vnmgS i4yQ== X-Gm-Message-State: ANoB5plLMvRxwjuJOjT/wUXFAYu1Ck5gVNrUbA8Zhk0aJ7RjNy543ngh 9i9pWSlU41FB4Iv2qjXpeV6YiQ== X-Google-Smtp-Source: AA0mqf4HLI0425WgRwXjVOczy7lGJ1ZoFRhJMikRvyU6kmBBe6o5W1MVmVmeziJeqm75+QzM+47Lew== X-Received: by 2002:a17:902:6aca:b0:188:736c:befa with SMTP id i10-20020a1709026aca00b00188736cbefamr1100928plt.8.1668099540938; Thu, 10 Nov 2022 08:59:00 -0800 (PST) Received: from google.com (7.104.168.34.bc.googleusercontent.com. [34.168.104.7]) by smtp.gmail.com with ESMTPSA id n63-20020a17090a5ac500b00200461cfa99sm3302123pji.11.2022.11.10.08.59.00 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 10 Nov 2022 08:59:00 -0800 (PST) Date: Thu, 10 Nov 2022 16:58:56 +0000 From: Sean Christopherson To: "Huang, Kai" Cc: "farman@linux.ibm.com" , "frankja@linux.ibm.com" , "mjrosato@linux.ibm.com" , "vkuznets@redhat.com" , "chenhuacai@kernel.org" , "aou@eecs.berkeley.edu" , "palmer@dabbelt.com" , "paul.walmsley@sifive.com" , "maz@kernel.org" , "anup@brainfault.org" , "imbrenda@linux.ibm.com" , "pbonzini@redhat.com" , "borntraeger@linux.ibm.com" , "aleksandar.qemu.devel@gmail.com" , "kvm@vger.kernel.org" , "atishp@atishpatra.org" , "farosas@linux.ibm.com" , "david@redhat.com" , "Yao, Yuan" , "mpe@ellerman.id.au" , "alexandru.elisei@arm.com" , "linux-s390@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "tglx@linutronix.de" , "Yamahata, Isaku" , "kvmarm@lists.linux.dev" , "james.morse@arm.com" , "kvm-riscv@lists.infradead.org" , "suzuki.poulose@arm.com" , "linuxppc-dev@lists.ozlabs.org" , "linux-arm-kernel@lists.infradead.org" , "linux-mips@vger.kernel.org" , "Gao, Chao" , "oliver.upton@linux.dev" , "kvmarm@lists.cs.columbia.edu" , "linux-riscv@lists.infradead.org" Subject: Re: [PATCH 38/44] KVM: Disable CPU hotplug during hardware enabling Message-ID: References: <20221102231911.3107438-1-seanjc@google.com> <20221102231911.3107438-39-seanjc@google.com> <88e920944de70e7d69a98f74005b49c59b5aaa3b.camel@intel.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20221110_085902_540256_BCB0A524 X-CRM114-Status: GOOD ( 24.67 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org On Thu, Nov 10, 2022, Huang, Kai wrote: > On Thu, 2022-11-10 at 01:33 +0000, Huang, Kai wrote: > > > @@ -9283,7 +9283,13 @@ static int > > > kvm_x86_check_processor_compatibility(struct kvm_x86_init_ops *ops) > > > =A0 int cpu =3D smp_processor_id(); > > > =A0 struct cpuinfo_x86 *c =3D &cpu_data(cpu); > > > =A0 > > > - WARN_ON(!irqs_disabled()); > > > + /* > > > + * Compatibility checks are done when loading KVM and when enabling > > > + * hardware, e.g. during CPU hotplug, to ensure all online CPUs are > > > + * compatible, i.e. KVM should never perform a compatibility check > > > on > > > + * an offline CPU. > > > + */ > > > + WARN_ON(!irqs_disabled() && cpu_active(cpu)); > > > =A0 > > = > > Also, the logic of: > > = > > !irqs_disabled() && cpu_active(cpu) > > = > > is quite weird. > > = > > The original "WARN(!irqs_disabled())" is reasonable because in STARTING > > section > > the IRQ is indeed disabled. > > = > > But this doesn't make sense anymore after we move to ONLINE section, in= which > > IRQ has already been enabled (see start_secondary()).=A0 IIUC the WARN_= ON() > > doesn't get exploded is purely because there's an additional cpu_active= (cpu) > > check. > > = > > So, a more reasonable check should be something like: > > = > > WARN_ON(irqs_disabled() || cpu_active(cpu) || !cpu_online(cpu)); > > = > > Or we can simply do: > > = > > WARN_ON(!cpu_online(cpu) || cpu_active(cpu)); > > = > > (because I don't know whether it's possible IRQ can somehow get disable= d in > > ONLINE section). > > = > > Btw above is purely based on code analysis, but I haven't done any test. > = > Hmm.. I wasn't thinking thoroughly. I forgot CPU compatibility check also > happens on all online cpus when loading KVM. For this case, IRQ is disab= led and > cpu_active() is true. For the hotplug case, IRQ is enabled but cpu_acti= ve() is > false. > = > So WARN_ON(!irqs_disabled() && cpu_active(cpu)) looks reasonable. Sorry = for the > noise. Just needed some time to connect the comment with the code. No worries, more than once while working through this code, I've considered= setting up one of those evidence boards from the movies with string and push pins t= o help connect all the dots. _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel