From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.8 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4E4A4C433FE for ; Fri, 11 Dec 2020 21:33:30 +0000 (UTC) Received: from merlin.infradead.org (merlin.infradead.org [205.233.59.134]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 007C022B47 for ; Fri, 11 Dec 2020 21:33:29 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 007C022B47 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=linaro.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Transfer-Encoding: Content-Type:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References:Message-ID: Subject:To:From:Date:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=OSuruxpgO/chZndSJZLV421b62IyeGA9teHjE+GE/qM=; b=syCplbyF9mOP1ue7fLoUoPvbU WI0tsrwWHmF7NsrcHBVyHXMqcPkZ0KiwJrd9O35E/XikzyZXxNSdeuEoI016wceD5yHe8qDQAv/dz 9U5SQ8kDYDzWElLZTjjxEbWwBsd9xJ0f/bbqmVzSbOCD3YyOldOxGPzG+RxQ3DeiluFH9L1ZQwlO5 E6l1xKu+a50X6cbtnQYwkiX03dr1P5/xprgbjRhFq1e2PIcrRlmmlxdDCemOxHpIpUXLvQnNhuQUV bGUJaoK19qzTXoBi6jrPM8dL1sUq1IW8b8HhC3gOS2ZRXWcsmLf2IdvRDHzyKpBuW+jffWyjsWYtA NBZpEJUew==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1knq11-0006lM-8O; Fri, 11 Dec 2020 21:31:51 +0000 Received: from mail-pg1-x543.google.com ([2607:f8b0:4864:20::543]) by merlin.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1knq0x-0006kn-Py for linux-arm-kernel@lists.infradead.org; Fri, 11 Dec 2020 21:31:48 +0000 Received: by mail-pg1-x543.google.com with SMTP id 143so1906603pge.10 for ; Fri, 11 Dec 2020 13:31:45 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=wOwudKi3c/sJJmdZte/owFpzWQE+oWQgZXymuZLUvFE=; b=fJ8vb9k5d5ih0Ew/8e6GpgyPz/qH+VxR4hoto6jF1IdyGvPy2r048XRP1tEl+SprVO RCfnP8Jq6xwT27xKmqPOhXzMEmutB4HMgxUlrtf00O1vO693bdvHnZIl2mJp8K65IYpD J/9eDXt9AKmEC4h3CPQX2e9FnsZufUcslge4k9M1vwQNoM41E28Ydt4377hdqJ9Mp0IC IjXmdm8QWgfabGs5QtZnb1p65jsdrXwUdvU5gYbj3+QbvcZ1b4Q9xsGXSzDc+aWeL/Uk jdb0RnaGO4VKNeSUdY5wTq+DEi1eplaeeItyr8WJQ9wbgd4YkjCEsz/nN6iMTXRXdToI 894g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=wOwudKi3c/sJJmdZte/owFpzWQE+oWQgZXymuZLUvFE=; b=FJCwLmAVh8dUS4uZhP5LZmZjNFn4fB0uD7lK3JFv//pXKtZ/SyK6N6CGamwKPmjUfv CrZKjaWWEo6UU7K9aypO05nYBomPDnYdTo3l5cgqKx7qf3kOY8ncSfi1bPsF71OhkJ6l cvzVvMW5Xi1IzKtcITLusJDD8R1gyb2cIGCf2ltgKucdFL7nEpjDqVC1YTe2AMeYS5my LzjdtkfQRuiZpsd7Qnsqa+so+ZS6K4qeTSsmVqcsGwSUuKUzCpapVs5xI/rJwdJbC8zE E6yHR0lMA/CyvveVEMRwl4Go8fz8ESZ1adtD8/uIm+gzylmy0DUfbYDBE/boTmcjhhpw OZRg== X-Gm-Message-State: AOAM531N5m2BJOkR5ElTznOJACIRQ70XzIQayjEu5/l2OaLG4OHXWgc7 Sgp8JXi16wluLtqV33gqVHcL2BodwP2Vx4Q3 X-Google-Smtp-Source: ABdhPJzJU2ztbjBhJlS4dJPQ3mPqooHfOZ+TprKJpG+UBUYRmhLms2GXHxkjbUYWo3Yz6kMa+EfEfg== X-Received: by 2002:a62:1a56:0:b029:19d:b6eb:291a with SMTP id a83-20020a621a560000b029019db6eb291amr13615938pfa.10.1607722303664; Fri, 11 Dec 2020 13:31:43 -0800 (PST) Received: from xps15 (S0106889e681aac74.cg.shawcable.net. [68.147.0.187]) by smtp.gmail.com with ESMTPSA id a141sm11447988pfa.189.2020.12.11.13.31.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Dec 2020 13:31:42 -0800 (PST) Date: Fri, 11 Dec 2020 14:31:41 -0700 From: Mathieu Poirier To: Anshuman Khandual Subject: Re: [RFC 10/11] coresgith: etm-perf: Connect TRBE sink with ETE source Message-ID: <20201211213141.GB1921322@xps15> References: <1605012309-24812-1-git-send-email-anshuman.khandual@arm.com> <1605012309-24812-11-git-send-email-anshuman.khandual@arm.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <1605012309-24812-11-git-send-email-anshuman.khandual@arm.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20201211_163147_941161_2022F8E6 X-CRM114-Status: GOOD ( 29.16 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: coresight@lists.linaro.org, mike.leach@linaro.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, suzuki.poulose@arm.com Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org On Tue, Nov 10, 2020 at 06:15:08PM +0530, Anshuman Khandual wrote: > Unlike traditional sink devices, individual TRBE instances are not detected > via DT or ACPI nodes. Instead TRBE instances are detected during CPU online > process. Hence a path connecting ETE and TRBE on a given CPU would not have > been established until then. This adds two coresight helpers that will help > modify outward connections from a source device to establish and terminate > path to a given sink device. But this method might not be optimal and would > be reworked later. > > Signed-off-by: Anshuman Khandual > --- > drivers/hwtracing/coresight/coresight-etm-perf.c | 30 ++++++++++++++++++++++++ > drivers/hwtracing/coresight/coresight-etm-perf.h | 4 ++++ > drivers/hwtracing/coresight/coresight-platform.c | 3 ++- > drivers/hwtracing/coresight/coresight-trbe.c | 2 ++ > include/linux/coresight.h | 2 ++ > 5 files changed, 40 insertions(+), 1 deletion(-) > > diff --git a/drivers/hwtracing/coresight/coresight-etm-perf.c b/drivers/hwtracing/coresight/coresight-etm-perf.c > index 1a37991..b4ab1d4 100644 > --- a/drivers/hwtracing/coresight/coresight-etm-perf.c > +++ b/drivers/hwtracing/coresight/coresight-etm-perf.c > @@ -664,3 +664,33 @@ void __exit etm_perf_exit(void) > { > perf_pmu_unregister(&etm_pmu); > } > + > +#ifdef CONFIG_CORESIGHT_TRBE > +void coresight_trbe_connect_ete(struct coresight_device *csdev_trbe, int cpu) > +{ > + struct coresight_device *csdev_ete = per_cpu(csdev_src, cpu); As Suzuki pointed out that won't work if the TRBE gets probed before the ETMv4-ETE. I also agree with Suzuki this situation should be better handled with a per csdev_trbe that should be declared in the coresight-core.c file. That way both sysfs and perf have access to it. > + > + if (!csdev_ete) { > + pr_err("Corresponding ETE device not present on cpu %d\n", cpu); > + return; > + } > + csdev_ete->def_sink = csdev_trbe; That should be done in function coresight_find_default_sink(). If per_cpu(csdev_trbe, cpu) exists then that's the what we pick. If not then move along with coresight_find_sink(). > + csdev_ete->pdata->nr_outport++; > + if (!csdev_ete->pdata->conns) > + coresight_alloc_conns(&csdev_ete->dev, csdev_ete->pdata); > + csdev_ete->pdata->conns[csdev_ete->pdata->nr_outport - 1].child_dev = csdev_trbe; I don't think we have to go through all that dance since the TRBE is directly connected to the ETE. With the above about coresight_find_default_sink() in mind, all we need to do is fix coresight_build_path() to check if the sink parameter is the same as csdev->def_sink. If so then just add the sink to the patch, no need to follow ports as we do for other classic components. Thanks, Mathieu > +} > + > +void coresight_trbe_remove_ete(struct coresight_device *csdev_trbe, int cpu) > +{ > + struct coresight_device *csdev_ete = per_cpu(csdev_src, cpu); > + > + if (!csdev_ete) { > + pr_err("Corresponding ETE device not present on cpu %d\n", cpu); > + return; > + } > + csdev_ete->pdata->conns[csdev_ete->pdata->nr_outport - 1].child_dev = NULL; > + csdev_ete->def_sink = NULL; > + csdev_ete->pdata->nr_outport--; > +} > +#endif > diff --git a/drivers/hwtracing/coresight/coresight-etm-perf.h b/drivers/hwtracing/coresight/coresight-etm-perf.h > index 3e4f2ad..20386cf 100644 > --- a/drivers/hwtracing/coresight/coresight-etm-perf.h > +++ b/drivers/hwtracing/coresight/coresight-etm-perf.h > @@ -85,4 +85,8 @@ static inline void *etm_perf_sink_config(struct perf_output_handle *handle) > int __init etm_perf_init(void); > void __exit etm_perf_exit(void); > > +#ifdef CONFIG_CORESIGHT_TRBE > +void coresight_trbe_connect_ete(struct coresight_device *csdev, int cpu); > +void coresight_trbe_remove_ete(struct coresight_device *csdev, int cpu); > +#endif > #endif > diff --git a/drivers/hwtracing/coresight/coresight-platform.c b/drivers/hwtracing/coresight/coresight-platform.c > index c594f45..8fa7406 100644 > --- a/drivers/hwtracing/coresight/coresight-platform.c > +++ b/drivers/hwtracing/coresight/coresight-platform.c > @@ -23,7 +23,7 @@ > * coresight_alloc_conns: Allocate connections record for each output > * port from the device. > */ > -static int coresight_alloc_conns(struct device *dev, > +int coresight_alloc_conns(struct device *dev, > struct coresight_platform_data *pdata) > { > if (pdata->nr_outport) { > @@ -35,6 +35,7 @@ static int coresight_alloc_conns(struct device *dev, > > return 0; > } > +EXPORT_SYMBOL_GPL(coresight_alloc_conns); > > static struct device * > coresight_find_device_by_fwnode(struct fwnode_handle *fwnode) > diff --git a/drivers/hwtracing/coresight/coresight-trbe.c b/drivers/hwtracing/coresight/coresight-trbe.c > index 48a8ec3..afd1a1c 100644 > --- a/drivers/hwtracing/coresight/coresight-trbe.c > +++ b/drivers/hwtracing/coresight/coresight-trbe.c > @@ -507,6 +507,7 @@ static void arm_trbe_probe_coresight_cpu(void *info) > if (IS_ERR(cpudata->csdev)) > goto cpu_clear; > > + coresight_trbe_connect_ete(cpudata->csdev, cpudata->cpu); > dev_set_drvdata(&cpudata->csdev->dev, cpudata); > cpudata->trbe_dbm = get_trbe_flag_update(); > cpudata->trbe_align = 1ULL << get_trbe_address_align(); > @@ -586,6 +587,7 @@ static int arm_trbe_cpu_teardown(unsigned int cpu, struct hlist_node *node) > > if (cpumask_test_cpu(cpu, &drvdata->supported_cpus)) { > cpudata = per_cpu_ptr(drvdata->cpudata, cpu); > + coresight_trbe_remove_ete(cpudata->csdev, cpu); > if (cpudata->csdev) { > coresight_unregister(cpudata->csdev); > cpudata->drvdata = NULL; > diff --git a/include/linux/coresight.h b/include/linux/coresight.h > index c2d0a2a..c657813 100644 > --- a/include/linux/coresight.h > +++ b/include/linux/coresight.h > @@ -496,6 +496,8 @@ void coresight_relaxed_write64(struct coresight_device *csdev, > u64 val, u32 offset); > void coresight_write64(struct coresight_device *csdev, u64 val, u32 offset); > > +int coresight_alloc_conns(struct device *dev, > + struct coresight_platform_data *pdata); > > #else > static inline struct coresight_device * > -- > 2.7.4 > _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel