Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4472178pxf; Tue, 30 Mar 2021 08:36:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJycY4B6RcTdHqR4gSNQGNKvzIHGnbaVU2pLLToKsjmO8+LpRITO3rBFb8wojhBQDeu2An0j X-Received: by 2002:a05:6402:35d3:: with SMTP id z19mr34122050edc.143.1617118607688; Tue, 30 Mar 2021 08:36:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617118607; cv=none; d=google.com; s=arc-20160816; b=f0T+PF7RIGVEtJcUM3xXfqnTnd1QrClI1LyH77Abny0qvJ/twI7nGW/8FeSiBsH7QP WIGhtnKEBBAsGDV4Y/WHzgg3JWqZABEGnKCHRBZ1PtSnWRtsQ/Zer0DRJUzc6X3P+AN3 +sYbTof/Jc0gVr/uzX2uxjMozX/ETa8hoqUYkPf3ZbmFuk5/JuEN8Feac9J+Dx9W8k39 F2BtlescZ5EFNI6gW7hQxvlgLQYxweyYacOiQV2piCAZjOStpPbZlKOcmk+m3Uwy7qvd +nGpC4ESXHteA0FMx0JHWAz48cjAjlheyVD5DriiY+E8ncf2V1qlipbz3LTr6bl782d0 vzsA== 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:dkim-signature; bh=iqChkIwvcI4/k209GnWWnKOfklFS/O3Qjl18Oans4mM=; b=md0nnltXRwrewEjuCOpTK2uM4GipDH2HYpAFvAIExpTvYCs7PgCoGUmsKV+PFwUijk nXUpZNJpDZQVBXQ9fJgeNYEjR4IjUnwGjdEhfXw+UBsZtTzOsSZy1nIeb75b40mlKd4u g0yVdxcKPRrgGQGuPEl5zMRdgmkc83G7TNxa/JgpZs5XwD3nzRUNDMAyezbpwY6xuFzk f3VQAXm6IsyK0CjMXa9WdLdsq1HsK+5VxaL8L+qUAztFwoVXczjbQyVxFRwN30hB99rC tDXolYaX7C49efHlb1/5yfDvfUj+ih7KL4g+hkgq/qvzL/tCjvIuSwdxLP/FtYCM1HjS OkPg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=gs19cNTo; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f16si16012547edj.210.2021.03.30.08.36.24; Tue, 30 Mar 2021 08:36:47 -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=@linuxfoundation.org header.s=korg header.b=gs19cNTo; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232459AbhC3Pf2 (ORCPT + 99 others); Tue, 30 Mar 2021 11:35:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:38892 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232166AbhC3PfJ (ORCPT ); Tue, 30 Mar 2021 11:35:09 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id DD213619BC; Tue, 30 Mar 2021 15:35:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1617118509; bh=VhSAKBruviPlg/vgUNyvo5P+iRjFLkrYBsb2f/d9P1Q=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=gs19cNToHr7NPbi1rFIUu2x306d0oTHp0jLIRXT7KvPlGADlfmT3Nkhq/mhA2dNsr thy3DzeoX5qEfchU83CnNO1XR6zzYrX+MECU6a5TloW/UqY2suwOUW3APrhES68uOZ e1mLN0sUXS99ZNuaX1URQbrtizCeT5wETLUl7MhY= Date: Tue, 30 Mar 2021 17:35:06 +0200 From: Greg KH To: Mathieu Poirier Cc: Suzuki K Poulose , Marc Zyngier , Catalin Marinas , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, coresight@lists.linaro.org, mike.leach@linaro.org, leo.yan@linaro.org, anshuman.khandual@arm.com, Will Deacon , Mark Rutland Subject: Re: [PATCH v5 07/19] arm64: kvm: Enable access to TRBE support for host Message-ID: References: <20210323120647.454211-1-suzuki.poulose@arm.com> <20210323120647.454211-8-suzuki.poulose@arm.com> <20210326165550.GC2009902@xps15> <20210330152314.GA2329603@xps15> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210330152314.GA2329603@xps15> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 30, 2021 at 09:23:14AM -0600, Mathieu Poirier wrote: > On Tue, Mar 30, 2021 at 11:38:18AM +0100, Suzuki K Poulose wrote: > > On 26/03/2021 16:55, Mathieu Poirier wrote: > > > On Tue, Mar 23, 2021 at 12:06:35PM +0000, Suzuki K Poulose wrote: > > > > For a nvhe host, the EL2 must allow the EL1&0 translation > > > > regime for TraceBuffer (MDCR_EL2.E2TB == 0b11). This must > > > > be saved/restored over a trip to the guest. Also, before > > > > entering the guest, we must flush any trace data if the > > > > TRBE was enabled. And we must prohibit the generation > > > > of trace while we are in EL1 by clearing the TRFCR_EL1. > > > > > > > > For vhe, the EL2 must prevent the EL1 access to the Trace > > > > Buffer. > > > > > > > > Cc: Will Deacon > > > > Cc: Catalin Marinas > > > > Cc: Marc Zyngier > > > > Cc: Mark Rutland > > > > Cc: Anshuman Khandual > > > > Acked-by: Mathieu Poirier > > > > Signed-off-by: Suzuki K Poulose > > > > --- > > > > arch/arm64/include/asm/el2_setup.h | 13 +++++++++ > > > > arch/arm64/include/asm/kvm_arm.h | 2 ++ > > > > arch/arm64/include/asm/kvm_host.h | 2 ++ > > > > arch/arm64/kernel/hyp-stub.S | 3 ++- > > > > arch/arm64/kvm/debug.c | 6 ++--- > > > > arch/arm64/kvm/hyp/nvhe/debug-sr.c | 42 ++++++++++++++++++++++++++++++ > > > > arch/arm64/kvm/hyp/nvhe/switch.c | 1 + > > > > 7 files changed, 65 insertions(+), 4 deletions(-) > > > > > > > > > > Marc - do you want me to pick up this one? > > > > I think the kvmarm tree is the best route for this patch, given the amount > > of changes the tree is going through, in the areas this patch > > touches. Or else there would be conflicts with merging. And this patch > > depends on the patches from this series that were queued. > > > > Here is the depency tree : > > > > a) kvm-arm fixes for debug (Patch 1, 2) & SPE save-restore fix (queued in > > v5.12-rc3) > > > > b) TRBE defintions and Trace synchronization barrier (Patches 5 & 6) > > > > c) kvm-arm TRBE host support (Patch 7) > > > > d) TRBE driver support (and the ETE changes) > > > > > > (c) code merge depends on -> (a) + (b) > > (d) build (no conflicts) depends on -> (b) > > > > > > Now (d) has an indirect dependency on (c) for operational correctness at > > runtime. > > So, if : > > > > kvmarm tree picks up : b + c > > coresight tree picksup : b + d > > > > and if we could ensure the merge order of the trees are in > > kvmarm > > greg-kh (device-misc tree) (coresight goes via this tree) > > > > Greg's char-misc tree is based on the rc releases rather than next. As such it > is a while before other branches like kvmarm get merged, causing all sort of > compilation breakage. My tree can not be based on -next, and neither can any other maintainer's tree, as next is composed of maintainer trees :) > > we should be fine. > > > > Additionally, we could rip out the Kconfig changes from the TRBE patch > > and add it only at the rc1, once we verify both the trees are in to make > > sure the runtime operation dependency is not triggered. > > > > We could also do that but Greg might frown at the tactic, and rightly so. The > usual way to work with complex merge dependencies is to proceed in steps, which > would mean that all KVM related patches go in the v5.13 merge window. When that > is done we add the ETE/TRBE for the v5.14 merge window. I agree that we waste > an entire cycle but it guarantees to avoid breaking builds and follows the > conventional way to do things. Or someone creates a single branch with a signed tag and it gets pulled into multiple maintainer's trees and never rebased. We've done that lots of time, nothing new there. Or everything goes through one tree, or you wait a release cycle. You have 3 choices, pick one :) thanks, greg k-h