MIPI SyS-T over STP

The MIPI SyS-T protocol driver can be used with STM class devices togenerate standardized trace stream. Aside from being a standard, itprovides better trace source identification and timestamp correlation.

In order to use the MIPI SyS-T protocol driver with your STM device,first, you’ll need CONFIG_STM_PROTO_SYS_T.

Now, you can select which protocol driver you want to use when you createa policy for your STM device, by specifying it in the policy name:

# mkdir /config/stp-policy/dummy_stm.0:p_sys-t.my-policy/

In other words, the policy name format is extended like this:

<device_name>:<protocol_name>.<policy_name>

With Intel TH, therefore it can look like “0-sth:p_sys-t.my-policy”.

If the protocol name is omitted, the STM class will chose whicheverprotocol driver was loaded first.

You can also double check that everything is working as expected by

# cat /config/stp-policy/dummy_stm.0:p_sys-t.my-policy/protocolp_sys-t

Now, with the MIPI SyS-T protocol driver, each policy node in theconfigfs gets a few additional attributes, which determine per-sourceparameters specific to the protocol:

# mkdir /config/stp-policy/dummy_stm.0:p_sys-t.my-policy/default# ls /config/stp-policy/dummy_stm.0:p_sys-t.my-policy/defaultchannelsclocksync_intervaldo_lenmastersts_intervaluuid

The most important one here is the “uuid”, which determines the UUIDthat will be used to tag all data coming from this source. It isautomatically generated when a new node is created, but it is likelythat you would want to change it.

do_len switches on/off the additional “payload length” field in theMIPI SyS-T message header. It is off by default as the STP alreadymarks message boundaries.

ts_interval and clocksync_interval determine how much time in millisecondscan pass before we need to include a protocol (not transport, aka STP)timestamp in a message header or send a CLOCKSYNC packet, respectively.

See Documentation/ABI/testing/configfs-stp-policy-p_sys-t for moredetails.