123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- Intel(R) Trace Hub (TH)
- =======================
- Overview
- --------
- Intel(R) Trace Hub (TH) is a set of hardware blocks that produce,
- switch and output trace data from multiple hardware and software
- sources over several types of trace output ports encoded in System
- Trace Protocol (MIPI STPv2) and is intended to perform full system
- debugging. For more information on the hardware, see Intel(R) Trace
- Hub developer's manual [1].
- It consists of trace sources, trace destinations (outputs) and a
- switch (Global Trace Hub, GTH). These devices are placed on a bus of
- their own ("intel_th"), where they can be discovered and configured
- via sysfs attributes.
- Currently, the following Intel TH subdevices (blocks) are supported:
- - Software Trace Hub (STH), trace source, which is a System Trace
- Module (STM) device,
- - Memory Storage Unit (MSU), trace output, which allows storing
- trace hub output in system memory,
- - Parallel Trace Interface output (PTI), trace output to an external
- debug host via a PTI port,
- - Global Trace Hub (GTH), which is a switch and a central component
- of Intel(R) Trace Hub architecture.
- Common attributes for output devices are described in
- Documentation/ABI/testing/sysfs-bus-intel_th-output-devices, the most
- notable of them is "active", which enables or disables trace output
- into that particular output device.
- GTH allows directing different STP masters into different output ports
- via its "masters" attribute group. More detailed GTH interface
- description is at Documentation/ABI/testing/sysfs-bus-intel_th-devices-gth.
- STH registers an stm class device, through which it provides interface
- to userspace and kernelspace software trace sources. See
- Documentation/tracing/stm.txt for more information on that.
- MSU can be configured to collect trace data into a system memory
- buffer, which can later on be read from its device nodes via read() or
- mmap() interface.
- On the whole, Intel(R) Trace Hub does not require any special
- userspace software to function; everything can be configured, started
- and collected via sysfs attributes, and device nodes.
- [1] https://software.intel.com/sites/default/files/managed/d3/3c/intel-th-developer-manual.pdf
- Bus and Subdevices
- ------------------
- For each Intel TH device in the system a bus of its own is
- created and assigned an id number that reflects the order in which TH
- devices were emumerated. All TH subdevices (devices on intel_th bus)
- begin with this id: 0-gth, 0-msc0, 0-msc1, 0-pti, 0-sth, which is
- followed by device's name and an optional index.
- Output devices also get a device node in /dev/intel_thN, where N is
- the Intel TH device id. For example, MSU's memory buffers, when
- allocated, are accessible via /dev/intel_th0/msc{0,1}.
- Quick example
- -------------
- # figure out which GTH port is the first memory controller:
- $ cat /sys/bus/intel_th/devices/0-msc0/port
- 0
- # looks like it's port 0, configure master 33 to send data to port 0:
- $ echo 0 > /sys/bus/intel_th/devices/0-gth/masters/33
- # allocate a 2-windowed multiblock buffer on the first memory
- # controller, each with 64 pages:
- $ echo multi > /sys/bus/intel_th/devices/0-msc0/mode
- $ echo 64,64 > /sys/bus/intel_th/devices/0-msc0/nr_pages
- # enable wrapping for this controller, too:
- $ echo 1 > /sys/bus/intel_th/devices/0-msc0/wrap
- # and enable tracing into this port:
- $ echo 1 > /sys/bus/intel_th/devices/0-msc0/active
- # .. send data to master 33, see stm.txt for more details ..
- # .. wait for traces to pile up ..
- # .. and stop the trace:
- $ echo 0 > /sys/bus/intel_th/devices/0-msc0/active
- # and now you can collect the trace from the device node:
- $ cat /dev/intel_th0/msc0 > my_stp_trace
|