| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- =============================
- 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.
|