2019-05-29 07:18:02 -07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2015-07-17 19:33:37 +03:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
|
2021-02-18 11:57:53 +02:00
|
|
|
#define INTEL_PT_VMX_NR_FLAG 1
|
|
|
|
|
2015-07-17 19:33:37 +03:00
|
|
|
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,
|
2015-07-17 19:33:53 +03:00
|
|
|
INTEL_PT_TMA,
|
2015-07-17 19:33:37 +03:00
|
|
|
INTEL_PT_MODE_EXEC,
|
|
|
|
INTEL_PT_MODE_TSX,
|
2015-07-17 19:33:53 +03:00
|
|
|
INTEL_PT_MTC,
|
2015-07-17 19:33:37 +03:00
|
|
|
INTEL_PT_TIP,
|
|
|
|
INTEL_PT_FUP,
|
2015-07-17 19:33:53 +03:00
|
|
|
INTEL_PT_CYC,
|
|
|
|
INTEL_PT_VMCS,
|
2015-07-17 19:33:37 +03:00
|
|
|
INTEL_PT_PSB,
|
|
|
|
INTEL_PT_PSBEND,
|
|
|
|
INTEL_PT_CBR,
|
2015-07-17 19:33:53 +03:00
|
|
|
INTEL_PT_TRACESTOP,
|
2015-07-17 19:33:37 +03:00
|
|
|
INTEL_PT_PIP,
|
|
|
|
INTEL_PT_OVF,
|
2015-07-17 19:33:53 +03:00
|
|
|
INTEL_PT_MNT,
|
2017-05-26 11:17:14 +03:00
|
|
|
INTEL_PT_PTWRITE,
|
|
|
|
INTEL_PT_PTWRITE_IP,
|
|
|
|
INTEL_PT_EXSTOP,
|
|
|
|
INTEL_PT_EXSTOP_IP,
|
|
|
|
INTEL_PT_MWAIT,
|
|
|
|
INTEL_PT_PWRE,
|
|
|
|
INTEL_PT_PWRX,
|
2019-06-10 10:27:53 +03:00
|
|
|
INTEL_PT_BBP,
|
|
|
|
INTEL_PT_BIP,
|
|
|
|
INTEL_PT_BEP,
|
|
|
|
INTEL_PT_BEP_IP,
|
perf intel-pt: pkt-decoder: Add CFE and EVD packets
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>
2022-01-24 10:41:39 +02:00
|
|
|
INTEL_PT_CFE,
|
|
|
|
INTEL_PT_CFE_IP,
|
|
|
|
INTEL_PT_EVD,
|
2015-07-17 19:33:37 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
struct intel_pt_pkt {
|
|
|
|
enum intel_pt_pkt_type type;
|
|
|
|
int count;
|
|
|
|
uint64_t payload;
|
|
|
|
};
|
|
|
|
|
2019-06-10 10:27:53 +03:00
|
|
|
/*
|
|
|
|
* 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 */
|
|
|
|
};
|
|
|
|
|
2015-07-17 19:33:37 +03:00
|
|
|
const char *intel_pt_pkt_name(enum intel_pt_pkt_type);
|
|
|
|
|
|
|
|
int intel_pt_get_packet(const unsigned char *buf, size_t len,
|
2019-06-10 10:27:53 +03:00
|
|
|
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);
|
2015-07-17 19:33:37 +03:00
|
|
|
|
|
|
|
int intel_pt_pkt_desc(const struct intel_pt_pkt *packet, char *buf, size_t len);
|
|
|
|
|
|
|
|
#endif
|