Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp36578423rwd; Tue, 11 Jul 2023 02:57:26 -0700 (PDT) X-Google-Smtp-Source: APBJJlHZB6lljwMd9Oo3qAdQ6UCzu66iMDFjRRzm243D3boFQNBf10ydwDT7sThyonYrVtZjc90y X-Received: by 2002:a05:6a20:96cb:b0:118:e70:6f7d with SMTP id hq11-20020a056a2096cb00b001180e706f7dmr10455824pzc.10.1689069446009; Tue, 11 Jul 2023 02:57:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689069445; cv=none; d=google.com; s=arc-20160816; b=vJ6xx/kj8+VsVUHPEMsoAMHMddwxy+wPx6VxMVQbYIKfzTsNL1XYsfMnrYWCY53jO1 8P/V/Z1CGe1ncphY3n01oG91iZDJi70MVGL3nI7Po4u9NXjlta1R17+AIME7ppWbbRaA sl1kodX/g8pVC1Yn6fZsrl6uuzKlvSB4DJyeayHoou22kjZhbr7s1QK+l9kxnr06yMEO 9MelL1R9EZpbEuGXohlN4QEKjsC65drRDkPnjYWyHmRR6NU2kb3ooNyi1SjtfApZOlNO 1ax5FNjsl0E9zwYagl4GWuzcqxWN5LEKOaDs2Oh41lb0B7wTJf2jfZFfSOqc1vicrS+R aVGg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=tsBTJlzLbX5xvehtqYGRXy8jYTyg0U7wQQzHGYycEAI=; fh=ErILU9z4ot+o9ICAsT5y7K9u2UsT7bo55V0MtDXdRoU=; b=UDIHv6+Vv0HnX/S8LKNMyCO7RRoU7mha1F4Vc/q7fQUZgXdyhMEVYqWjjoborFYfZ+ +0/mfb7UpkFHCLJ1qLPjQls4uH/EMrRJEAdhERwL9Pd67i4VTx9paSbiRcFZBZKE6iVO BCE9R6bcvuBQwtv6sFYyLkWH2AL6o8lAEqLf5fg/2zZZdBvxSx9EHRozO8gIxtkyrcwF G2gI1pz3KYpSeSJyfjDSM8+8e6sk0iM7mGd9fXjVVQPwizBiodmdaULRn2QzM6M+kzq2 54tjDGt/s0jQkLIWvp3y2OvlLf3Ypvbv+0XW6SvxUH/R3ZHzrfZiEyYC0BV4wjTkRUt4 EfNw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j13-20020a170902da8d00b0019c354055d0si1364640plx.304.2023.07.11.02.57.14; Tue, 11 Jul 2023 02:57:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229844AbjGKJmA (ORCPT + 99 others); Tue, 11 Jul 2023 05:42:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33572 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229583AbjGKJl6 (ORCPT ); Tue, 11 Jul 2023 05:41:58 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8EEAA91 for ; Tue, 11 Jul 2023 02:41:57 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 7941F2B; Tue, 11 Jul 2023 02:42:39 -0700 (PDT) Received: from bogus (e103737-lin.cambridge.arm.com [10.1.197.49]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 083593F67D; Tue, 11 Jul 2023 02:41:55 -0700 (PDT) Date: Tue, 11 Jul 2023 10:41:53 +0100 From: Sudeep Holla To: Marc Zyngier Cc: kvmarm@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Will Deacon , Oliver Upton , James Morse , Suzuki K Poulose , Sudeep Holla , Zenghui Yu Subject: Re: [PATCH] KVM: arm64: Handle kvm_arm_init failure correctly in finalize_pkvm Message-ID: <20230711094153.36b746snfds3cbr7@bogus> References: <20230704193243.3300506-1-sudeep.holla@arm.com> <86fs5ux2sh.wl-maz@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <86fs5ux2sh.wl-maz@kernel.org> X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 11, 2023 at 09:36:46AM +0100, Marc Zyngier wrote: > On Tue, 04 Jul 2023 20:32:43 +0100, > Sudeep Holla wrote: > > > > Currently there is no synchronisation between finalize_pkvm() and > > kvm_arm_init() initcalls. The finalize_pkvm() proceeds happily even if > > kvm_arm_init() fails resulting in the following warning on all the CPUs > > and eventually a HYP panic: > > > > | kvm [1]: IPA Size Limit: 48 bits > > | kvm [1]: Failed to init hyp memory protection > > | kvm [1]: error initializing Hyp mode: -22 > > | > > | > > | > > | WARNING: CPU: 0 PID: 0 at arch/arm64/kvm/pkvm.c:226 _kvm_host_prot_finalize+0x30/0x50 > > | Modules linked in: > > | CPU: 0 PID: 0 Comm: swapper/0 Not tainted 6.4.0 #237 > > | Hardware name: FVP Base RevC (DT) > > | pstate: 634020c5 (nZCv daIF +PAN -UAO +TCO +DIT -SSBS BTYPE=--) > > | pc : _kvm_host_prot_finalize+0x30/0x50 > > | lr : __flush_smp_call_function_queue+0xd8/0x230 > > | > > | Call trace: > > | _kvm_host_prot_finalize+0x3c/0x50 > > | on_each_cpu_cond_mask+0x3c/0x6c > > | pkvm_drop_host_privileges+0x4c/0x78 > > | finalize_pkvm+0x3c/0x5c > > | do_one_initcall+0xcc/0x240 > > | do_initcall_level+0x8c/0xac > > | do_initcalls+0x54/0x94 > > | do_basic_setup+0x1c/0x28 > > | kernel_init_freeable+0x100/0x16c > > | kernel_init+0x20/0x1a0 > > | ret_from_fork+0x10/0x20 > > | Failed to finalize Hyp protection: -22 > > | dtb=fvp-base-revc.dtb > > | kvm [95]: nVHE hyp BUG at: arch/arm64/kvm/hyp/nvhe/mem_protect.c:540! > > | kvm [95]: nVHE call trace: > > | kvm [95]: [] __kvm_nvhe_hyp_panic+0xac/0xf8 > > | kvm [95]: [] __kvm_nvhe_handle_host_mem_abort+0x1a0/0x2ac > > | kvm [95]: [] __kvm_nvhe_handle_trap+0x4c/0x160 > > | kvm [95]: [] __kvm_nvhe___skip_pauth_save+0x4/0x4 > > | kvm [95]: ---[ end nVHE call trace ]--- > > | kvm [95]: Hyp Offset: 0xfffe8db00ffa0000 > > | Kernel panic - not syncing: HYP panic: > > | PS:a34023c9 PC:0000f250710b973c ESR:00000000f2000800 > > | FAR:ffff000800cb00d0 HPFAR:000000000880cb00 PAR:0000000000000000 > > | VCPU:0000000000000000 > > | CPU: 3 PID: 95 Comm: kworker/u16:2 Tainted: G W 6.4.0 #237 > > | Hardware name: FVP Base RevC (DT) > > | Workqueue: rpciod rpc_async_schedule > > | Call trace: > > | dump_backtrace+0xec/0x108 > > | show_stack+0x18/0x2c > > | dump_stack_lvl+0x50/0x68 > > | dump_stack+0x18/0x24 > > | panic+0x138/0x33c > > | nvhe_hyp_panic_handler+0x100/0x184 > > | new_slab+0x23c/0x54c > > | ___slab_alloc+0x3e4/0x770 > > | kmem_cache_alloc_node+0x1f0/0x278 > > | __alloc_skb+0xdc/0x294 > > | tcp_stream_alloc_skb+0x2c/0xf0 > > | tcp_sendmsg_locked+0x3d0/0xda4 > > | tcp_sendmsg+0x38/0x5c > > | inet_sendmsg+0x44/0x60 > > | sock_sendmsg+0x1c/0x34 > > | xprt_sock_sendmsg+0xdc/0x274 > > | xs_tcp_send_request+0x1ac/0x28c > > | xprt_transmit+0xcc/0x300 > > | call_transmit+0x78/0x90 > > | __rpc_execute+0x114/0x3d8 > > | rpc_async_schedule+0x28/0x48 > > | process_one_work+0x1d8/0x314 > > | worker_thread+0x248/0x474 > > | kthread+0xfc/0x184 > > | ret_from_fork+0x10/0x20 > > | SMP: stopping secondary CPUs > > | Kernel Offset: 0x57c5cb460000 from 0xffff800080000000 > > | PHYS_OFFSET: 0x80000000 > > | CPU features: 0x00000000,1035b7a3,ccfe773f > > | Memory Limit: none > > | ---[ end Kernel panic - not syncing: HYP panic: > > | PS:a34023c9 PC:0000f250710b973c ESR:00000000f2000800 > > | FAR:ffff000800cb00d0 HPFAR:000000000880cb00 PAR:0000000000000000 > > | VCPU:0000000000000000 ]--- > > > > Fix it by checking for the successfull initialisation of kvm_arm_init() > > in finalize_pkvm() before proceeding any futher. > > > > Fixes: 87727ba2bb05 ("KVM: arm64: Ensure CPU PMU probes before pKVM host de-privilege") > > Cc: Will Deacon > > Cc: Marc Zyngier > > Cc: Oliver Upton > > Cc: James Morse > > Cc: Suzuki K Poulose > > Cc: Zenghui Yu > > Signed-off-by: Sudeep Holla > > I really dislike the additional helper, but now that the capabilities > are patched, I can't see another way to achieve this so: > Yes, I too don't like it and was almost tempted to post it as RFC, but then I didn't want it to get ignored ;) as it a bug I hit on my setup with mismatched FF-A version. > Acked-by: Marc Zyngier > Thanks! -- Regards, Sudeep