~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/trace/intel_th.rst

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/trace/intel_th.rst (Architecture i386) and /Documentation/trace/intel_th.rst (Architecture m68k)


  1 .. SPDX-License-Identifier: GPL-2.0                 1 .. SPDX-License-Identifier: GPL-2.0
  2                                                     2 
  3 =======================                             3 =======================
  4 Intel(R) Trace Hub (TH)                             4 Intel(R) Trace Hub (TH)
  5 =======================                             5 =======================
  6                                                     6 
  7 Overview                                            7 Overview
  8 --------                                            8 --------
  9                                                     9 
 10 Intel(R) Trace Hub (TH) is a set of hardware b     10 Intel(R) Trace Hub (TH) is a set of hardware blocks that produce,
 11 switch and output trace data from multiple har     11 switch and output trace data from multiple hardware and software
 12 sources over several types of trace output por     12 sources over several types of trace output ports encoded in System
 13 Trace Protocol (MIPI STPv2) and is intended to     13 Trace Protocol (MIPI STPv2) and is intended to perform full system
 14 debugging. For more information on the hardwar     14 debugging. For more information on the hardware, see Intel(R) Trace
 15 Hub developer's manual [1].                        15 Hub developer's manual [1].
 16                                                    16 
 17 It consists of trace sources, trace destinatio     17 It consists of trace sources, trace destinations (outputs) and a
 18 switch (Global Trace Hub, GTH). These devices      18 switch (Global Trace Hub, GTH). These devices are placed on a bus of
 19 their own ("intel_th"), where they can be disc     19 their own ("intel_th"), where they can be discovered and configured
 20 via sysfs attributes.                              20 via sysfs attributes.
 21                                                    21 
 22 Currently, the following Intel TH subdevices (     22 Currently, the following Intel TH subdevices (blocks) are supported:
 23   - Software Trace Hub (STH), trace source, wh     23   - Software Trace Hub (STH), trace source, which is a System Trace
 24     Module (STM) device,                           24     Module (STM) device,
 25   - Memory Storage Unit (MSU), trace output, w     25   - Memory Storage Unit (MSU), trace output, which allows storing
 26     trace hub output in system memory,             26     trace hub output in system memory,
 27   - Parallel Trace Interface output (PTI), tra     27   - Parallel Trace Interface output (PTI), trace output to an external
 28     debug host via a PTI port,                     28     debug host via a PTI port,
 29   - Global Trace Hub (GTH), which is a switch      29   - Global Trace Hub (GTH), which is a switch and a central component
 30     of Intel(R) Trace Hub architecture.            30     of Intel(R) Trace Hub architecture.
 31                                                    31 
 32 Common attributes for output devices are descr     32 Common attributes for output devices are described in
 33 Documentation/ABI/testing/sysfs-bus-intel_th-o     33 Documentation/ABI/testing/sysfs-bus-intel_th-output-devices, the most
 34 notable of them is "active", which enables or      34 notable of them is "active", which enables or disables trace output
 35 into that particular output device.                35 into that particular output device.
 36                                                    36 
 37 GTH allows directing different STP masters int     37 GTH allows directing different STP masters into different output ports
 38 via its "masters" attribute group. More detail     38 via its "masters" attribute group. More detailed GTH interface
 39 description is at Documentation/ABI/testing/sy     39 description is at Documentation/ABI/testing/sysfs-bus-intel_th-devices-gth.
 40                                                    40 
 41 STH registers an stm class device, through whi     41 STH registers an stm class device, through which it provides interface
 42 to userspace and kernelspace software trace so     42 to userspace and kernelspace software trace sources. See
 43 Documentation/trace/stm.rst for more informati     43 Documentation/trace/stm.rst for more information on that.
 44                                                    44 
 45 MSU can be configured to collect trace data in     45 MSU can be configured to collect trace data into a system memory
 46 buffer, which can later on be read from its de     46 buffer, which can later on be read from its device nodes via read() or
 47 mmap() interface and directed to a "software s     47 mmap() interface and directed to a "software sink" driver that will
 48 consume the data and/or relay it further.          48 consume the data and/or relay it further.
 49                                                    49 
 50 On the whole, Intel(R) Trace Hub does not requ     50 On the whole, Intel(R) Trace Hub does not require any special
 51 userspace software to function; everything can     51 userspace software to function; everything can be configured, started
 52 and collected via sysfs attributes, and device     52 and collected via sysfs attributes, and device nodes.
 53                                                    53 
 54 [1] https://software.intel.com/sites/default/f     54 [1] https://software.intel.com/sites/default/files/managed/d3/3c/intel-th-developer-manual.pdf
 55                                                    55 
 56 Bus and Subdevices                                 56 Bus and Subdevices
 57 ------------------                                 57 ------------------
 58                                                    58 
 59 For each Intel TH device in the system a bus o     59 For each Intel TH device in the system a bus of its own is
 60 created and assigned an id number that reflect     60 created and assigned an id number that reflects the order in which TH
 61 devices were enumerated. All TH subdevices (de     61 devices were enumerated. All TH subdevices (devices on intel_th bus)
 62 begin with this id: 0-gth, 0-msc0, 0-msc1, 0-p     62 begin with this id: 0-gth, 0-msc0, 0-msc1, 0-pti, 0-sth, which is
 63 followed by device's name and an optional inde     63 followed by device's name and an optional index.
 64                                                    64 
 65 Output devices also get a device node in /dev/     65 Output devices also get a device node in /dev/intel_thN, where N is
 66 the Intel TH device id. For example, MSU's mem     66 the Intel TH device id. For example, MSU's memory buffers, when
 67 allocated, are accessible via /dev/intel_th0/m     67 allocated, are accessible via /dev/intel_th0/msc{0,1}.
 68                                                    68 
 69 Quick example                                      69 Quick example
 70 -------------                                      70 -------------
 71                                                    71 
 72 # figure out which GTH port is the first memor     72 # figure out which GTH port is the first memory controller::
 73                                                    73 
 74         $ cat /sys/bus/intel_th/devices/0-msc0     74         $ cat /sys/bus/intel_th/devices/0-msc0/port
 75         0                                          75         0
 76                                                    76 
 77 # looks like it's port 0, configure master 33      77 # looks like it's port 0, configure master 33 to send data to port 0::
 78                                                    78 
 79         $ echo 0 > /sys/bus/intel_th/devices/0     79         $ echo 0 > /sys/bus/intel_th/devices/0-gth/masters/33
 80                                                    80 
 81 # allocate a 2-windowed multiblock buffer on t     81 # allocate a 2-windowed multiblock buffer on the first memory
 82 # controller, each with 64 pages::                 82 # controller, each with 64 pages::
 83                                                    83 
 84         $ echo multi > /sys/bus/intel_th/devic     84         $ echo multi > /sys/bus/intel_th/devices/0-msc0/mode
 85         $ echo 64,64 > /sys/bus/intel_th/devic     85         $ echo 64,64 > /sys/bus/intel_th/devices/0-msc0/nr_pages
 86                                                    86 
 87 # enable wrapping for this controller, too::       87 # enable wrapping for this controller, too::
 88                                                    88 
 89         $ echo 1 > /sys/bus/intel_th/devices/0     89         $ echo 1 > /sys/bus/intel_th/devices/0-msc0/wrap
 90                                                    90 
 91 # and enable tracing into this port::              91 # and enable tracing into this port::
 92                                                    92 
 93         $ echo 1 > /sys/bus/intel_th/devices/0     93         $ echo 1 > /sys/bus/intel_th/devices/0-msc0/active
 94                                                    94 
 95 # .. send data to master 33, see stm.txt for m     95 # .. send data to master 33, see stm.txt for more details ..
 96 # .. wait for traces to pile up ..                 96 # .. wait for traces to pile up ..
 97 # .. and stop the trace::                          97 # .. and stop the trace::
 98                                                    98 
 99         $ echo 0 > /sys/bus/intel_th/devices/0     99         $ echo 0 > /sys/bus/intel_th/devices/0-msc0/active
100                                                   100 
101 # and now you can collect the trace from the d    101 # and now you can collect the trace from the device node::
102                                                   102 
103         $ cat /dev/intel_th0/msc0 > my_stp_tra    103         $ cat /dev/intel_th0/msc0 > my_stp_trace
104                                                   104 
105 Host Debugger Mode                                105 Host Debugger Mode
106 ------------------                                106 ------------------
107                                                   107 
108 It is possible to configure the Trace Hub and     108 It is possible to configure the Trace Hub and control its trace
109 capture from a remote debug host, which should    109 capture from a remote debug host, which should be connected via one of
110 the hardware debugging interfaces, which will     110 the hardware debugging interfaces, which will then be used to both
111 control Intel Trace Hub and transfer its trace    111 control Intel Trace Hub and transfer its trace data to the debug host.
112                                                   112 
113 The driver needs to be told that such an arran    113 The driver needs to be told that such an arrangement is taking place
114 so that it does not touch any capture/port con    114 so that it does not touch any capture/port configuration and avoids
115 conflicting with the debug host's configuratio    115 conflicting with the debug host's configuration accesses. The only
116 activity that the driver will perform in this     116 activity that the driver will perform in this mode is collecting
117 software traces to the Software Trace Hub (an     117 software traces to the Software Trace Hub (an stm class device). The
118 user is still responsible for setting up adequ    118 user is still responsible for setting up adequate master/channel
119 mappings that the decoder on the receiving end    119 mappings that the decoder on the receiving end would recognize.
120                                                   120 
121 In order to enable the host mode, set the 'hos    121 In order to enable the host mode, set the 'host_mode' parameter of the
122 'intel_th' kernel module to 'y'. None of the v    122 'intel_th' kernel module to 'y'. None of the virtual output devices
123 will show up on the intel_th bus. Also, trace     123 will show up on the intel_th bus. Also, trace configuration and
124 capture controlling attribute groups of the 'g    124 capture controlling attribute groups of the 'gth' device will not be
125 exposed. The 'sth' device will operate as usua    125 exposed. The 'sth' device will operate as usual.
126                                                   126 
127 Software Sinks                                    127 Software Sinks
128 --------------                                    128 --------------
129                                                   129 
130 The Memory Storage Unit (MSU) driver provides     130 The Memory Storage Unit (MSU) driver provides an in-kernel API for
131 drivers to register themselves as software sin    131 drivers to register themselves as software sinks for the trace data.
132 Such drivers can further export the data via o    132 Such drivers can further export the data via other devices, such as
133 USB device controllers or network cards.          133 USB device controllers or network cards.
134                                                   134 
135 The API has two main parts::                      135 The API has two main parts::
136  - notifying the software sink that a particul    136  - notifying the software sink that a particular window is full, and
137    "locking" that window, that is, making it u    137    "locking" that window, that is, making it unavailable for the trace
138    collection; when this happens, the MSU driv    138    collection; when this happens, the MSU driver will automatically
139    switch to the next window in the buffer if     139    switch to the next window in the buffer if it is unlocked, or stop
140    the trace capture if it's not;                 140    the trace capture if it's not;
141  - tracking the "locked" state of windows and     141  - tracking the "locked" state of windows and providing a way for the
142    software sink driver to notify the MSU driv    142    software sink driver to notify the MSU driver when a window is
143    unlocked and can be used again to collect t    143    unlocked and can be used again to collect trace data.
144                                                   144 
145 An example sink driver, msu-sink illustrates t    145 An example sink driver, msu-sink illustrates the implementation of a
146 software sink. Functionally, it simply unlocks    146 software sink. Functionally, it simply unlocks windows as soon as they
147 are full, keeping the MSU running in a circula    147 are full, keeping the MSU running in a circular buffer mode. Unlike the
148 "multi" mode, it will fill out all the windows    148 "multi" mode, it will fill out all the windows in the buffer as opposed
149 to just the first one. It can be enabled by wr    149 to just the first one. It can be enabled by writing "sink" to the "mode"
150 file (assuming msu-sink.ko is loaded).            150 file (assuming msu-sink.ko is loaded).
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php