Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3023pxb; Thu, 14 Oct 2021 22:20:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw6M/+vRzh/UjRUMtmCGXXNSdsNKeiy5gqV37uunKG+PRdC6DcnLtGwsyfd8NLuane7lIld X-Received: by 2002:a17:90b:4d08:: with SMTP id mw8mr1949903pjb.96.1634275257292; Thu, 14 Oct 2021 22:20:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634275257; cv=none; d=google.com; s=arc-20160816; b=tGFvu5QfgV+oJzxMFqOT80/YQTJBRmbp7uBVCO/dsfy2FbXohpoGwpRaRrLCTo1xiX vteaSJUO8AEqGoBm0LMUmcnt4kM96gVyNXPthKOUmGQm2ClKKGRM7qplHXtZ6OkhRR4f XlGyFKMS5fWi0ymzfgw4YzFki1BTLcDE7umD9Je0ByBpfcP1geHq7We8WCrBjo/dSvzm 42dEBOrgwNt4M8rgqcxwntHkXVmMSgh8C7yUq0xKFffDktX9Ctr/KsVGyTp+5dX/Vp1m YghqWDMbVz1GDRb/1eJoi9zptXMaXNvz0C4QDL6Dq2d/WjCAZkA3qxbKBFWSXWaWa3wm LYjA== 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=Fsv+k4+M14EYM2S2Lp3UMZsdhGsCtFW1Ay2NrtPCrFY=; b=U8uLkBnRo0iwdnSFZcJGcn+0Umoz85n0Xtsd5wMQvCbQqrH80icW7wSf5M8AA4ltVh EhgEOGxWI9xx0qN90JfPQmDIzTa9cVNaUt9GPPRv0fkN1wptpTXipJM0lfTMQ2I+23O6 9AfP3AKL9ZrO5UlcIjUjNoRLRg2uPmxmBaa6gWn8RA34bQtsmJroVgym90qOm78hp15b rPlm9yuJi4q15H06B1xmrBzLKsBBZYguLrUKkRr8Da6ByLm4X/8R8YUzx2N0EBXjBF4A kilL6iZqfigwjhAOQGLp4oHWmJcYpd6s4atlex7DW0/vg5fxxStMXYDK6yHHaGMglTl7 HpCA== 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 a2si6930886pgt.382.2021.10.14.22.19.49; Thu, 14 Oct 2021 22:20:57 -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 S234243AbhJNWeA (ORCPT + 99 others); Thu, 14 Oct 2021 18:34:00 -0400 Received: from foss.arm.com ([217.140.110.172]:60994 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234251AbhJNWdx (ORCPT ); Thu, 14 Oct 2021 18:33:53 -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 E5AE214BF; Thu, 14 Oct 2021 15:31:47 -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 7A9C53F694; Thu, 14 Oct 2021 15:31:46 -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 v5 07/15] coresight: trbe: Decouple buffer base from the hardware base Date: Thu, 14 Oct 2021 23:31:17 +0100 Message-Id: <20211014223125.2605031-8-suzuki.poulose@arm.com> X-Mailer: git-send-email 2.25.4 In-Reply-To: <20211014223125.2605031-1-suzuki.poulose@arm.com> References: <20211014223125.2605031-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 3de03136285f..58796ff425a4 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