Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp704999rwl; Wed, 29 Mar 2023 07:27:48 -0700 (PDT) X-Google-Smtp-Source: AKy350buPjq5bUCJbQsGVt59yXSyYU2cTJR7DxMuBP6RlQU5aTDG7JtoyUxrYEYl4ZJyNZ3ld6qm X-Received: by 2002:a17:906:b198:b0:8f6:88b7:73a7 with SMTP id w24-20020a170906b19800b008f688b773a7mr2178567ejy.7.1680100068181; Wed, 29 Mar 2023 07:27:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680100068; cv=none; d=google.com; s=arc-20160816; b=ls01ndcDBFohFzYcP57ZIYy8EBty9BlUl6KEUJDjLqzkctsv0rvGCKIwTgjFsRvN4Q haEhHt6iB5zJKmxXLQIxFc2txIZa/cJCIp+R6QjqaiiQUBlgGOegNjupvcm0Tr9qvFbi vuzGqT8NxY7mf3IqvTZJBP1vURi8exwJ+j3ja4VqFfS90c4L3wNkFjv1k7vzzZ2sn7Ou i7wBpErEpEiCb7zsLSFMd7mkSQOHHqkmaGaoO8H4ciuawj1PX4/uBn4F7IbZEpiAuO5z 8fMadmGEYRvpkeK5fg2Bt401RbBWeyyCe3JjivXVdtDBhC7ZeimkEtKQfi3ZmNN5YrnT mrgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=copWWF1Y+A8/Q5Sx3Zj/WMeS5LuOxXbAOzngQLKvPww=; b=0pZRLBmQDYhxR/ss3pJosJ5594C+4o1ChLbjZd0Daj5QWcjhI6TOYCHRDTu7p3bKpy TPZT/1/1cbQs8wcTcf1JbFBFIiFVKtVwY1rb8ewN9zabd63dbwFut7HCS6WtBx2Y5++6 /FqFjBW6vG4tb19NEECpRzhqzt1LyBem/VUQkB1DVJwkD4tw9j/A+8ek6WNqRFpmF5gs pWm2HiA0HbPMZeRX0rDqv+1CVfKT1raIRRNjUhdO3CgkFsz/1mLS6zpKGlKrCD1Bryhj 6zqIrMEA7cobb0llU0RzMrpDMXFRLURWdMA0ZzlPW2LySAVQ3ez7rKAfXvPMVFitiLlz UGPg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z16-20020a170906945000b0093dd2150283si14744513ejx.715.2023.03.29.07.27.23; Wed, 29 Mar 2023 07:27:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S229803AbjC2OZi (ORCPT + 99 others); Wed, 29 Mar 2023 10:25:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36426 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231441AbjC2OXQ (ORCPT ); Wed, 29 Mar 2023 10:23:16 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 9890259E6 for ; Wed, 29 Mar 2023 07:16:53 -0700 (PDT) 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 E65941FB; Wed, 29 Mar 2023 07:11:23 -0700 (PDT) Received: from [10.57.19.106] (unknown [10.57.19.106]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 4336E3F663; Wed, 29 Mar 2023 07:10:38 -0700 (PDT) Message-ID: <0c612e58-9b1e-34fd-9665-842754fb5fdd@arm.com> Date: Wed, 29 Mar 2023 15:10:36 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 Subject: Re: [PATCH v2 8/9] coresight: Enable and disable helper devices adjacent to the path Content-Language: en-US To: Suzuki K Poulose , coresight@lists.linaro.org Cc: Mathieu Poirier , Mike Leach , Leo Yan , Alexander Shishkin , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <20230310160610.742382-1-james.clark@arm.com> <20230310160610.742382-9-james.clark@arm.com> <303e295e-0bdb-c771-3756-ca4c81b4c600@arm.com> From: James Clark In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.3 required=5.0 tests=NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29/03/2023 14:23, Suzuki K Poulose wrote: > On 29/03/2023 13:04, James Clark wrote: >> >> >> On 17/03/2023 11:04, Suzuki K Poulose wrote: >>> On 10/03/2023 16:06, James Clark wrote: >>>> Currently CATU is the only helper device, and its enable and disable >>>> calls are hard coded. To allow more helper devices to be added in a >>>> generic way, remove these hard coded calls and just enable and disable >>>> all helper devices. >>>> >>>> This has to apply to helpers adjacent to the path, because they will >>>> never be in the path. CATU was already discovered in this way, so >>>> there is no change there. >>>> >>>> One change that is needed is for CATU to call back into ETR to allocate >>>> the buffer. Because the enable call was previously hard coded, it was >>>> done at a point where the buffer was already allocated, but this is no >>>> longer the case. >>>> >>>> Signed-off-by: James Clark >>>> --- >>>>    drivers/hwtracing/coresight/coresight-catu.c  | 34 ++++++++-- >>>>    drivers/hwtracing/coresight/coresight-core.c  | 68 >>>> ++++++++++++++++++- >>>>    .../hwtracing/coresight/coresight-tmc-etr.c   | 28 -------- >>>>    include/linux/coresight.h                     |  3 +- >>>>    4 files changed, 99 insertions(+), 34 deletions(-) >>>> >>>> diff --git a/drivers/hwtracing/coresight/coresight-catu.c >>>> b/drivers/hwtracing/coresight/coresight-catu.c >>>> index bc90a03f478f..24a08a2b96b1 100644 >>>> --- a/drivers/hwtracing/coresight/coresight-catu.c >>>> +++ b/drivers/hwtracing/coresight/coresight-catu.c >>>> @@ -395,13 +395,32 @@ static inline int catu_wait_for_ready(struct >>>> catu_drvdata *drvdata) >>>>        return coresight_timeout(csa, CATU_STATUS, CATU_STATUS_READY, >>>> 1); >>>>    } >>>>    -static int catu_enable_hw(struct catu_drvdata *drvdata, void *data) >>>> +static struct coresight_device * >>>> +catu_get_etr_device(struct coresight_device *csdev) >>>> +{ >>>> +    int i; >>>> +    struct coresight_device *tmp; >>>> + >>>> +    for (i = 0; i < csdev->pdata->nr_inconns; i++) { >>>> +        tmp = csdev->pdata->in_conns[i].remote_dev; >>>> +        if (tmp && tmp->type == CORESIGHT_DEV_TYPE_SINK && >>>> +            tmp->subtype.sink_subtype == >>>> +                CORESIGHT_DEV_SUBTYPE_SINK_SYSMEM) >>>> +            return tmp; >>>> +    } >>>> + >>>> +    return NULL; >>>> +} >>>> + >>>> +static int catu_enable_hw(struct catu_drvdata *drvdata, enum cs_mode >>>> cs_mode, >>>> +              void *data) >>>>    { >>>>        int rc; >>>>        u32 control, mode; >>>> -    struct etr_buf *etr_buf = data; >>>> +    struct etr_buf *etr_buf = NULL; >>>>        struct device *dev = &drvdata->csdev->dev; >>>>        struct coresight_device *csdev = drvdata->csdev; >>>> +    struct coresight_device *etrdev; >>>>          if (catu_wait_for_ready(drvdata)) >>>>            dev_warn(dev, "Timeout while waiting for READY\n"); >>>> @@ -416,6 +435,12 @@ static int catu_enable_hw(struct catu_drvdata >>>> *drvdata, void *data) >>>>        if (rc) >>>>            return rc; >>>>    +    etrdev = catu_get_etr_device(csdev); >>>> +    if (etrdev) { >>>> +        etr_buf = tmc_etr_get_buffer(etrdev, cs_mode, data); >>>> +        if (IS_ERR(etr_buf)) >>>> +            return PTR_ERR(etr_buf); >>>> +    } >>> >>> WARN_ON(!etrdev) ? We are not supposed to reach in the first place and >>> return. >>> >> >> I saw there was the pass-through mode below which I thought didn't need >> an ETR device. I think I followed the code through and there was a way >> for it to get there without an ETR in the existing version, but now I'm >> not sure. > > >> Or does it still need the ETR device but it just doesn't >> access the buffer? > > The first part is correct. Without an ETR, CATU wouldn't be a helper > device, and wouldn't get here in "enable CATU" via the helper route. > The CATU chooses the mode depending on the etr_buf mode. Ok thanks I will add that warning then > > > Suzuki >