# SPDX-License-Identifier: GPL-2.0-only or BSD-2-Clause # Copyright 2021, Arm Ltd %YAML 1.2 --- $id: "http://devicetree.org/schemas/arm/ete.yaml#" $schema: "http://devicetree.org/meta-schemas/core.yaml#" title: ARM Embedded Trace Extensions maintainers: - Suzuki K Poulose - Mathieu Poirier description: | Arm Embedded Trace Extension(ETE) is a per CPU trace component that allows tracing the CPU execution. It overlaps with the CoreSight ETMv4 architecture and has extended support for future architecture changes. The trace generated by the ETE could be stored via legacy CoreSight components (e.g, TMC-ETR) or other means (e.g, using a per CPU buffer Arm Trace Buffer Extension (TRBE)). Since the ETE can be connected to legacy CoreSight components, a node must be listed per instance, along with any optional connection graph as per the coresight bindings. See bindings/arm/coresight.txt. properties: $nodename: pattern: "^ete([0-9a-f]+)$" compatible: items: - const: arm,embedded-trace-extension cpu: description: | Handle to the cpu this ETE is bound to. $ref: /schemas/types.yaml#/definitions/phandle out-ports: description: | Output connections from the ETE to legacy CoreSight trace bus. $ref: /schemas/graph.yaml#/properties/ports properties: port: description: Output connection from the ETE to legacy CoreSight Trace bus. $ref: /schemas/graph.yaml#/properties/port required: required: - compatible - cpu additionalProperties: false examples: # An ETE node without legacy CoreSight connections - | ete0 { compatible = "arm,embedded-trace-extension"; cpu = <&cpu_0>; }; # An ETE node with legacy CoreSight connections - | ete1 { compatible = "arm,embedded-trace-extension"; cpu = <&cpu_1>; out-ports { /* legacy coresight connection */ port { ete1_out_port: endpoint { remote-endpoint = <&funnel_in_port0>; }; }; }; }; ...