Received: by 2002:a05:7412:8598:b0:f9:33c2:5753 with SMTP id n24csp512682rdh; Tue, 19 Dec 2023 05:59:47 -0800 (PST) X-Google-Smtp-Source: AGHT+IEA5OuOnOpXPvdQ5W0iCZJgkqRtwjbuC+CkISHypVST622Ca2PNvm5Ppuj9kdbyQLgBxENH X-Received: by 2002:a05:620a:1916:b0:77f:a663:f879 with SMTP id bj22-20020a05620a191600b0077fa663f879mr1859535qkb.26.1702994387547; Tue, 19 Dec 2023 05:59:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702994387; cv=none; d=google.com; s=arc-20160816; b=zr5SNWn0/ZZSARF4S8ErnPw+AS/VF5TQ252Uvp/WEvbDRJQk6G4DFJm+u/Fxny+xk3 GBac6+iilLZlzyE4iPgc0t7biV2l9oHaDi+dL9u7uiX28DQd5GK+01u/d0xXStaY+45t jqISeLHiDfpl6BWoNY37WQ6MPC2UyGePjRvrpuA8BAU4VM2i5+QTqf+4nwgMFcW/sVTM JRo404iMLwqlFNaN5BasgWyXUSeCRGHNC9iUR8wU1kFfdtj5ltsxQmPmVq4aYFRPMJH+ QjMd2vFZKXYLNJYP02EbEmfPY6otphYMIX86kk2zwFWuTpS9bqim9f/pOaf8WRQG5Nsi BEtw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:references:cc:to:from :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=Ub8ZvcPWaOudXqXpHGc7SxxbXLrUd9pj3qKRi9YcdBU=; fh=VVn1or143ocJn81UN5C70YFisJoYbLqtg4Us8PNvf4I=; b=nBWsmznD7e6MPbp1Fiw6hGwWVhn/kYYYy+tbai45Qs2y/KDhsHyG3KlAbN6jbZ30PC wsnD/70HJeg4vcqHBWSImulq+PuTNpvMnIBgHzo3xydFqnzOH8bZ2bzcD507B3o4ID+5 oYTmXodp8YOt4+kC6ynHnmf/cIaAFnuHilvFLlh+H9XP0u7pxT0EaQfLA010NLQXk8h0 TcQWZrcHI6v/IO1ccMKmb0wRNqJCdMUxyw7WCVpkYNpUvKPk/lyz7MPK9hQwQsS+dwut xfqUkNJ6A5seWdifLGAtvhdfIx6oA23Ixfh68HieQ0RLas+qM1SyhWFVs2NN0CP+VdPf 66rQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-5298-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5298-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id o20-20020a05620a2a1400b0077da9bb98a7si22129909qkp.347.2023.12.19.05.59.47 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Dec 2023 05:59:47 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-5298-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-5298-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5298-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 439E51C21BF9 for ; Tue, 19 Dec 2023 13:59:47 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 1EC6A1A72B; Tue, 19 Dec 2023 13:59:38 +0000 (UTC) X-Original-To: linux-kernel@vger.kernel.org Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CCAEE1A58F; Tue, 19 Dec 2023 13:59:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com 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 4B96E1FB; Tue, 19 Dec 2023 06:00:18 -0800 (PST) Received: from [10.57.46.64] (unknown [10.57.46.64]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 75B113F5A1; Tue, 19 Dec 2023 05:59:31 -0800 (PST) Message-ID: <987a101d-043e-4893-89c0-f9fcd46b5aeb@arm.com> Date: Tue, 19 Dec 2023 13:59:30 +0000 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v3 2/8] coresight-tpda: Add support to configure CMB element Content-Language: en-GB From: Suzuki K Poulose To: Tao Zhang , Mathieu Poirier , Alexander Shishkin , Konrad Dybcio , Mike Leach , Rob Herring , Krzysztof Kozlowski Cc: Jinlong Mao , Leo Yan , Greg Kroah-Hartman , coresight@lists.linaro.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Tingwei Zhang , Yuanfang Zhang , Trilok Soni , Song Chai , linux-arm-msm@vger.kernel.org, andersson@kernel.org References: <1700533494-19276-1-git-send-email-quic_taozha@quicinc.com> <1700533494-19276-3-git-send-email-quic_taozha@quicinc.com> <88e51407-344e-4584-8711-29cc014c782b@arm.com> In-Reply-To: <88e51407-344e-4584-8711-29cc014c782b@arm.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 18/12/2023 10:27, Suzuki K Poulose wrote: > On 21/11/2023 02:24, Tao Zhang wrote: >> Read the CMB element size from the device tree. Set the register >> bit that controls the CMB element size of the corresponding port. >> >> Signed-off-by: Tao Zhang >> Signed-off-by: Mao Jinlong >> --- >>   drivers/hwtracing/coresight/coresight-tpda.c | 117 +++++++++++-------- >>   drivers/hwtracing/coresight/coresight-tpda.h |   6 + >>   2 files changed, 74 insertions(+), 49 deletions(-) >> >> diff --git a/drivers/hwtracing/coresight/coresight-tpda.c >> b/drivers/hwtracing/coresight/coresight-tpda.c >> index 5f82737c37bb..e3762f38abb3 100644 >> --- a/drivers/hwtracing/coresight/coresight-tpda.c >> +++ b/drivers/hwtracing/coresight/coresight-tpda.c >> @@ -28,24 +28,54 @@ static bool coresight_device_is_tpdm(struct >> coresight_device *csdev) >>               CORESIGHT_DEV_SUBTYPE_SOURCE_TPDM); >>   } >> +static void tpdm_clear_element_size(struct coresight_device *csdev) >> +{ >> +    struct tpda_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); >> + >> +    if (drvdata->dsb_esize) >> +        drvdata->dsb_esize = 0; >> +    if (drvdata->cmb_esize) >> +        drvdata->cmb_esize = 0; > > Why do we need the if (...) check here ? > >> +} >> + >> +static void tpda_set_element_size(struct tpda_drvdata *drvdata, u32 >> *val) >> +{ >> + >> +    if (drvdata->dsb_esize == 64) >> +        *val |= TPDA_Pn_CR_DSBSIZE; >> +    else if (drvdata->dsb_esize == 32) >> +        *val &= ~TPDA_Pn_CR_DSBSIZE; >> + >> +    if (drvdata->cmb_esize == 64) >> +        *val |= FIELD_PREP(TPDA_Pn_CR_CMBSIZE, 0x2); >> +    else if (drvdata->cmb_esize == 32) >> +        *val |= FIELD_PREP(TPDA_Pn_CR_CMBSIZE, 0x1); >> +    else if (drvdata->cmb_esize == 8) >> +        *val &= ~TPDA_Pn_CR_CMBSIZE; >> +} >> + > > >>   /* >> - * Read the DSB element size from the TPDM device >> + * Read the element size from the TPDM device >>    * Returns >> - *    The dsb element size read from the devicetree if available. >> + *    The element size read from the devicetree if available. >>    *    0 - Otherwise, with a warning once. > > This doesn't match the function ? It return 0 on success and > error (-EINVAL) on failure ? > >>    */ >> -static int tpdm_read_dsb_element_size(struct coresight_device *csdev) >> +static int tpdm_read_element_size(struct tpda_drvdata *drvdata, >> +                  struct coresight_device *csdev) >>   { >> -    int rc = 0; >> -    u8 size = 0; >> - >> -    rc = fwnode_property_read_u8(dev_fwnode(csdev->dev.parent), >> -            "qcom,dsb-element-size", &size); >> +    int rc = -EINVAL; >> + >> +    if (!fwnode_property_read_u8(dev_fwnode(csdev->dev.parent), >> +            "qcom,dsb-element-size", &drvdata->dsb_esize)) >> +        rc = 0; >> +    if (!fwnode_property_read_u8(dev_fwnode(csdev->dev.parent), >> +            "qcom,cmb-element-size", &drvdata->cmb_esize)) At this point we have the csdev->dev.parent as the TPDM device and with: #include struct tpdm_drvdata *tpdm_data = get_drvdata(csdev->dev.parent); if (tpdm_has_cmb(tpdm_data)) { rc = fwnode_...(... "qcom,cmb-element-size"...) } if (tpdm_has_dsb(tpdm_data)) { rc = fwnode_...(..., "qcom,dsb-element-size"..) } Suzuki >> +        rc = 0; > > Are we not silently resetting the error if the former failed ? > > Could we not : > >     rc |= fwnode_... > >     rc |= fwnode_... > > instead ? > > Also what is the expectation here ? Are these properties a MUST for > TPDM ? > >>       if (rc) >>           dev_warn_once(&csdev->dev, >> -            "Failed to read TPDM DSB Element size: %d\n", rc); >> +            "Failed to read TPDM Element size: %d\n", rc); >> -    return size; >> +    return rc; >>   } >>   /* >> @@ -56,11 +86,12 @@ static int tpdm_read_dsb_element_size(struct >> coresight_device *csdev) >>    * Parameter "inport" is used to pass in the input port number >>    * of TPDA, and it is set to -1 in the recursize call. >>    */ >> -static int tpda_get_element_size(struct coresight_device *csdev, >> +static int tpda_get_element_size(struct tpda_drvdata *drvdata, >> +                 struct coresight_device *csdev, >>                    int inport) >>   { >> -    int dsb_size = -ENOENT; >> -    int i, size; >> +    int rc = 0; >> +    int i; >>       struct coresight_device *in; >>       for (i = 0; i < csdev->pdata->nr_inconns; i++) { >> @@ -74,25 +105,21 @@ static int tpda_get_element_size(struct >> coresight_device *csdev, >>               continue; >>           if (coresight_device_is_tpdm(in)) { >> -            size = tpdm_read_dsb_element_size(in); >> +            if ((drvdata->dsb_esize) || (drvdata->cmb_esize)) >> +                return -EEXIST; >> +            rc = tpdm_read_element_size(drvdata, in); >> +            if (rc) >> +                return rc; >>           } else { >>               /* Recurse down the path */ >> -            size = tpda_get_element_size(in, -1); >> -        } >> - >> -        if (size < 0) >> -            return size; >> - >> -        if (dsb_size < 0) { >> -            /* Found a size, save it. */ >> -            dsb_size = size; >> -        } else { >> -            /* Found duplicate TPDMs */ >> -            return -EEXIST; >> +            rc = tpda_get_element_size(drvdata, in, -1); >> +            if (rc) >> +                return rc; >>           } >>       } >> -    return dsb_size; >> + >> +    return rc; >>   } >>   /* Settings pre enabling port control register */ >> @@ -109,7 +136,7 @@ static void tpda_enable_pre_port(struct >> tpda_drvdata *drvdata) >>   static int tpda_enable_port(struct tpda_drvdata *drvdata, int port) >>   { >>       u32 val; >> -    int size; >> +    int rc; >>       val = readl_relaxed(drvdata->base + TPDA_Pn_CR(port)); >>       /* >> @@ -117,29 +144,21 @@ static int tpda_enable_port(struct tpda_drvdata >> *drvdata, int port) >>        * Set the bit to 0 if the size is 32 >>        * Set the bit to 1 if the size is 64 >>        */ >> -    size = tpda_get_element_size(drvdata->csdev, port); >> -    switch (size) { >> -    case 32: >> -        val &= ~TPDA_Pn_CR_DSBSIZE; >> -        break; >> -    case 64: >> -        val |= TPDA_Pn_CR_DSBSIZE; >> -        break; >> -    case 0: >> -        return -EEXIST; >> -    case -EEXIST: >> +    tpdm_clear_element_size(drvdata->csdev); >> +    rc = tpda_get_element_size(drvdata, drvdata->csdev, port); >> +    if (!rc && ((drvdata->dsb_esize) || (drvdata->cmb_esize))) { >> +        tpda_set_element_size(drvdata, &val); >> +        /* Enable the port */ >> +        val |= TPDA_Pn_CR_ENA; >> +        writel_relaxed(val, drvdata->base + TPDA_Pn_CR(port)); >> +    } else if (rc == -EEXIST) >>           dev_warn_once(&drvdata->csdev->dev, >> -            "Detected multiple TPDMs on port %d", -EEXIST); >> -        return -EEXIST; >> -    default: >> -        return -EINVAL; >> -    } >> - >> -    /* Enable the port */ >> -    val |= TPDA_Pn_CR_ENA; >> -    writel_relaxed(val, drvdata->base + TPDA_Pn_CR(port)); >> +                  "Detected multiple TPDMs on port %d", -EEXIST); >> +    else >> +        dev_warn_once(&drvdata->csdev->dev, >> +                  "Didn't find TPDM elem size"); > > "element size" > >> -    return 0; >> +    return rc; >>   } >>   static int __tpda_enable(struct tpda_drvdata *drvdata, int port) >> diff --git a/drivers/hwtracing/coresight/coresight-tpda.h >> b/drivers/hwtracing/coresight/coresight-tpda.h >> index b3b38fd41b64..29164fd9711f 100644 >> --- a/drivers/hwtracing/coresight/coresight-tpda.h >> +++ b/drivers/hwtracing/coresight/coresight-tpda.h >> @@ -10,6 +10,8 @@ >>   #define TPDA_Pn_CR(n)        (0x004 + (n * 4)) >>   /* Aggregator port enable bit */ >>   #define TPDA_Pn_CR_ENA        BIT(0) >> +/* Aggregator port CMB data set element size bit */ >> +#define TPDA_Pn_CR_CMBSIZE        GENMASK(7, 6) >>   /* Aggregator port DSB data set element size bit */ >>   #define TPDA_Pn_CR_DSBSIZE        BIT(8) >> @@ -25,6 +27,8 @@ >>    * @csdev:      component vitals needed by the framework. >>    * @spinlock:   lock for the drvdata value. >>    * @enable:     enable status of the component. >> + * @dsb_esize   Record the DSB element size. >> + * @cmb_esize   Record the CMB element size. >>    */ >>   struct tpda_drvdata { >>       void __iomem        *base; >> @@ -32,6 +36,8 @@ struct tpda_drvdata { >>       struct coresight_device    *csdev; >>       spinlock_t        spinlock; >>       u8            atid; >> +    u8            dsb_esize; >> +    u8            cmb_esize; >>   }; >>   #endif  /* _CORESIGHT_CORESIGHT_TPDA_H */ > > Suzuki > >