Received: by 2002:a05:7412:8598:b0:f9:33c2:5753 with SMTP id n24csp510055rdh; Tue, 19 Dec 2023 05:54:17 -0800 (PST) X-Google-Smtp-Source: AGHT+IFswG7yEOlWvQz4fi4p7V3iATRgUFZkH+V/kl7Lz7wknXXkX2/+D4gWkq1WmgTbLfpR9k3U X-Received: by 2002:a05:620a:4382:b0:77e:fba3:a220 with SMTP id a2-20020a05620a438200b0077efba3a220mr24566326qkp.122.1702994057132; Tue, 19 Dec 2023 05:54:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702994057; cv=none; d=google.com; s=arc-20160816; b=TQIDocOOlZP5leFWu7Fu/65qQd9AJIHqedsz189yOuoqWiPsHjacvHgH9CZNMxqzr2 svT+C6pF7Av77iBe8BBNoDRsoKYG0uEMo9qY79mCvawoP5XdqkaewSxODXNfMlDTQ/xC ahhJv44CZ+5nM8RMYN6WNK56OdUotdLc6u3Y09JLSF2sXXEKsnYHXFpWlBb6DbWAjFkw VnpdMSiQONLy4sOaZAatz6FO6k3INiMtZRTCy3Ki25ZAW9D3lJIKnk1bD45RuxB2EspP FeXjIyLZlzfrkoDFNF2pXiMxFGGRDu1O7ixQrjcocZwAiVI3yTuMIGbcBvIP6GA+AFPD lEDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=sKp/2/Hv2XE58RUABtWOSI0GjZuNa8S61zlQIps3skU=; fh=VVn1or143ocJn81UN5C70YFisJoYbLqtg4Us8PNvf4I=; b=T13JUEfb5X05vo5XqRyU/wJ+7SyXeaN5vS5ujozgVBK+4O2fXq4EilD2V7M6t7p7iz zp5VxZBpVkWYUJa4ODsvgZAfyzZA0Qv6LtcjXjjL6HrGJHzRRTh1I7YhbvgDlg0U1HDd kPgSHpW0d/utHMsFhke2UNaMB2/OK+B9FUlA1+KzawL9EzxB25g1d1rnwYRXegM9ZkCj acO4XMW7HiPdW8VqKVOLFVoTdvs7ypu5RF103Oem9FZd2+M5s+WA6PETU/Z3dF9Spge3 /RTuIZUrTrZLXrakfphBsMTgG25hcony3xraBeI8cddaGSnPwJgSzEAoYYE68KpEjJTT 9Lew== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-5291-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5291-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. [147.75.199.223]) by mx.google.com with ESMTPS id x11-20020a05620a258b00b0077d7d836d92si27298774qko.149.2023.12.19.05.54.16 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Dec 2023 05:54:17 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-5291-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-5291-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5291-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 D1D031C23A71 for ; Tue, 19 Dec 2023 13:54:16 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CA2431A72B; Tue, 19 Dec 2023 13:54:07 +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 223841A5A5; Tue, 19 Dec 2023 13:54:04 +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 7D8C61FB; Tue, 19 Dec 2023 05:54:48 -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 8BA243F5A1; Tue, 19 Dec 2023 05:54:01 -0800 (PST) Message-ID: Date: Tue, 19 Dec 2023 13:54:00 +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 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> From: Suzuki K Poulose In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 19/12/2023 02:13, Tao Zhang wrote: > > On 12/18/2023 6:27 PM, 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 ? > > The element size of all the TPDM sub-unit should be set to 0 here. > > I will update this in the next patch series. > >> >>> +} >>> + >>> +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 ? > > 0 means the element size property is found from the devicetree. > > Otherwise, it will return error(-EINVAL). > > I will update this in the next patch series. > >> >>>    */ >>> -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)) >>> +        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 ? > > The TPDM must have one of the element size property. As long as one Please add a comment in the function. Someone else might try to "fix" it otherwise. Suzuki > > can be found, this TPDM configuration can be considered valid. So this > > function will return 0 if one of the element size property is found. > > > Best, > > Tao > >> >>>       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 >> >>