pt_packet - Man Page

encode/decode an Intel(R) Processor Trace packet

Synopsis

#include <intel-pt.h>

struct pt_packet;

int pt_enc_next(struct pt_packet_encoder *encoder,

                const struct pt_packet *packet);

int pt_pkt_next(struct pt_packet_decoder *decoder,

                struct pt_packet *packet, size_t size);

Link with -lipt.

Description

pt_enc_next() encodes its packet argument as Intel Processor Trace (Intel PT) packet at encoder’s current position. On success, sets encoder’s current position to point to the first byte after the encoded packet.

pt_pkt_next() decodes the Intel PT packet at decoder’s current position into packet. On success, sets decoder*’s current position to point to the first byte after the decoded packet.

The caller is responsible for allocating and freeing the pt_packet object pointed to be the packet argument.

The size argument of pt_pkt_next() must be set to sizeof(struct pt_packet). The function will provide at most size bytes of packet data. A newer decoder library may provide packet types that are not yet defined. Those packets may be truncated. Unknown packet types should be ignored.

If the packet decoder does not know the packet opcode at decoder’s current position and if decoder’s configuration contains a packet decode callback function, pt_pkt_next() will call that callback function to decode the unknown packet. On success, a ppt_unknown packet type is provided with the information provided by the decode callback function.

An Intel PT packet is described by the pt_packet structure, which is declared as:

/** An Intel PT packet. */
struct pt_packet {
    /** The type of the packet.
     *
     * This also determines the \@variant field.
     */
    enum pt_packet_type type;

    /** The size of the packet including opcode and payload. */
    uint8_t size;

    /** Packet specific data. */
    union {
        /** Packets: pad, ovf, psb, psbend, stop - no payload. */

        /** Packet: tnt-8, tnt-64. */
        struct pt_packet_tnt tnt;

        /** Packet: tip, fup, tip.pge, tip.pgd. */
        struct pt_packet_ip ip;

        /** Packet: mode. */
        struct pt_packet_mode mode;

        /** Packet: pip. */
        struct pt_packet_pip pip;

        /** Packet: tsc. */
        struct pt_packet_tsc tsc;

        /** Packet: cbr. */
        struct pt_packet_cbr cbr;

        /** Packet: tma. */
        struct pt_packet_tma tma;

        /** Packet: mtc. */
        struct pt_packet_mtc mtc;

        /** Packet: cyc. */
        struct pt_packet_cyc cyc;

        /** Packet: vmcs. */
        struct pt_packet_vmcs vmcs;

        /** Packet: mnt. */
        struct pt_packet_mnt mnt;

        /** Packet: unknown. */
        struct pt_packet_unknown unknown;
    } payload;
};

See the intel-pt.h header file for more detail.

Return Value

pt_enc_next() returns the number of bytes written on success or a negative pt_error_code enumeration constant in case of an error.

pt_pkt_next() returns the number of bytes consumed on success or a negative pt_error_code enumeration constant in case of an error.

Errors

pte_invalid

The encoder/decoder or packet argument is NULL or the size argument is zero (pt_pkt_next() only).

pte_nosync

decoder has not been synchronized onto the trace stream (pt_pkt_next() only). Use pt_pkt_sync_forward(3), pt_pkt_sync_backward(3), or pt_pkt_sync_set(3) to synchronize decoder.

pte_eos

Encode/decode has reached the end of the trace buffer. There is not enough space in the trace buffer to generate packet (pt_enc_next()) or the trace buffer does not contain a full Intel PT packet (pt_pkt_next()).

pte_bad_opc

The type of the packet argument is not supported (pt_enc_next()) or the packet at decoder’s current position is not supported (pt_pkt_next()).

pte_bad_packet

The payload or parts of the payload of the packet argument is not supported (pt_enc_next()) or the packet at decoder’s current position contains unsupported payload (pt_pkt_next()).

Example

The example shows a typical Intel PT packet decode loop.

int foo(struct pt_packet_decoder *decoder) {
    for (;;) {
        struct pt_packet packet;
        int errcode;

        errcode = pt_pkt_next(decoder, &packet, sizeof(packet));
        if (errcode < 0)
            return errcode;

        [...]
    }
}

See Also

pt_alloc_encoder(3), pt_pkt_alloc_decoder(3), pt_pkt_sync_forward(3), pt_pkt_sync_backward(3), pt_pkt_sync_set(3)

Referenced By

pt_alloc_encoder(3), pt_enc_get_offset(3), pt_pkt_alloc_decoder(3), pt_pkt_get_offset(3), pt_pkt_sync_forward(3).

The man pages pt_enc_next(3) and pt_pkt_next(3) are aliases of pt_packet(3).