blob: 70b7126eaeeb2477605bbc0c53dc91bcbc066f6e [file] [log] [blame]
Alexander Shishkin85d49eb2019-05-03 11:44:35 +03001.. SPDX-License-Identifier: GPL-2.0
2
Changbin Du66135812018-02-17 13:39:49 +08003=======================
Alexander Shishkin39f40342015-09-22 15:47:14 +03004Intel(R) Trace Hub (TH)
5=======================
6
7Overview
8--------
9
10Intel(R) Trace Hub (TH) is a set of hardware blocks that produce,
11switch and output trace data from multiple hardware and software
12sources over several types of trace output ports encoded in System
13Trace Protocol (MIPI STPv2) and is intended to perform full system
14debugging. For more information on the hardware, see Intel(R) Trace
15Hub developer's manual [1].
16
17It consists of trace sources, trace destinations (outputs) and a
18switch (Global Trace Hub, GTH). These devices are placed on a bus of
19their own ("intel_th"), where they can be discovered and configured
20via sysfs attributes.
21
22Currently, the following Intel TH subdevices (blocks) are supported:
23 - Software Trace Hub (STH), trace source, which is a System Trace
Changbin Du66135812018-02-17 13:39:49 +080024 Module (STM) device,
Alexander Shishkin39f40342015-09-22 15:47:14 +030025 - Memory Storage Unit (MSU), trace output, which allows storing
Changbin Du66135812018-02-17 13:39:49 +080026 trace hub output in system memory,
Alexander Shishkin39f40342015-09-22 15:47:14 +030027 - Parallel Trace Interface output (PTI), trace output to an external
Changbin Du66135812018-02-17 13:39:49 +080028 debug host via a PTI port,
Alexander Shishkin39f40342015-09-22 15:47:14 +030029 - Global Trace Hub (GTH), which is a switch and a central component
Changbin Du66135812018-02-17 13:39:49 +080030 of Intel(R) Trace Hub architecture.
Alexander Shishkin39f40342015-09-22 15:47:14 +030031
32Common attributes for output devices are described in
33Documentation/ABI/testing/sysfs-bus-intel_th-output-devices, the most
34notable of them is "active", which enables or disables trace output
35into that particular output device.
36
37GTH allows directing different STP masters into different output ports
38via its "masters" attribute group. More detailed GTH interface
39description is at Documentation/ABI/testing/sysfs-bus-intel_th-devices-gth.
40
41STH registers an stm class device, through which it provides interface
42to userspace and kernelspace software trace sources. See
Mauro Carvalho Chehab5fb94e92018-05-08 15:14:57 -030043Documentation/trace/stm.rst for more information on that.
Alexander Shishkin39f40342015-09-22 15:47:14 +030044
45MSU can be configured to collect trace data into a system memory
46buffer, which can later on be read from its device nodes via read() or
Alexander Shishkin87ff1602019-11-14 08:42:01 +020047mmap() interface and directed to a "software sink" driver that will
48consume the data and/or relay it further.
Alexander Shishkin39f40342015-09-22 15:47:14 +030049
50On the whole, Intel(R) Trace Hub does not require any special
51userspace software to function; everything can be configured, started
52and collected via sysfs attributes, and device nodes.
53
54[1] https://software.intel.com/sites/default/files/managed/d3/3c/intel-th-developer-manual.pdf
55
56Bus and Subdevices
57------------------
58
59For each Intel TH device in the system a bus of its own is
60created and assigned an id number that reflects the order in which TH
61devices were emumerated. All TH subdevices (devices on intel_th bus)
62begin with this id: 0-gth, 0-msc0, 0-msc1, 0-pti, 0-sth, which is
63followed by device's name and an optional index.
64
65Output devices also get a device node in /dev/intel_thN, where N is
66the Intel TH device id. For example, MSU's memory buffers, when
67allocated, are accessible via /dev/intel_th0/msc{0,1}.
68
69Quick example
70-------------
71
Changbin Du66135812018-02-17 13:39:49 +080072# figure out which GTH port is the first memory controller::
Alexander Shishkin39f40342015-09-22 15:47:14 +030073
Changbin Du66135812018-02-17 13:39:49 +080074 $ cat /sys/bus/intel_th/devices/0-msc0/port
75 0
Alexander Shishkin39f40342015-09-22 15:47:14 +030076
Changbin Du66135812018-02-17 13:39:49 +080077# looks like it's port 0, configure master 33 to send data to port 0::
Alexander Shishkin39f40342015-09-22 15:47:14 +030078
Changbin Du66135812018-02-17 13:39:49 +080079 $ echo 0 > /sys/bus/intel_th/devices/0-gth/masters/33
Alexander Shishkin39f40342015-09-22 15:47:14 +030080
81# allocate a 2-windowed multiblock buffer on the first memory
Changbin Du66135812018-02-17 13:39:49 +080082# controller, each with 64 pages::
Alexander Shishkin39f40342015-09-22 15:47:14 +030083
Changbin Du66135812018-02-17 13:39:49 +080084 $ echo multi > /sys/bus/intel_th/devices/0-msc0/mode
85 $ echo 64,64 > /sys/bus/intel_th/devices/0-msc0/nr_pages
Alexander Shishkin39f40342015-09-22 15:47:14 +030086
Changbin Du66135812018-02-17 13:39:49 +080087# enable wrapping for this controller, too::
Alexander Shishkin39f40342015-09-22 15:47:14 +030088
Changbin Du66135812018-02-17 13:39:49 +080089 $ echo 1 > /sys/bus/intel_th/devices/0-msc0/wrap
Alexander Shishkin39f40342015-09-22 15:47:14 +030090
Changbin Du66135812018-02-17 13:39:49 +080091# and enable tracing into this port::
Alexander Shishkin39f40342015-09-22 15:47:14 +030092
Changbin Du66135812018-02-17 13:39:49 +080093 $ echo 1 > /sys/bus/intel_th/devices/0-msc0/active
Alexander Shishkin39f40342015-09-22 15:47:14 +030094
95# .. send data to master 33, see stm.txt for more details ..
96# .. wait for traces to pile up ..
Changbin Du66135812018-02-17 13:39:49 +080097# .. and stop the trace::
Alexander Shishkin39f40342015-09-22 15:47:14 +030098
Changbin Du66135812018-02-17 13:39:49 +080099 $ echo 0 > /sys/bus/intel_th/devices/0-msc0/active
Alexander Shishkin39f40342015-09-22 15:47:14 +0300100
Changbin Du66135812018-02-17 13:39:49 +0800101# and now you can collect the trace from the device node::
Alexander Shishkin39f40342015-09-22 15:47:14 +0300102
Changbin Du66135812018-02-17 13:39:49 +0800103 $ cat /dev/intel_th0/msc0 > my_stp_trace
Alexander Shishkinee01aeb2016-09-19 18:06:25 +0300104
105Host Debugger Mode
Changbin Du66135812018-02-17 13:39:49 +0800106------------------
Alexander Shishkinee01aeb2016-09-19 18:06:25 +0300107
108It is possible to configure the Trace Hub and control its trace
109capture from a remote debug host, which should be connected via one of
110the hardware debugging interfaces, which will then be used to both
111control Intel Trace Hub and transfer its trace data to the debug host.
112
113The driver needs to be told that such an arrangement is taking place
114so that it does not touch any capture/port configuration and avoids
115conflicting with the debug host's configuration accesses. The only
116activity that the driver will perform in this mode is collecting
117software traces to the Software Trace Hub (an stm class device). The
118user is still responsible for setting up adequate master/channel
119mappings that the decoder on the receiving end would recognize.
120
121In order to enable the host mode, set the 'host_mode' parameter of the
122'intel_th' kernel module to 'y'. None of the virtual output devices
123will show up on the intel_th bus. Also, trace configuration and
124capture controlling attribute groups of the 'gth' device will not be
125exposed. The 'sth' device will operate as usual.
Alexander Shishkin87ff1602019-11-14 08:42:01 +0200126
127Software Sinks
128--------------
129
130The Memory Storage Unit (MSU) driver provides an in-kernel API for
131drivers to register themselves as software sinks for the trace data.
132Such drivers can further export the data via other devices, such as
133USB device controllers or network cards.
134
135The API has two main parts::
136 - notifying the software sink that a particular window is full, and
137 "locking" that window, that is, making it unavailable for the trace
138 collection; when this happens, the MSU driver will automatically
139 switch to the next window in the buffer if it is unlocked, or stop
140 the trace capture if it's not;
141 - tracking the "locked" state of windows and providing a way for the
142 software sink driver to notify the MSU driver when a window is
143 unlocked and can be used again to collect trace data.
144
145An example sink driver, msu-sink illustrates the implementation of a
146software sink. Functionally, it simply unlocks windows as soon as they
147are full, keeping the MSU running in a circular buffer mode. Unlike the
148"multi" mode, it will fill out all the windows in the buffer as opposed
149to just the first one. It can be enabled by writing "sink" to the "mode"
150file (assuming msu-sink.ko is loaded).