Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp625038pxb; Tue, 19 Oct 2021 09:35:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwD1X5BhB1fYDO+K7pzACeJK4sJAa9S1ujB9qgKDCLQgPQzwXpgZ5lHqGnteEqMEPxLTZxR X-Received: by 2002:a63:9358:: with SMTP id w24mr13031327pgm.435.1634661323746; Tue, 19 Oct 2021 09:35:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634661323; cv=none; d=google.com; s=arc-20160816; b=Lmxo1D7qitok1Der7SD+FstzDvJXPmxqcnfh0DcCO11UE0DqXBlTGlWfUy08IInyPX quyjKzm65PYqlQY42BYTTKP8s39ogD4U0sxYd+3H2vW1gbguu5ZNe+t5hqhrIS1wN3fe A81bh5vqnoyxJzZuhP4/oXzD03JYfJ3wHmuli00xWuaJxI9wxA0u+5VkJP/vo5hzH5bF W0m5S7bzunR3QXP8Rnb3d+Wlrp12vOPFNlYfoj5TZiJ/VCyrwcm7E+IYg8jz2tZ6WJgt f8jOH4f9UloK7Rl6kX02b8WMmNd8XYLWoW0E5ufC79052+dGwJekTRxnImNvZEDjGa5a VQzw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=yJZMLHPJEFK7SjhG2JxXM0AJ6sTXfYiRsWHoNTwEcro=; b=We8rAxR3P4D3MCLkDZ8qLrY3vT0aQAm/fZ43kifuS+KtVM9ev361B8esSy8YbPsxrJ R4GLZfK5eNJg6u16grG05DgFwRlbI2kdten3gsJViz/QpD97ot6U+3TNGBdMRcyJyP4V HHhyblpWK91YBYmiO84b6q0XISSFN2LxHNmPMYTatZ02OA0sNYiIiho2dt/u4G1VTBIR +HdBgWuHg560x0DJt5BM9rFwyiIWzb5NlYGR4zfxBPaozLGJktrMfKsVGpjpwaHnQJfU erHvomAx1s2pm4mPksiPSsZFpAFAt0DhFJf+KnVDJnDasE53X+d8Ff+hEojDRBPkHnod SJHg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ng10si3929007pjb.86.2021.10.19.09.35.11; Tue, 19 Oct 2021 09:35:23 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234504AbhJSQft (ORCPT + 99 others); Tue, 19 Oct 2021 12:35:49 -0400 Received: from foss.arm.com ([217.140.110.172]:51636 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234476AbhJSQfh (ORCPT ); Tue, 19 Oct 2021 12:35:37 -0400 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 7A57D2F; Tue, 19 Oct 2021 09:33:24 -0700 (PDT) Received: from ewhatever.cambridge.arm.com (ewhatever.cambridge.arm.com [10.1.197.1]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 100E53F694; Tue, 19 Oct 2021 09:33:22 -0700 (PDT) From: Suzuki K Poulose To: will@kernel.org, mathieu.poirier@linaro.org Cc: catalin.marinas@arm.com, anshuman.khandual@arm.com, mike.leach@linaro.org, leo.yan@linaro.org, maz@kernel.org, coresight@lists.linaro.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Suzuki K Poulose Subject: [PATCH v6 07/15] coresight: trbe: Decouple buffer base from the hardware base Date: Tue, 19 Oct 2021 17:31:45 +0100 Message-Id: <20211019163153.3692640-8-suzuki.poulose@arm.com> X-Mailer: git-send-email 2.25.4 In-Reply-To: <20211019163153.3692640-1-suzuki.poulose@arm.com> References: <20211019163153.3692640-1-suzuki.poulose@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We always set the TRBBASER_EL1 to the base of the virtual ring buffer. We are about to change this for working around an erratum. So, in preparation to that, allow the driver to choose a different base for the TRBBASER_EL1 (which is within the buffer range). Cc: Anshuman Khandual Cc: Mike Leach Cc: Mathieu Poirier Cc: Leo Yan Reviewed-by: Anshuman Khandual Reviewed-by: Mathieu Poirier Signed-off-by: Suzuki K Poulose --- drivers/hwtracing/coresight/coresight-trbe.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/drivers/hwtracing/coresight/coresight-trbe.c b/drivers/hwtracing/coresight/coresight-trbe.c index e3767f21ee68..ae0bde9630f6 100644 --- a/drivers/hwtracing/coresight/coresight-trbe.c +++ b/drivers/hwtracing/coresight/coresight-trbe.c @@ -57,6 +57,8 @@ struct trbe_buf { * trbe_limit sibling pointers. */ unsigned long trbe_base; + /* The base programmed into the TRBE */ + unsigned long trbe_hw_base; unsigned long trbe_limit; unsigned long trbe_write; int nr_pages; @@ -470,12 +472,13 @@ static void set_trbe_limit_pointer_enabled(unsigned long addr) static void trbe_enable_hw(struct trbe_buf *buf) { - WARN_ON(buf->trbe_write < buf->trbe_base); + WARN_ON(buf->trbe_hw_base < buf->trbe_base); + WARN_ON(buf->trbe_write < buf->trbe_hw_base); WARN_ON(buf->trbe_write >= buf->trbe_limit); set_trbe_disabled(); isb(); clr_trbe_status(); - set_trbe_base_pointer(buf->trbe_base); + set_trbe_base_pointer(buf->trbe_hw_base); set_trbe_write_pointer(buf->trbe_write); /* @@ -520,7 +523,12 @@ static unsigned long trbe_get_trace_size(struct perf_output_handle *handle, else write = get_trbe_write_pointer(); - end_off = write - get_trbe_base_pointer(); + /* + * TRBE may use a different base address than the base + * of the ring buffer. Thus use the beginning of the ring + * buffer to compute the offsets. + */ + end_off = write - buf->trbe_base; start_off = PERF_IDX2OFF(handle->head, buf); if (WARN_ON_ONCE(end_off < start_off)) @@ -678,6 +686,8 @@ static int __arm_trbe_enable(struct trbe_buf *buf, trbe_stop_and_truncate_event(handle); return -ENOSPC; } + /* Set the base of the TRBE to the buffer base */ + buf->trbe_hw_base = buf->trbe_base; *this_cpu_ptr(buf->cpudata->drvdata->handle) = handle; trbe_enable_hw(buf); return 0; @@ -771,7 +781,7 @@ static bool is_perf_trbe(struct perf_output_handle *handle) struct trbe_drvdata *drvdata = cpudata->drvdata; int cpu = smp_processor_id(); - WARN_ON(buf->trbe_base != get_trbe_base_pointer()); + WARN_ON(buf->trbe_hw_base != get_trbe_base_pointer()); WARN_ON(buf->trbe_limit != get_trbe_limit_pointer()); if (cpudata->mode != CS_MODE_PERF) -- 2.25.4