aboutsummaryrefslogtreecommitdiff
path: root/library/doxygen/Protocol.md
blob: 498e9e9f46308d80b571b5a918749fd7491992a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
\page mipi_syst_decoder_protocol SyS-T Data Protocol

[TOC]

Overview {#syst_decoder_prot_overview}
==============================================================================
The SyS-T Data Protocol is a byte sequence that represents a list of variable
length SyS-T Messages without additional padding bytes between them. The
SyS-T Data Protocol is intended for transmission over a lower level transport
protocol. The lower level protocol is expected to provide indicators that
identify the start and end of a SyS-T Message. One example of a lower level
transport protocol is the
[MIPI System Trace Protocol](http://mipi.org/specifications/debug#STP) (STP).
SyS-T includes message frame definitions that provides time stamping
and framing of a SyS-T Message based on STP packet types. The usage of
other lower level transports protocols is possible by adapting the message
writer or low level trace output functions from the platform level code.

The SyS-T Data Protocol includes various optional fields for ensuring data
integrity or time stamping. Depending on the capabilities of the lower level
protocol, these SyS-T Message fields may be redundant and so be omitted to
save trace bandwidth.


Data Field Byte Ordering {#syst_decoder_prot_byteorder}
------------------------------------------------------------------------------
All numeric data fields of the SyS-T Data Protocol follow little-endian byte
ordering where less significant bytes precede more significant ones. Only the
optional 128-bit Guid field is an exception to this rule. Its byte odering
follows RFC 4122 which defines Guid fields following big-endian ordering.

MIPI STPv2 Protocol Encoding {#syst_decoder_prot_format}
------------------------------------------------------------------------------
In order to timestamp packets and to give an indication of a valid SyS-T
Message beginning and end, each SyS-T Message starts with a
TIMESTAMPED STP data packet and ends with either a FLAG packet or a
MARKED data packet.
For environments that can only afford light weight value style traces, a
short message encoding is also available. This encoding uses a single IO to
generate an STP packet that is both MARKED and TIMESTAMPED. The following
table shows the supported STP packet sequences for a SyS-T Message. Dn means
either a D8, D16, D32 or D64 data packet.
The Dn* stands for a sequence of 0-x repeated Dn packets (of any sizes). Dn
packets with a smaller payload size can be combined into a Dn with a larger
size to reduce the number of IO's. For example, two D16 IO's can be combined
into a single D32 as long as the resulting binary payload data produces the
same result when being copied into memory.

  MIPI STPv2 Sequences     |  Description
---------------------------|--------------------------------------------
DnMTS                      |Single IO short message with Dn sized payload. This message is intended for numeric value only tracing.
DnTS-Dn*-DnM               |Arbitrary length sequence starting with a time stamped data value and followed by a sequence of zero or more payload data values. The last data value is MARKED to indicate the end of the sequence.
DnTS-Dn*-FLAG              |Arbitrary length sequence starting with time stamped data value and followed by a sequence of zero or more payload data values. The sequence is terminated with a FLAG packet.

The reason for supporting sequences terminated with either a MARKED or a
FLAG packet is to simplify the implementation for SW and HW trace generators.
HW based generates may prefer the MARKED method to save additional logic for
issuing a FLAG. SW trace generators may prefer the FLAG variant as it
avoids special handling for the last Dn.



Message Anatomy {#syst_decoder_prot_anatomy}
------------------------------------------------------------------------------
A SyS-T Message is a byte sequence that starts with a 32-bit header, followed by
mandatory and optional data attributes. The following picture shows the layout
of a SyS-T Message with all fields present.

![SyS-T Message Anatomy](mipi_sys_t_message_anatomy.png)


The message fields are:
 - A 32-bit [header] (#syst_decoder_prot_header) describing the message type and content
 - An optional 128-bit wide [GUID] (#syst_decoder_prot_guid) identifying the message originating software module.
 - An optional [location record] (#syst_decoder_prot_location)
 - An optional [payload length] (#syst_decoder_prot_length)
 - An optional [SyS-T timestamp] (#syst_prot_timestamp)
 - API specific [payload data] (#syst_decoder_prot_payload) from zero up to 64 Kbytes.
 - An optional CRC-32C [checksum] (#syst_decoder_prot_checksum)

Attributes are stored one after the other without any additional alignment bytes.

SyS-T Protocol Overhead {#syst_decoder_prot_overhead}
------------------------------------------------------------------------------
The typical data overhead of the SyS-T Data Protocol is 4 bytes (32 bits) per
message unless optional elements like CRC32 checksums are enabled.
These 4 bytes come from the 32-bit message header at the beginning
of each message.

In addition to the typical usage as a message trace, SyS-T protocol offers also
the following protocol types for small value or bulk data transfer support:

 - Single value onle traces can utilize SHORT messages. These provide a
   zero data overhead method on STP hardware using single DnMTS
   packets to hold the data.
 - SyS-T raw messages can be used to stream up to 64 Kbytes of payload data
   in a single SyS-T Message to tunnel another Data Protocol through SyS-T.


Data Protocol Details {#syst_decoder_prot_details}
==============================================================================

Header {#syst_decoder_prot_header}
------------------------------------------------------------------------------
A SyS-T header is 32-bit value using the following layout:

![SyS-T Message header](mipi_sys_t_event_header.png)

The meaning of the individual fields is explained in the table below.

Field   |Bits  |Description
--------|------|-----------------------------------------------------
RES31   |31..31|Reserved, Must be set to zero.
RES30   |30..30|Reserved, Must be set to zero.
SUBTYPE |24..29|Additional message type information that depends on TYPE.
GUID    |23..23|Indicates whether the optional GUID is present
ORIGIN  |12..22|message origin and/or unit information
TS      |11..11|Indicates whether the optional message time stamp is present.
CHK     |10..10|Indicates whether the optional Checksum is present at the end.
LEN     |9..9  |Indicates whether the optional Payload length is present.
LOC     |8..8  |Indicates whether the optional Location Record field is present.
RES7    |7..7  |Reserved, Must be set to zero.
SEVERITY|4..6  |Severity level of the message.
TYPE    |0..3  |Message type

C-Definition (struct mipi_syst_msg_tag):
\code{.cpp}
struct mipi_syst_msg_tag {
     mipi_syst_u32 et_type:4;     /**< SyS-T message type ID            */
     mipi_syst_u32 et_severity:3; /**< severity level of message        */
     mipi_syst_u32 et_res7:1;     /**< reserved for future use          */
     mipi_syst_u32 et_location:1; /**< indicate location information    */
     mipi_syst_u32 et_length:1;   /**< indicate variable length message */
     mipi_syst_u32 et_chksum:1;   /**< indicate 32bit CRC               */
     mipi_syst_u32 et_timestamp:1;/**< indicate 64 bit timestamp        */
     mipi_syst_u32 et_modunit:11; /**< unit for GUID or module:unit     */
     mipi_syst_u32 et_guid:1;     /**< 128 bit GUID present             */
     mipi_syst_u32 et_subtype:6;  /**< type dependent sub category      */
     mipi_syst_u32 et_res30:1;    /**< reserved for future use          */
     mipi_syst_u32 et_res31:1;    /**< reserved for future use          */
};
\endcode

Severity {#syst_decoder_prot_header_severity}
------------------------------------------------------------------------------

An optional severity level is assigned to a SyS-T Message to distinguish
informational messages from warnings and errors. Severity levels are used
for message classification and filtering. The severity levels are ordered
by ascending numerical values.

Severity                   |Value  | Description
---------------------------|:-----:|----------------------------------------------
MIPI_SYST_SEVERITY_MAX     | 0     |No assigned severity. This is used for messages that should bypass filtering. This is typically used with RAW message that tunnel other protocols over SyS-T Messages.
MIPI_SYST_SEVERITY_FATAL   | 1     |Indicates a fatal level message. Such messages provide information about a failure condition from which the system cannot recover or cannot continue to function properly.
MIPI_SYST_SEVERITY_ERROR   | 2     |Indicates an error level message. Such messages provide information about an operation failure or inappropriate action that the system is not designed to handle. Errors may or may not cause a feature or system to subsequently fail.
MIPI_SYST_SEVERITY_WARNING | 3     |Indicates a warning level message. Such messages provide information about an undesirable, but recoverable situation that may result in problems if no actions are taken. Warning message information can be utilized to adaptively adjust system operations to avoid failures or to improve performance based on the use case.
MIPI_SYST_SEVERITY_INFO    | 4     |Indicates an information level message. Such messages provide component specific information about operational actions and progress. They are intended for component specialists to analyze system behavior.
MIPI_SYST_SEVERITY_USER1   | 5     |Indicates a first user-defined message level for information with a higher verbosity than MIPI_SYST_SEVERITY_INFO. They are intended for component specialists to analyze system behavior in greater detail.
MIPI_SYST_SEVERITY_USER2   | 6     |Indicates a second user-defined level for informational messages with a higher verbosity than MIPI_SYST_SEVERITY_USER1. They are intended for component specialists to analyze system behavior in even greater detail.
MIPI_SYST_SEVERITY_DEBUG   | 7     |Indicate a debug level message. Such messages provide information that is intended for system developers for detailed analysis and debug of system behavior. It provides the finest granularity of trace information and is typically used during verification and debug phases.


Message Origin or GUID {#syst_decoder_prot_guid}
------------------------------------------------------------------------------
A SyS-T Message may contain a 128-bit wide GUID to identify the instrumented
software module in a unique way. A GUID is used if the guid bit in the header
is set. Otherwise the header origin field defines the message origin,
saving the bandwidth and space that would be used for the additional GUID bits.

Omitting the GUID is possible when the origin field or transport layer
information sufficiently identifies the trace emitting source. An example
for transport layer information are the Master and Channel pairs for transports
using MIPI System Trace Protocol. If the message was sent from a dynamically
assigned master and channel pool, then these values are not sufficient and a
GUID must be used to describe the origin. If the handle got initialized using
the #MIPI_SYST_SET_HANDLE_GUID_UNIT API then the GUID is emitted directly after
the header in each message.
Note:
The GUID structure follows https://www.ietf.org/rfc/rfc4122.txt.

Location {#syst_decoder_prot_location}
------------------------------------------------------------------------------

A SyS-T Message can contain location information describing the position of
its instrumentation call either as an instruction pointer address or as a
"file:line" ID pair. This location information is generated if one of the
API variants with the `_LOCADDR`, `_LOC16` or `_LOC32` suffix in the name is
used.

### C Definition of Location ###

\code{.cpp}
/**
 * Specify format of used message location information that is added to the
 * message data if tag.et_location == 1
 */
struct mipi_syst_msglocation {
    /** Message format
     * 0 = 16-Bit file and 16-Bit line (total: 32-bit)
     * 1 = 32-Bit file and 32-Bit line (total: 64-bit)
     * 2 = 32-bit code address
     * 3 = 64-bit code address
     */
    mipi_syst_u8 el_format;
    union {
        union mipi_syst_msglocation32 loc32; /**< data for 32-bit variant  */
        union mipi_syst_msglocation64 loc64; /**< data for 64-bit variant  */
    } el_u;
};


/**
 * Location information inside a message (32-bit format)
 * Location is either the source position of the instrumentation call, or
 * the call instruction pointer value.
 */
union mipi_syst_msglocation32 {
    struct {
        mipi_syst_u16 etls_fileID; /**< ID of instrumented file   */
        mipi_syst_u16 etls_lineNo; /**< line number in file       */
    } etls_source_location;
    mipi_syst_u32 etls_code_location:32;
    /**< instruction pointer value */
};

/**
 * Location information inside a message (64-bit format)
 * Location is either the source position of the instrumentation call, or
 * the call instruction pointer value.
 */
union mipi_syst_msglocation64 {
    struct {
        mipi_syst_u32 etls_fileID; /**< ID of instrumented file   */
        mipi_syst_u32 etls_lineNo; /**< line number in file       */
    } etls_source_location;
    mipi_syst_u64 etls_code_location:64;
    /**< instruction pointer value */
};

\endcode

Length {#syst_decoder_prot_length}
------------------------------------------------------------------------------

The location information is followed by a 16-bit length field if  the header bit
et_length is set. This length indicates the number of message payload bytes that
follow.

### C Definition of Length ###

\code{.cpp}
    syst_u16_t ed_len;
\endcode


Message Payload {#syst_decoder_prot_payload}
------------------------------------------------------------------------------
A SyS-T Message can contain a type specific payload of up to 64 Kbytes. The payload
appears after the optional message fields, but before the optional checksum.

Checksum {#syst_decoder_prot_checksum}
------------------------------------------------------------------------------
A SyS-T Message can end with a 32-bit CRC-32C checksum calculated over all of
the message bytes, excluding the checksum value itself. The CRC generation is
a per SyS-T handle choice. It is enabled or disabled by the
#MIPI_SYST_ENABLE_HANDLE_CHECKSUM API. The default is disabled.

Protocol Timestamp Handling  {#syst_prot_timestamp}
==============================================================================
The default usage for the SyS-T protocol is to rely on a transport timestamp
generated by, for example, trace arbiter hardware or a trace creating driver.
In this case, a SyS-T Message does not carry its own timestamp information. In
scenarios where no hardware time stamp exists, or this timestamp is not
accurate, SyS-T Messages can include their own time stamp. An example scenario
for this is when messages are buffered by a trace source before they are sent.
In this case, the hardware time stamp will reflect a later message submission
time, not the message creation time, which is typically what is desired.

Clock Synchronization {#syst_prot_timestamp_sync}
------------------------------------------------------------------------------
The SyS-T protocol facilitates correlating messages that use a time stamp of
their own with the trace timestamp of the underlying transport protocol. This
correlation is done using a synchronisation message, which contains both the
transport protocol timestamp and the source clock value and frequency from
the SyS-T message clock.

These data values build a time correlation point between the transport
clock and the SyS-T message clock. If MIPI STP is the transport protocol then
the D32TS header time stamp will define the transport time stamp. The message
is expected to be sent periodically from any source that requires time
synchronisation with the transport protocol. Host side tooling needs at least
one of these records in a trace stream to do the time correlation. Typically
these synchronization messages are sent either periodically, such as once
every second, or at the beginning of trace emitting phases.


SyS-T Messages Types {#syst_decoder_prot_msg_types}
==============================================================================
This chapter shows the major SyS-T message types.
The type can be one of the following (See [C Definition] (@ref mipi_syst_msgtype) ):



Value   |SyS-T Name               |Description
--------|-------------------------|-------------------------------------
0       |MIPI_SYST_TYPE_BUILD     |SyS-T client build version information
1       |MIPI_SYST_TYPE_SHORT32   |32 Bit message with user defined payload value
2       |MIPI_SYST_TYPE_STRING    |Text message output for UTF-8 encoded strings
3       |MIPI_SYST_TYPE_CATALOG   |Catalog message output support formatting string with parameters
4,5     |RESERVED-FOR-FUTURE-USE  |Reserved
6       |MIPI_SYST_TYPE_RAW       |Raw binary payload
7       |MIPI_SYST_TYPE_SHORT64   |64 Bit message with user defined payload value
8       |MIPI_SYST_TYPE_CLOCK     |Timing synchronization
9..15   |RESERVED-FOR-FUTURE-USE  |Reserved

For further information on the different message type contents, read chapter 8
in the MIPI Alliance Specification for System Software-Trace (SyS-T).