Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1523210pxb; Thu, 4 Feb 2021 15:37:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJyW+Mu3lR6gXJztYIDBkzHtcecR4fpzYtO6Cm3kaIUFoFV3ZoIJkMtXB55L6nbIW7m72Kn7 X-Received: by 2002:a17:906:c0c9:: with SMTP id bn9mr1445960ejb.318.1612481859496; Thu, 04 Feb 2021 15:37:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612481859; cv=none; d=google.com; s=arc-20160816; b=YpeBEM28NeQa7+LeCTDET4FcDmrw3k8CvxTANRG13yhO1aktExirPr0TTxW+BioaD+ ZVFMJHLkmBZnNnf+YaRrLFiSb6km8q2bEO04/hrGEA4xSIt/t94FfP2S6CzKlpzIlBJ8 L61jHpfm41XKmFMBNKfIbw+HCrPoS2+O+BXnzcgBSwwP1G5LvFPcrq10G/ufcQdEe/Wg fb69irkLfzNOI0kyQE1CIQjppJEKaRvwrpwtTNNFlO8X3Vve0lIaUz88S41tk3liv7jP t6PbTgVn66vY7YzMd9MakRsxbb+6WnD4AUcGJIwU1VAcJSMtTUwUf9bnTZJGNYgqsaD1 pXVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=xS8yvcgZxszBL/Lp1Q20lv+JupswqTIWNdF81ct5ihc=; b=Ru00z56rdhYWeYjxQAv2fLcXNJ+/H9BVuwxwX14cmNNWmInCzmth9dcx4pJyxqSt1Z UeASiADu13FWA0YLVdpjVNqhDMSYEHXpQuswUQpROl6D1xKvNUJ8z3kUqAgex/knRQl/ SnLiR7VHQ5TO8PMzI+xtS5mUKOlik8eno/2vcGOm8EJPd4XwtGPmNurO9DbgWEYWFeep KCcu+RGkLpT7bDFKjJAlTg3sdumvPOqmoMBBHJjosiAPvJuceH94tIvNN2XN5v+3wsGO qFkvJ4r/TGCVSwcqRw2tWzWWYo+fDlgDNxBCrCiN/5N4VLKG9K2uXgrVU9zg9USMSBhH zSAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=vFDndyt6; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s8si3885031edd.534.2021.02.04.15.37.15; Thu, 04 Feb 2021 15:37:39 -0800 (PST) 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=@kernel.org header.s=k20201202 header.b=vFDndyt6; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235142AbhBDJf3 (ORCPT + 99 others); Thu, 4 Feb 2021 04:35:29 -0500 Received: from mail.kernel.org ([198.145.29.99]:33902 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235262AbhBDJfP (ORCPT ); Thu, 4 Feb 2021 04:35:15 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id AD4EF64F51; Thu, 4 Feb 2021 09:34:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1612431274; bh=JZn0fWEQP3IOCgy3diGQCOjnTYrAIwK2aSJ/VhcnDHM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=vFDndyt6NSQFwscvlNNJUIa065sFq6KD/ieVgiNPLfJh5r4i2Na3h7tdfUt6/eyq5 qLTNDehWSqu7ChjS6c30pzr53GYt1roQYniZzM9GivjclpIqHJqknYU726isCkL+AO K0ksJUjjLxA9sF+ccYzunzBUaC352aNqGhwISRRaNZOoB0wcXiXoXz0qgXh55HFVml sCHonAfwjt1ZIIdXRn4q6Udl/4tfIdczeofFFY1mnNn3Jum9LihYqkmC5XZdOOm0BI i4uHtNAlLTbQih+2EYV5J3GhSSq9XS/yQU64zZXfV5LdIyktWczSSH1O/vED1tPXuv JFNnc4v2x3ZoA== Date: Thu, 4 Feb 2021 09:34:28 +0000 From: Will Deacon To: Marc Zyngier Cc: linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, linux-kernel@vger.kernel.org, Catalin Marinas , Mark Rutland , David Brazdil , Alexandru Elisei , Ard Biesheuvel , Jing Zhang , Ajay Patil , Prasad Sodagudi , Srinivas Ramana , James Morse , Julien Thierry , Suzuki K Poulose , kernel-team@android.com Subject: Re: [PATCH v6 06/21] arm64: Move VHE-specific SPE setup to mutate_to_vhe() Message-ID: <20210204093427.GB20244@willie-the-truck> References: <20210201115637.3123740-1-maz@kernel.org> <20210201115637.3123740-7-maz@kernel.org> <20210203211319.GA19694@willie-the-truck> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Feb 04, 2021 at 09:30:08AM +0000, Marc Zyngier wrote: > Hi Will, > > On 2021-02-03 21:13, Will Deacon wrote: > > Hi Marc, > > > > On Mon, Feb 01, 2021 at 11:56:22AM +0000, Marc Zyngier wrote: > > > There isn't much that a VHE kernel needs on top of whatever has > > > been done for nVHE, so let's move the little we need to the > > > VHE stub (the SPE setup), and drop the init_el2_state macro. > > > > > > No expected functional change. > > > > > > Signed-off-by: Marc Zyngier > > > Acked-by: David Brazdil > > > Acked-by: Catalin Marinas > > > --- > > > arch/arm64/kernel/hyp-stub.S | 28 +++++++++++++++++++++++++--- > > > 1 file changed, 25 insertions(+), 3 deletions(-) > > > > > > diff --git a/arch/arm64/kernel/hyp-stub.S > > > b/arch/arm64/kernel/hyp-stub.S > > > index 373ed2213e1d..6b5c73cf9d52 100644 > > > --- a/arch/arm64/kernel/hyp-stub.S > > > +++ b/arch/arm64/kernel/hyp-stub.S > > > @@ -92,9 +92,6 @@ SYM_CODE_START_LOCAL(mutate_to_vhe) > > > msr hcr_el2, x0 > > > isb > > > > > > - // Doesn't do much on VHE, but still, worth a shot > > > - init_el2_state vhe > > > - > > > // Use the EL1 allocated stack, per-cpu offset > > > mrs x0, sp_el1 > > > mov sp, x0 > > > @@ -107,6 +104,31 @@ SYM_CODE_START_LOCAL(mutate_to_vhe) > > > mrs_s x0, SYS_VBAR_EL12 > > > msr vbar_el1, x0 > > > > > > + // Fixup SPE configuration, if supported... > > > + mrs x1, id_aa64dfr0_el1 > > > + ubfx x1, x1, #ID_AA64DFR0_PMSVER_SHIFT, #4 > > > + mov x2, xzr > > > + cbz x1, skip_spe > > > + > > > + // ... and not owned by EL3 > > > + mrs_s x0, SYS_PMBIDR_EL1 > > > + and x0, x0, #(1 << SYS_PMBIDR_EL1_P_SHIFT) > > > + cbnz x0, skip_spe > > > + > > > + // Let the SPE driver in control of the sampling > > > + mrs_s x0, SYS_PMSCR_EL1 > > > + bic x0, x0, #(1 << SYS_PMSCR_EL2_PCT_SHIFT) > > > + bic x0, x0, #(1 << SYS_PMSCR_EL2_PA_SHIFT) > > > + msr_s SYS_PMSCR_EL1, x0 > > > > Why do we need to touch pmscr_el1 at all? The SPE driver should take > > care of > > that, no? If you drop the pmscr_el1 accesses, I think you can drop the > > pmbidr_el1 check as well. > > That's definitely a brain fart, and is what we need on the nVHE path, > not here. Doing the same thing twice isn't exactly helpful. > > > And actually, then why even check dfr0? Doing the > > bic for the mdcr_el1.e2pb bits is harmless. > > > > > + mov x2, #MDCR_EL2_TPMS > > > + > > > +skip_spe: > > > + // For VHE, use EL2 translation and disable access from EL1 > > > + mrs x0, mdcr_el2 > > > + bic x0, x0, #(MDCR_EL2_E2PB_MASK << MDCR_EL2_E2PB_SHIFT) > > > + orr x0, x0, x2 > > > + msr mdcr_el2, x0 > > > > Doesn't this undo the setting of mdcr_el2.hpmn if SPE is not present or > > unavailable? (This wouldn't be an issue if we removed the skip_spe paths > > altogether). > > I don't think it does. We only clear the E2PB bits (harmless, as you point > out above), and OR something that is either 0 (no SPE) or MDCR_EL2_TPMS. > In any case, the HPMN bits are preserved (having been set during the nVHE > setup). Duh, OR not AND. Yes, sorry. > I think the following patch addresses the above issue, which I'll squash > with the original patch. Please shout if I missed anything. > > Thanks, > > M. > > diff --git a/arch/arm64/kernel/hyp-stub.S b/arch/arm64/kernel/hyp-stub.S > index aa7e8d592295..3e08dcc924b5 100644 > --- a/arch/arm64/kernel/hyp-stub.S > +++ b/arch/arm64/kernel/hyp-stub.S > @@ -115,29 +115,9 @@ SYM_CODE_START_LOCAL(mutate_to_vhe) > mrs_s x0, SYS_VBAR_EL12 > msr vbar_el1, x0 > > - // Fixup SPE configuration, if supported... > - mrs x1, id_aa64dfr0_el1 > - ubfx x1, x1, #ID_AA64DFR0_PMSVER_SHIFT, #4 > - mov x2, xzr > - cbz x1, skip_spe > - > - // ... and not owned by EL3 > - mrs_s x0, SYS_PMBIDR_EL1 > - and x0, x0, #(1 << SYS_PMBIDR_EL1_P_SHIFT) > - cbnz x0, skip_spe > - > - // Let the SPE driver in control of the sampling > - mrs_s x0, SYS_PMSCR_EL1 > - bic x0, x0, #(1 << SYS_PMSCR_EL2_PCT_SHIFT) > - bic x0, x0, #(1 << SYS_PMSCR_EL2_PA_SHIFT) > - msr_s SYS_PMSCR_EL1, x0 > - mov x2, #MDCR_EL2_TPMS > - > -skip_spe: > - // For VHE, use EL2 translation and disable access from EL1 > + // Use EL2 translations for SPE and disable access from EL1 > mrs x0, mdcr_el2 > bic x0, x0, #(MDCR_EL2_E2PB_MASK << MDCR_EL2_E2PB_SHIFT) > - orr x0, x0, x2 > msr mdcr_el2, x0 Looks a tonne better, thanks! Be nice if somebody could test it for us. Will