2750af50a3
As of Intel SDM (https://www.intel.com/sdm) version 076, there is a new Intel PT feature called Event Trace which requires 2 new packets CFE and EVD. Add them to the packet decoder and packet decoder test. Committer notes: I got the "Intel® 64 and IA-32 architectures software developer’s manual combined volumes: 1, 2A, 2B, 2C, 2D, 3A, 3B, 3C, 3D, and 4" PDF at: https://cdrdv2.intel.com/v1/dl/getContent/671200 And these new packets are described in page 3951: <quote> 32.2.4 Event Trace is a capability that exposes details about the asynchronous events, when they are generated, and when their corresponding software event handler completes execution. These include: o Interrupts, including NMI and SMI, including the interrupt vector when defined. o Faults, exceptions including the fault vector. — Page faults additionally include the page fault address, when in context. o Event handler returns, including IRET and RSM. o VM exits and VM entries.¹ — VM exits include the values written to the “exit reason” and “exit qualification” VMCS fields. INIT and SIPI events. o TSX aborts, including the abort status returned for the RTM instructions. o Shutdown. Additionally, it provides indication of the status of the Interrupt Flag (IF), to indicate when interrupts are masked. </quote> Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Link: https://lore.kernel.org/r/20220124084201.2699795-4-adrian.hunter@intel.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
93 lines
2.0 KiB
C
93 lines
2.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* intel_pt_pkt_decoder.h: Intel Processor Trace support
|
|
* Copyright (c) 2013-2014, Intel Corporation.
|
|
*/
|
|
|
|
#ifndef INCLUDE__INTEL_PT_PKT_DECODER_H__
|
|
#define INCLUDE__INTEL_PT_PKT_DECODER_H__
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
#define INTEL_PT_PKT_DESC_MAX 256
|
|
|
|
#define INTEL_PT_NEED_MORE_BYTES -1
|
|
#define INTEL_PT_BAD_PACKET -2
|
|
|
|
#define INTEL_PT_PSB_STR "\002\202\002\202\002\202\002\202" \
|
|
"\002\202\002\202\002\202\002\202"
|
|
#define INTEL_PT_PSB_LEN 16
|
|
|
|
#define INTEL_PT_PKT_MAX_SZ 16
|
|
|
|
#define INTEL_PT_VMX_NR_FLAG 1
|
|
|
|
enum intel_pt_pkt_type {
|
|
INTEL_PT_BAD,
|
|
INTEL_PT_PAD,
|
|
INTEL_PT_TNT,
|
|
INTEL_PT_TIP_PGD,
|
|
INTEL_PT_TIP_PGE,
|
|
INTEL_PT_TSC,
|
|
INTEL_PT_TMA,
|
|
INTEL_PT_MODE_EXEC,
|
|
INTEL_PT_MODE_TSX,
|
|
INTEL_PT_MTC,
|
|
INTEL_PT_TIP,
|
|
INTEL_PT_FUP,
|
|
INTEL_PT_CYC,
|
|
INTEL_PT_VMCS,
|
|
INTEL_PT_PSB,
|
|
INTEL_PT_PSBEND,
|
|
INTEL_PT_CBR,
|
|
INTEL_PT_TRACESTOP,
|
|
INTEL_PT_PIP,
|
|
INTEL_PT_OVF,
|
|
INTEL_PT_MNT,
|
|
INTEL_PT_PTWRITE,
|
|
INTEL_PT_PTWRITE_IP,
|
|
INTEL_PT_EXSTOP,
|
|
INTEL_PT_EXSTOP_IP,
|
|
INTEL_PT_MWAIT,
|
|
INTEL_PT_PWRE,
|
|
INTEL_PT_PWRX,
|
|
INTEL_PT_BBP,
|
|
INTEL_PT_BIP,
|
|
INTEL_PT_BEP,
|
|
INTEL_PT_BEP_IP,
|
|
INTEL_PT_CFE,
|
|
INTEL_PT_CFE_IP,
|
|
INTEL_PT_EVD,
|
|
};
|
|
|
|
struct intel_pt_pkt {
|
|
enum intel_pt_pkt_type type;
|
|
int count;
|
|
uint64_t payload;
|
|
};
|
|
|
|
/*
|
|
* Decoding of BIP packets conflicts with single-byte TNT packets. Since BIP
|
|
* packets only occur in the context of a block (i.e. between BBP and BEP), that
|
|
* context must be recorded and passed to the packet decoder.
|
|
*/
|
|
enum intel_pt_pkt_ctx {
|
|
INTEL_PT_NO_CTX, /* BIP packets are invalid */
|
|
INTEL_PT_BLK_4_CTX, /* 4-byte BIP packets */
|
|
INTEL_PT_BLK_8_CTX, /* 8-byte BIP packets */
|
|
};
|
|
|
|
const char *intel_pt_pkt_name(enum intel_pt_pkt_type);
|
|
|
|
int intel_pt_get_packet(const unsigned char *buf, size_t len,
|
|
struct intel_pt_pkt *packet,
|
|
enum intel_pt_pkt_ctx *ctx);
|
|
|
|
void intel_pt_upd_pkt_ctx(const struct intel_pt_pkt *packet,
|
|
enum intel_pt_pkt_ctx *ctx);
|
|
|
|
int intel_pt_pkt_desc(const struct intel_pt_pkt *packet, char *buf, size_t len);
|
|
|
|
#endif
|