| ============================= |
| Arm Coherent Mesh Network PMU |
| ============================= |
| |
| CMN-600 is a configurable mesh interconnect consisting of a rectangular |
| grid of crosspoints (XPs), with each crosspoint supporting up to two |
| device ports to which various AMBA CHI agents are attached. |
| |
| CMN implements a distributed PMU design as part of its debug and trace |
| functionality. This consists of a local monitor (DTM) at every XP, which |
| counts up to 4 event signals from the connected device nodes and/or the |
| XP itself. Overflow from these local counters is accumulated in up to 8 |
| global counters implemented by the main controller (DTC), which provides |
| overall PMU control and interrupts for global counter overflow. |
| |
| PMU events |
| ---------- |
| |
| The PMU driver registers a single PMU device for the whole interconnect, |
| see /sys/bus/event_source/devices/arm_cmn_0. Multi-chip systems may link |
| more than one CMN together via external CCIX links - in this situation, |
| each mesh counts its own events entirely independently, and additional |
| PMU devices will be named arm_cmn_{1..n}. |
| |
| Most events are specified in a format based directly on the TRM |
| definitions - "type" selects the respective node type, and "eventid" the |
| event number. Some events require an additional occupancy ID, which is |
| specified by "occupid". |
| |
| * Since RN-D nodes do not have any distinct events from RN-I nodes, they |
| are treated as the same type (0xa), and the common event templates are |
| named "rnid_*". |
| |
| * The cycle counter is treated as a synthetic event belonging to the DTC |
| node ("type" == 0x3, "eventid" is ignored). |
| |
| * XP events also encode the port and channel in the "eventid" field, to |
| match the underlying pmu_event0_id encoding for the pmu_event_sel |
| register. The event templates are named with prefixes to cover all |
| permutations. |
| |
| By default each event provides an aggregate count over all nodes of the |
| given type. To target a specific node, "bynodeid" must be set to 1 and |
| "nodeid" to the appropriate value derived from the CMN configuration |
| (as defined in the "Node ID Mapping" section of the TRM). |
| |
| Watchpoints |
| ----------- |
| |
| The PMU can also count watchpoint events to monitor specific flit |
| traffic. Watchpoints are treated as a synthetic event type, and like PMU |
| events can be global or targeted with a particular XP's "nodeid" value. |
| Since the watchpoint direction is otherwise implicit in the underlying |
| register selection, separate events are provided for flit uploads and |
| downloads. |
| |
| The flit match value and mask are passed in config1 and config2 ("val" |
| and "mask" respectively). "wp_dev_sel", "wp_chn_sel", "wp_grp" and |
| "wp_exclusive" are specified per the TRM definitions for dtm_wp_config0. |
| Where a watchpoint needs to match fields from both match groups on the |
| REQ or SNP channel, it can be specified as two events - one for each |
| group - with the same nonzero "combine" value. The count for such a |
| pair of combined events will be attributed to the primary match. |
| Watchpoint events with a "combine" value of 0 are considered independent |
| and will count individually. |