Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp503541iog; Thu, 30 Jun 2022 05:09:16 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tYURSGkwYTlQtso2LHdLS08mkiQmLTQG/v3ea1ruTjGd9x1vQNbDMdBSg5DVErOx15BzIk X-Received: by 2002:a17:90b:1b42:b0:1ec:c483:3eb7 with SMTP id nv2-20020a17090b1b4200b001ecc4833eb7mr12209085pjb.52.1656590956659; Thu, 30 Jun 2022 05:09:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656590956; cv=none; d=google.com; s=arc-20160816; b=IDDVswKfy8Rh57Xk35yC7YbS8bsJam+anWDCHuZMmo0eWD0l8uqOh90V7l3WyeXWH+ IrkDtss4vTTMlM/U6SjRYkbxu1UyBNiTxLlb5SgJWCCTZbQxAvmkV/2vpmG8/m/UAjrp u/9vi0uVSUdj7HCWVrmLNxMr84eReFidE7F5FkQNwAe9xFUObCatuNEdWUkklBMDYBec 5TY6X2xEiIZHfSSwvSSNKryWsac4Lh+ImtpfW6QUajfZXqpGyREygUz19A7ceT39E4Ec rC0soBzBEBQD/jMGRrXb9TRtBkLshOuBabl+vPgAKL+6zR/CmFyLZl7zUH/24hoeSs5W d1mw== 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:dkim-signature; bh=AnUwEBzguN4yrlQIkaV5hrzKocIGpAcr2W1vCv14+W4=; b=u4CxQOrGcuZHrFOeIVZHWHzNbsWwXXaxizhLehxMm0erY8VTlKX6EMlyknjlwyG2BI AxHj1e7DhQjD/ptaOqFywQsIUhBuZ5ijKpGomaXKl+wJHDNTBx7j2OXAPa4xHnFmljOv i9UYecr3eeFDiHtICaxljyWkIscUCeAZeE2wr6x6sWPkBXYjESBGf96JJha7ADZFYqyt NJw+63cyOf52exLolOJted5CMYA2shokgLl13BJS7ciq7REQWqOP/hWUF1QDTK6YcCAT 87fyW6SzsKRbD8iITbclKvhBXJssGxv/JQbnJ8EMfriZaUdLKLJoRSUBRfDBuAYC8N+J QzkQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b="o/tzACGs"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c15-20020a170903234f00b00163539b9430si29585039plh.434.2022.06.30.05.09.04; Thu, 30 Jun 2022 05:09:16 -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; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b="o/tzACGs"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234507AbiF3Ll7 (ORCPT + 99 others); Thu, 30 Jun 2022 07:41:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56352 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230350AbiF3Ll6 (ORCPT ); Thu, 30 Jun 2022 07:41:58 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BEEEE523AA; Thu, 30 Jun 2022 04:41:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1656589318; x=1688125318; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=AnUwEBzguN4yrlQIkaV5hrzKocIGpAcr2W1vCv14+W4=; b=o/tzACGsQ2/QIvGnyVHpruXf2PFGwc2EQnarJ9RMksbfJPQ/u6EoAyLI yqOuTXkruoY/qoxvsCgjFY81Fkhb1H9sp2A3haKa8E3qT63g9SBILLCe7 S9Lk7JxzY92gKNWzEWpYLDeOle49mc3EuNmfs9vYPe7raS/Vi8ON0pCs2 Q=; Received: from ironmsg-lv-alpha.qualcomm.com ([10.47.202.13]) by alexa-out.qualcomm.com with ESMTP; 30 Jun 2022 04:41:57 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg-lv-alpha.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 30 Jun 2022 04:41:56 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Thu, 30 Jun 2022 04:41:56 -0700 Received: from [10.253.75.186] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Thu, 30 Jun 2022 04:41:51 -0700 Message-ID: <7601feb4-1255-2978-f0bc-4c25f501e67f@quicinc.com> Date: Thu, 30 Jun 2022 19:41:49 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH v11 0/9] Coresight: Add support for TPDM and TPDA Content-Language: en-US To: Mathieu Poirier , Suzuki K Poulose , Alexander Shishkin , Konrad Dybcio , Mike Leach , Andy Gross , "Bjorn Andersson" , Rob Herring , Krzysztof Kozlowski CC: Leo Yan , Greg Kroah-Hartman , , , , , Tingwei Zhang , Yuanfang Zhang , Tao Zhang , Trilok Soni , Hao Zhang , References: <20220620120101.2906-1-quic_jinlmao@quicinc.com> From: Jinlong Mao In-Reply-To: <20220620120101.2906-1-quic_jinlmao@quicinc.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 Hi Reviewers, Please help to review V11 patches. Thanks Jinlong Mao On 6/20/2022 8:00 PM, Mao Jinlong wrote: > This series adds support for the trace performance monitoring and > diagnostics hardware (TPDM and TPDA). It is composed of two major > elements. > a) Changes for original coresight framework to support for TPDM and TPDA. > b) Add driver code for TPDM and TPDA. > > Introduction of changes for original coresight framework > Support TPDM as new coresight source. > Since only STM and ETM are supported as coresight source originally. > TPDM is a newly added coresight source. We need to change > the original way of saving coresight path to support more types source > for coresight driver. > The following patch is to add support more coresight sources. > coresight: core: Use IDR for non-cpu bound sources' paths. > > Introduction of TPDM and TPDA > TPDM - The trace performance monitoring and diagnostics monitor or TPDM in > short serves as data collection component for various dataset types > specified in the QPMDA(Qualcomm performance monitoring and diagnostics > architecture) spec. The primary use case of the TPDM is to collect data > from different data sources and send it to a TPDA for packetization, > timestamping and funneling. > Coresight: Add coresight TPDM source driver > dt-bindings: arm: Adds CoreSight TPDM hardware definitions > coresight-tpdm: Add DSB dataset support > coresight-tpdm: Add integration test support > docs: sysfs: coresight: Add sysfs ABI documentation for TPDM > > TPDA - The trace performance monitoring and diagnostics aggregator or > TPDA in short serves as an arbitration and packetization engine for the > performance monitoring and diagnostics network as specified in the QPMDA > (Qualcomm performance monitoring and diagnostics architecture) > specification. The primary use case of the TPDA is to provide > packetization, funneling and timestamping of Monitor data as specified > in the QPMDA specification. > The following patch is to add driver for TPDA. > Coresight: Add TPDA link driver > dt-bindings: arm: Adds CoreSight TPDA hardware definitions > > The last patch of this series is a device tree modification, which add > the TPDM and TPDA configuration to device tree for validating. > ARM: dts: msm: Add coresight components for SM8250 > ARM: dts: msm: Add tpdm mm/prng for sm8250 > > Once this series patches are applied properly, the tpdm and tpda nodes > should be observed at the coresight path /sys/bus/coresight/devices > e.g. > /sys/bus/coresight/devices # ls -l | grep tpd > tpda0 -> ../../../devices/platform/soc@0/6004000.tpda/tpda0 > tpdm0 -> ../../../devices/platform/soc@0/6c08000.mm.tpdm/tpdm0 > > We can use the commands are similar to the below to validate TPDMs. > Enable coresight sink first. > > echo 1 > /sys/bus/coresight/devices/tmc_etf0/enable_sink > echo 1 > /sys/bus/coresight/devices/tpdm0/enable_source > echo 1 > /sys/bus/coresight/devices/tpdm0/integration_test > echo 2 > /sys/bus/coresight/devices/tpdm0/integration_test > The test data will be collected in the coresight sink which is enabled. > If rwp register of the sink is keeping updating when do > integration_test (by cat tmc_etf0/mgmt/rwp), it means there is data > generated from TPDM to sink. > > There must be a tpda between tpdm and the sink. When there are some > other trace event hw components in the same HW block with tpdm, tpdm > and these hw components will connect to the coresight funnel. When > there is only tpdm trace hw in the HW block, tpdm will connect to > tpda directly. > > +---------------+ +-------------+ > | tpdm@6c08000 | |tpdm@684C000 | > +-------|-------+ +------|------+ > | | > +-------|-------+ | > | funnel@6c0b000| | > +-------|-------+ | > | | > +-------|-------+ | > |funnel@6c2d000 | | > +-------|-------+ | > | | > | +---------------+ | > +----- tpda@6004000 -----------+ > +-------|-------+ > | > +-------|-------+ > |funnel@6005000 | > +---------------+ > > This patch series depends on patch series > "coresight: Add new API to allocate trace source ID values". > https://patchwork.kernel.org/project/linux-arm-kernel/cover/20220308205000.27646-1-mike.leach@linaro.org/ > > Changes from V10: > 1. Change dev_info to dev_dbg in TPDM/TPDA drivers. -- Suzuki K Poulose > 2. Merge sysfs API change of integration_test to integration_test driver > change. -- -- Suzuki K Poulose > > Mao Jinlong (9): > coresight: core: Use IDR for non-cpu bound sources' paths. > Coresight: Add coresight TPDM source driver > dt-bindings: arm: Adds CoreSight TPDM hardware definitions > coresight-tpdm: Add DSB dataset support > coresight-tpdm: Add integration test support > Coresight: Add TPDA link driver > dt-bindings: arm: Adds CoreSight TPDA hardware definitions > arm64: dts: qcom: sm8250: Add coresight components > arm64: dts: qcom: sm8250: Add tpdm mm/prng > > .../testing/sysfs-bus-coresight-devices-tpdm | 13 + > .../bindings/arm/qcom,coresight-tpda.yaml | 111 +++ > .../bindings/arm/qcom,coresight-tpdm.yaml | 93 +++ > MAINTAINERS | 2 + > arch/arm64/boot/dts/qcom/sm8250.dtsi | 671 ++++++++++++++++++ > drivers/hwtracing/coresight/Kconfig | 23 + > drivers/hwtracing/coresight/Makefile | 2 + > drivers/hwtracing/coresight/coresight-core.c | 42 +- > drivers/hwtracing/coresight/coresight-tpda.c | 206 ++++++ > drivers/hwtracing/coresight/coresight-tpda.h | 35 + > drivers/hwtracing/coresight/coresight-tpdm.c | 259 +++++++ > drivers/hwtracing/coresight/coresight-tpdm.h | 62 ++ > include/linux/coresight.h | 1 + > 13 files changed, 1508 insertions(+), 12 deletions(-) > create mode 100644 Documentation/ABI/testing/sysfs-bus-coresight-devices-tpdm > create mode 100644 Documentation/devicetree/bindings/arm/qcom,coresight-tpda.yaml > create mode 100644 Documentation/devicetree/bindings/arm/qcom,coresight-tpdm.yaml > create mode 100644 drivers/hwtracing/coresight/coresight-tpda.c > create mode 100644 drivers/hwtracing/coresight/coresight-tpda.h > create mode 100644 drivers/hwtracing/coresight/coresight-tpdm.c > create mode 100644 drivers/hwtracing/coresight/coresight-tpdm.h >