blob: 15027d865b437089ac8c638662b47b136b32aab6 [file] [log] [blame]
/*
* Copyright (c) 2013-2015, Intel Corporation
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* * Neither the name of Intel Corporation nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#include "ptunit.h"
#include "pt_last_ip.h"
#include "pt_decoder_function.h"
#include "pt_query_decoder.h"
#include "pt_encoder.h"
/* A query testing fixture. */
struct ptu_decoder_fixture {
/* The test fixture initialization and finalization functions. */
struct ptunit_result (*init)(struct ptu_decoder_fixture *);
struct ptunit_result (*fini)(struct ptu_decoder_fixture *);
/* Encode an optional header for the test to read over. */
struct ptunit_result (*header)(struct ptu_decoder_fixture *);
/* The trace buffer. */
uint8_t buffer[1024];
/* The configuration under test. */
struct pt_config config;
/* A encoder and query decoder for the above configuration. */
struct pt_encoder encoder;
struct pt_query_decoder decoder;
/* For tracking last-ip in tests. */
struct pt_last_ip last_ip;
};
/* An invalid address. */
static const uint64_t pt_dfix_bad_ip = (1ull << 62) - 1;
/* A sign-extended address. */
static const uint64_t pt_dfix_sext_ip = 0xffffff00ff00ff00ull;
/* The highest possible address. */
static const uint64_t pt_dfix_max_ip = (1ull << 47) - 1;
/* The highest possible cr3 value. */
static const uint64_t pt_dfix_max_cr3 = ((1ull << 47) - 1) & ~0x1f;
/* Synchronize the decoder at the beginning of the trace stream, avoiding the
* initial PSB header.
*/
static struct ptunit_result ptu_sync_decoder(struct pt_query_decoder *decoder)
{
ptu_ptr(decoder);
decoder->enabled = 1;
(void) pt_df_fetch(&decoder->next, decoder->pos, &decoder->config);
return ptu_passed();
}
/* Cut off the last encoded packet. */
static struct ptunit_result cutoff(struct pt_query_decoder *decoder,
const struct pt_encoder *encoder)
{
uint8_t *pos;
ptu_ptr(decoder);
ptu_ptr(encoder);
pos = encoder->pos;
ptu_ptr(pos);
pos -= 1;
ptu_ptr_le(decoder->config.begin, pos);
decoder->config.end = pos;
return ptu_passed();
}
static struct ptunit_result indir_not_synced(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
int errcode;
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_nosync);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result cond_not_synced(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
int errcode, tnt = 0xbc, taken = tnt;
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_nosync);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result event_not_synced(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_event event;
int errcode;
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_nosync);
return ptu_passed();
}
static struct ptunit_result indir_null(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
int errcode;
errcode = pt_qry_indirect_branch(NULL, &addr);
ptu_int_eq(errcode, -pte_invalid);
ptu_uint_eq(addr, ip);
errcode = pt_qry_indirect_branch(decoder, NULL);
ptu_int_eq(errcode, -pte_invalid);
ptu_ptr_eq(decoder->pos, config->begin);
return ptu_passed();
}
static struct ptunit_result indir_empty(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
int errcode;
decoder->pos = config->end;
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_eos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result indir(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip packet;
uint64_t addr = pt_dfix_bad_ip;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_sext_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_tip(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
if (ipc == pt_ipc_suppressed) {
ptu_int_eq(errcode, pts_ip_suppressed | pts_eos);
ptu_uint_eq(addr, pt_dfix_bad_ip);
} else {
ptu_int_eq(errcode, pts_eos);
ptu_uint_eq(addr, dfix->last_ip.ip);
}
return ptu_passed();
}
static struct ptunit_result indir_tnt(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip packet;
uint64_t addr = pt_dfix_bad_ip;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_sext_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_tnt_8(encoder, 0ull, 1);
pt_encode_tip(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
if (ipc == pt_ipc_suppressed) {
ptu_int_eq(errcode, pts_ip_suppressed);
ptu_uint_eq(addr, pt_dfix_bad_ip);
} else {
ptu_int_eq(errcode, 0);
ptu_uint_eq(addr, dfix->last_ip.ip);
}
return ptu_passed();
}
static struct ptunit_result indir_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
int errcode;
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_eos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result
indir_skip_tnt_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
int errcode;
pt_encode_tnt_8(encoder, 0, 1);
pt_encode_tnt_8(encoder, 0, 1);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_bad_query);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result
indir_skip_tip_pge_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_tip_pge(encoder, 0, pt_ipc_sext_48);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result
indir_skip_tip_pgd_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_sext_48);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result
indir_skip_fup_tip_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
const uint8_t *pos;
int errcode;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result
indir_skip_fup_tip_pgd_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t ip = pt_dfix_bad_ip, addr = ip;
const uint8_t *pos;
int errcode;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_sext_48);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_uint_eq(addr, ip);
return ptu_passed();
}
static struct ptunit_result cond_null(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
int errcode, tnt = 0xbc, taken = tnt;
errcode = pt_qry_cond_branch(NULL, &taken);
ptu_int_eq(errcode, -pte_invalid);
ptu_int_eq(taken, tnt);
errcode = pt_qry_cond_branch(decoder, NULL);
ptu_int_eq(errcode, -pte_invalid);
ptu_ptr_eq(decoder->pos, config->begin);
return ptu_passed();
}
static struct ptunit_result cond_empty(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
int errcode, tnt = 0xbc, taken = tnt;
decoder->pos = config->end;
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_eos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result cond(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
pt_encode_tnt_8(encoder, 0x02, 3);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, 0);
ptu_int_eq(taken, 0);
taken = tnt;
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, 0);
ptu_int_eq(taken, 1);
taken = tnt;
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(taken, 0);
taken = tnt;
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_eos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result cond_skip_tip_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
const uint8_t *pos;
pos = encoder->pos;
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
pt_encode_tnt_8(encoder, 0, 1);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result
cond_skip_tip_pge_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
const uint8_t *pos;
pos = encoder->pos;
pt_encode_tip_pge(encoder, 0, pt_ipc_sext_48);
pt_encode_tnt_8(encoder, 0, 1);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result
cond_skip_tip_pgd_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
const uint8_t *pos;
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_sext_48);
pt_encode_tnt_8(encoder, 0, 1);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result
cond_skip_fup_tip_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
const uint8_t *pos;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
pt_encode_tnt_8(encoder, 0, 1);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result
cond_skip_fup_tip_pgd_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
int errcode, tnt = 0xbc, taken = tnt;
const uint8_t *pos;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_sext_48);
pt_encode_tnt_8(encoder, 0, 1);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_cond_branch(decoder, &taken);
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
ptu_int_eq(taken, tnt);
return ptu_passed();
}
static struct ptunit_result event_null(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
struct pt_event event;
int errcode;
errcode = pt_qry_event(NULL, &event, sizeof(event));
ptu_int_eq(errcode, -pte_invalid);
errcode = pt_qry_event(decoder, NULL, sizeof(event));
ptu_int_eq(errcode, -pte_invalid);
ptu_ptr_eq(decoder->pos, config->begin);
return ptu_passed();
}
static struct ptunit_result event_bad_size(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_event event;
int errcode;
errcode = pt_qry_event(decoder, &event, 4);
ptu_int_eq(errcode, -pte_invalid);
return ptu_passed();
}
static struct ptunit_result event_small_size(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
union {
struct pt_event event;
uint8_t buffer[41];
} variant;
int errcode;
memset(variant.buffer, 0xcd, sizeof(variant.buffer));
pt_encode_tip_pge(encoder, 0ull, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &variant.event, 40);
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(variant.event.type, ptev_enabled);
ptu_uint_eq(variant.buffer[40], 0xcd);
return ptu_passed();
}
static struct ptunit_result event_big_size(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
union {
struct pt_event event;
uint8_t buffer[1024];
} variant;
int errcode;
memset(variant.buffer, 0xcd, sizeof(variant.buffer));
pt_encode_tip_pge(encoder, 0ull, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &variant.event, sizeof(variant.buffer));
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(variant.event.type, ptev_enabled);
ptu_uint_eq(variant.buffer[sizeof(variant.event)], 0xcd);
return ptu_passed();
}
static struct ptunit_result event_empty(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_config *config = &decoder->config;
struct pt_event event;
int errcode;
decoder->pos = config->end;
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result event_enabled(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip packet;
struct pt_event event;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_tip_pge(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
if (ipc == pt_ipc_suppressed)
ptu_int_eq(errcode, -pte_bad_packet);
else {
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_enabled);
ptu_uint_eq(event.variant.enabled.ip, dfix->last_ip.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
}
return ptu_passed();
}
static struct ptunit_result
event_enabled_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_tip_pge(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result event_disabled(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip packet;
struct pt_event event;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_sext_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_tip_pgd(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.disabled.ip, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_disabled);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_disabled_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_tip_pgd(encoder, 0, pt_ipc_update_32);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_async_disabled(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip fup, tip;
struct pt_event event;
int errcode;
fup.ipc = pt_ipc_sext_48;
fup.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &fup, &dfix->config);
tip.ipc = ipc;
tip.ip = pt_dfix_sext_ip;
pt_last_ip_update_ip(&dfix->last_ip, &tip, &dfix->config);
pt_encode_fup(encoder, fup.ip, fup.ipc);
pt_encode_tip_pgd(encoder, tip.ip, tip.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.async_disabled.ip, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_async_disabled);
ptu_uint_eq(event.variant.async_disabled.at, fup.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_async_disabled_suppressed_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_fup(encoder, 0, pt_ipc_suppressed);
pt_encode_tip_pgd(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_bad_packet);
return ptu_passed();
}
static struct ptunit_result
event_async_disabled_cutoff_fail_a(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
uint64_t at = pt_dfix_sext_ip;
const uint8_t *pos;
int errcode;
pt_encode_fup(encoder, at, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_update_16);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result
event_async_disabled_cutoff_fail_b(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result
event_async_branch_suppressed_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_fup(encoder, 0, pt_ipc_suppressed);
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_bad_packet);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result event_async_branch(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip fup, tip;
struct pt_event event;
int errcode;
fup.ipc = pt_ipc_sext_48;
fup.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &fup, &dfix->config);
tip.ipc = ipc;
tip.ip = pt_dfix_sext_ip;
pt_last_ip_update_ip(&dfix->last_ip, &tip, &dfix->config);
pt_encode_fup(encoder, fup.ip, fup.ipc);
pt_encode_tip(encoder, tip.ip, tip.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.async_branch.to, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_async_branch);
ptu_uint_eq(event.variant.async_branch.from, fup.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_async_branch_cutoff_fail_a(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
const uint8_t *pos;
int errcode;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pos = encoder->pos;
pt_encode_tip_pgd(encoder, 0, pt_ipc_update_16);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result
event_async_branch_cutoff_fail_b(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result event_paging(struct ptu_decoder_fixture *dfix,
uint8_t flags, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
uint64_t cr3 = pt_dfix_max_cr3;
int errcode;
pt_encode_pip(encoder, cr3, flags);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_paging);
ptu_uint_eq(event.variant.paging.cr3, cr3);
ptu_uint_eq(event.variant.paging.non_root, (flags & pt_pl_pip_nr) != 0);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_paging_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_pip(encoder, 0, 0);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_async_paging(struct ptu_decoder_fixture *dfix, uint8_t flags,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
uint64_t to = pt_dfix_sext_ip, from = to & ~0xffffull;
uint64_t cr3 = pt_dfix_max_cr3;
int errcode;
pt_encode_fup(encoder, from, pt_ipc_sext_48);
pt_encode_pip(encoder, cr3, flags);
pt_encode_tip(encoder, to, pt_ipc_update_16);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_event_pending);
ptu_int_eq(event.type, ptev_async_branch);
ptu_uint_eq(event.variant.async_branch.from, from);
ptu_uint_eq(event.variant.async_branch.to, to);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_async_paging);
ptu_uint_eq(event.variant.async_paging.cr3, cr3);
ptu_uint_eq(event.variant.async_paging.non_root,
(flags & pt_pl_pip_nr) != 0);
ptu_uint_eq(event.variant.async_paging.ip, to);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_async_paging_suppressed(struct ptu_decoder_fixture *dfix, uint8_t flags,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
uint64_t from = pt_dfix_sext_ip, cr3 = pt_dfix_max_cr3;
int errcode;
pt_encode_fup(encoder, from, pt_ipc_sext_48);
pt_encode_pip(encoder, cr3, flags);
pt_encode_tip(encoder, 0, pt_ipc_suppressed);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_event_pending);
ptu_uint_ne(event.ip_suppressed, 0);
ptu_int_eq(event.type, ptev_async_branch);
ptu_uint_eq(event.variant.async_branch.from, from);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_uint_ne(event.ip_suppressed, 0);
ptu_int_eq(event.type, ptev_async_paging);
ptu_uint_eq(event.variant.async_paging.cr3, cr3);
ptu_uint_eq(event.variant.async_paging.non_root,
(flags & pt_pl_pip_nr) != 0);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_async_paging_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
pt_encode_pip(encoder, 0, 0);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result event_overflow_fup(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
struct pt_packet_ip packet;
int errcode;
packet.ipc = ipc;
packet.ip = 0xccull;
pt_last_ip_init(&dfix->last_ip);
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_ovf(encoder);
pt_encode_fup(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
switch (ipc) {
case pt_ipc_suppressed:
ptu_int_eq(errcode, -pte_bad_packet);
break;
case pt_ipc_update_16:
case pt_ipc_update_32:
case pt_ipc_update_48:
case pt_ipc_sext_48:
case pt_ipc_full:
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_overflow);
ptu_uint_eq(event.variant.overflow.ip, dfix->last_ip.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
break;
}
return ptu_passed();
}
static struct ptunit_result
event_overflow_fup_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_ovf(encoder);
pt_encode_fup(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_overflow_tip_pge(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
struct pt_packet_ip packet;
int errcode;
packet.ipc = ipc;
packet.ip = 0xccull;
pt_last_ip_init(&dfix->last_ip);
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_ovf(encoder);
pt_encode_tip_pge(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_event_pending);
ptu_int_eq(event.type, ptev_overflow);
ptu_uint_ne(event.ip_suppressed, 0);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_event(decoder, &event, sizeof(event));
switch (ipc) {
case pt_ipc_suppressed:
ptu_int_eq(errcode, -pte_bad_packet);
break;
case pt_ipc_update_16:
case pt_ipc_update_32:
case pt_ipc_update_48:
case pt_ipc_sext_48:
case pt_ipc_full:
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_enabled);
ptu_uint_eq(event.variant.enabled.ip, dfix->last_ip.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
break;
}
return ptu_passed();
}
static struct ptunit_result
event_overflow_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_ovf(encoder);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result event_stop(struct ptu_decoder_fixture *dfix,
uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_stop(encoder);
ptu_sync_decoder(decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_stop);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
return ptu_passed();
}
static struct ptunit_result
event_exec_mode_tip(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
enum pt_exec_mode mode = ptem_16bit;
struct pt_packet_ip packet;
struct pt_event event;
uint64_t addr = 0ull;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_mode_exec(encoder, mode);
pt_encode_tip(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, 0);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.exec_mode.ip, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_exec_mode);
ptu_int_eq(event.variant.exec_mode.mode, mode);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_indirect_branch(decoder, &addr);
if (ipc == pt_ipc_suppressed)
ptu_int_eq(errcode, pts_ip_suppressed | pts_eos);
else {
ptu_int_eq(errcode, pts_eos);
ptu_uint_eq(addr, dfix->last_ip.ip);
}
return ptu_passed();
}
static struct ptunit_result
event_exec_mode_tip_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_mode_exec(encoder, ptem_32bit);
pt_encode_tip(encoder, 0, pt_ipc_update_16);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_exec_mode_tip_pge(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
enum pt_exec_mode mode = ptem_16bit;
struct pt_packet_ip packet;
struct pt_event event;
uint64_t addr = 0ull;
int errcode;
packet.ipc = ipc;
packet.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_mode_exec(encoder, mode);
pt_encode_tip_pge(encoder, packet.ip, packet.ipc);
ptu_check(ptu_sync_decoder, decoder);
decoder->enabled = 0;
errcode = pt_qry_event(decoder, &event, sizeof(event));
if (ipc == pt_ipc_suppressed) {
ptu_int_eq(errcode, -pte_bad_packet);
ptu_uint_eq(addr, 0ull);
} else {
ptu_int_eq(errcode, pts_event_pending);
ptu_int_eq(event.type, ptev_enabled);
ptu_uint_eq(event.variant.enabled.ip, dfix->last_ip.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_exec_mode);
ptu_int_eq(event.variant.exec_mode.mode, mode);
ptu_uint_eq(event.variant.exec_mode.ip, dfix->last_ip.ip);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
}
return ptu_passed();
}
static struct ptunit_result
event_exec_mode_tip_pge_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_mode_exec(encoder, ptem_16bit);
pt_encode_tip_pge(encoder, 0, pt_ipc_sext_48);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_exec_mode_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_mode_exec(encoder, ptem_64bit);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result event_tsx_fup(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc,
uint8_t flags, uint64_t tsc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip fup, tip;
struct pt_event event;
uint64_t addr = 0;
int errcode;
fup.ipc = ipc;
fup.ip = pt_dfix_max_ip;
pt_last_ip_update_ip(&dfix->last_ip, &fup, &dfix->config);
tip.ipc = pt_ipc_sext_48;
tip.ip = pt_dfix_sext_ip;
pt_encode_mode_tsx(encoder, flags);
pt_encode_fup(encoder, fup.ip, fup.ipc);
pt_encode_tip(encoder, tip.ip, tip.ipc);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, 0);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.tsx.ip, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_tsx);
ptu_int_eq(event.variant.tsx.speculative,
(flags & pt_mob_tsx_intx) != 0);
ptu_int_eq(event.variant.tsx.aborted,
(flags & pt_mob_tsx_abrt) != 0);
if (!tsc)
ptu_int_eq(event.has_tsc, 0);
else {
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, tsc);
}
errcode = pt_qry_indirect_branch(decoder, &addr);
ptu_int_eq(errcode, pts_eos);
ptu_uint_eq(addr, tip.ip);
return ptu_passed();
}
static struct ptunit_result
event_tsx_fup_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_mode_tsx(encoder, 0);
pt_encode_fup(encoder, 0, pt_ipc_update_16);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_tsx_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_mode_tsx(encoder, 0);
ptu_check(cutoff, decoder, encoder);
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
event_skip_tip_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
const uint8_t *pos;
int errcode;
pos = encoder->pos;
pt_encode_tip(encoder, 0, pt_ipc_sext_48);
/* We omit the actual event - we don't get that far, anyway. */
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_bad_query);
ptu_ptr_eq(decoder->pos, pos);
return ptu_passed();
}
static struct ptunit_result
event_skip_tnt_8_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_tnt_8(encoder, 0, 1);
pt_encode_tnt_8(encoder, 0, 1);
/* We omit the actual event - we don't get that far, anyway. */
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_bad_query);
/* The fail position depends on the fixture's header. */
return ptu_passed();
}
static struct ptunit_result
event_skip_tnt_64_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_event event;
int errcode;
pt_encode_tnt_64(encoder, 0, 1);
pt_encode_tnt_64(encoder, 0, 1);
/* We omit the actual event - we don't get that far, anyway. */
ptu_check(ptu_sync_decoder, decoder);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, -pte_bad_query);
/* The fail position depends on the fixture's header. */
return ptu_passed();
}
static struct ptunit_result sync_event(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip packet;
struct pt_event event;
uint64_t addr = 0ull;
int errcode;
packet.ipc = ipc;
packet.ip = 0xccull;
pt_last_ip_init(&dfix->last_ip);
pt_last_ip_update_ip(&dfix->last_ip, &packet, &dfix->config);
pt_encode_psb(encoder);
pt_encode_mode_tsx(encoder, pt_mob_tsx_intx);
pt_encode_fup(encoder, packet.ip, packet.ipc);
pt_encode_psbend(encoder);
errcode = pt_qry_sync_forward(decoder, &addr);
switch (ipc) {
case pt_ipc_suppressed:
ptu_int_eq(errcode, (pts_event_pending | pts_ip_suppressed));
break;
case pt_ipc_update_16:
case pt_ipc_update_32:
case pt_ipc_update_48:
case pt_ipc_sext_48:
case pt_ipc_full:
ptu_int_eq(errcode, pts_event_pending);
ptu_uint_eq(addr, dfix->last_ip.ip);
break;
}
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_eos);
ptu_uint_ne(event.status_update, 0);
if (ipc == pt_ipc_suppressed)
ptu_uint_ne(event.ip_suppressed, 0);
else {
ptu_uint_eq(event.ip_suppressed, 0);
ptu_uint_eq(event.variant.tsx.ip, dfix->last_ip.ip);
}
ptu_int_eq(event.type, ptev_tsx);
ptu_int_eq(event.variant.tsx.speculative, 1);
ptu_int_eq(event.variant.tsx.aborted, 0);
ptu_int_eq(event.has_tsc, 0);
return ptu_passed();
}
static struct ptunit_result
sync_event_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t addr;
int errcode;
pt_encode_psb(encoder);
pt_encode_psbend(encoder);
ptu_check(cutoff, decoder, encoder);
errcode = pt_qry_sync_forward(decoder, &addr);
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result
sync_event_incomplete_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t addr;
int errcode;
pt_encode_psb(encoder);
errcode = pt_qry_sync_forward(decoder, &addr);
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result sync_ovf_event(struct ptu_decoder_fixture *dfix,
enum pt_ip_compression ipc)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
struct pt_packet_ip fup, ovf;
struct pt_event event;
uint64_t addr = 0;
int errcode;
fup.ipc = pt_ipc_sext_48;
fup.ip = pt_dfix_max_ip;
ovf.ipc = ipc;
ovf.ip = 0xccull;
pt_last_ip_init(&dfix->last_ip);
pt_last_ip_update_ip(&dfix->last_ip, &ovf, &dfix->config);
pt_encode_psb(encoder);
pt_encode_fup(encoder, fup.ip, fup.ipc);
pt_encode_mode_tsx(encoder, 0);
pt_encode_tsc(encoder, 0x1000);
pt_encode_ovf(encoder);
pt_encode_fup(encoder, ovf.ip, ovf.ipc);
errcode = pt_qry_sync_forward(decoder, &addr);
ptu_int_eq(errcode, pts_event_pending);
ptu_uint_eq(addr, fup.ip);
errcode = pt_qry_event(decoder, &event, sizeof(event));
ptu_int_eq(errcode, pts_event_pending);
ptu_uint_ne(event.status_update, 0);
ptu_int_eq(event.type, ptev_tsx);
ptu_int_eq(event.variant.tsx.speculative, 0);
ptu_int_eq(event.variant.tsx.aborted, 0);
ptu_uint_eq(event.variant.tsx.ip, fup.ip);
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, 0x1000);
errcode = pt_qry_event(decoder, &event, sizeof(event));
switch (ipc) {
case pt_ipc_suppressed:
ptu_int_eq(errcode, -pte_bad_packet);
return ptu_passed();
case pt_ipc_update_16:
case pt_ipc_update_32:
case pt_ipc_update_48:
case pt_ipc_sext_48:
case pt_ipc_full:
ptu_int_eq(errcode, pts_eos);
ptu_int_eq(event.type, ptev_overflow);
ptu_uint_eq(event.variant.overflow.ip, dfix->last_ip.ip);
ptu_int_eq(event.has_tsc, 1);
ptu_uint_eq(event.tsc, 0x1000);
break;
}
return ptu_passed();
}
static struct ptunit_result
sync_ovf_event_cutoff_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
uint64_t addr;
int errcode;
pt_encode_psb(encoder);
pt_encode_ovf(encoder);
ptu_check(cutoff, decoder, encoder);
errcode = pt_qry_sync_forward(decoder, &addr);
ptu_int_eq(errcode, -pte_eos);
return ptu_passed();
}
static struct ptunit_result time_null_fail(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint64_t tsc;
int errcode;
errcode = pt_qry_time(NULL, NULL, NULL, NULL);
ptu_int_eq(errcode, -pte_invalid);
errcode = pt_qry_time(decoder, NULL, NULL, NULL);
ptu_int_eq(errcode, -pte_invalid);
errcode = pt_qry_time(NULL, &tsc, NULL, NULL);
ptu_int_eq(errcode, -pte_invalid);
return ptu_passed();
}
static struct ptunit_result time_initial(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint64_t tsc;
int errcode;
errcode = pt_qry_time(decoder, &tsc, NULL, NULL);
ptu_int_eq(errcode, -pte_no_time);
return ptu_passed();
}
static struct ptunit_result time(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint64_t tsc, exp;
int errcode;
exp = 0x11223344556677ull;
decoder->time.have_tsc = 1;
decoder->time.tsc = exp;
errcode = pt_qry_time(decoder, &tsc, NULL, NULL);
ptu_int_eq(errcode, 0);
ptu_uint_eq(tsc, exp);
return ptu_passed();
}
static struct ptunit_result cbr_null(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint32_t cbr;
int errcode;
errcode = pt_qry_core_bus_ratio(NULL, NULL);
ptu_int_eq(errcode, -pte_invalid);
errcode = pt_qry_core_bus_ratio(decoder, NULL);
ptu_int_eq(errcode, -pte_invalid);
errcode = pt_qry_core_bus_ratio(NULL, &cbr);
ptu_int_eq(errcode, -pte_invalid);
return ptu_passed();
}
static struct ptunit_result cbr_initial(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint32_t cbr;
int errcode;
errcode = pt_qry_core_bus_ratio(decoder, &cbr);
ptu_int_eq(errcode, -pte_no_cbr);
return ptu_passed();
}
static struct ptunit_result cbr(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
uint32_t cbr;
int errcode;
decoder->time.have_cbr = 1;
decoder->time.cbr = 42;
errcode = pt_qry_core_bus_ratio(decoder, &cbr);
ptu_int_eq(errcode, 0);
ptu_uint_eq(cbr, 42);
return ptu_passed();
}
static struct ptunit_result ptu_dfix_init(struct ptu_decoder_fixture *dfix)
{
struct pt_config *config = &dfix->config;
int errcode;
(void) memset(dfix->buffer, 0, sizeof(dfix->buffer));
pt_config_init(config);
config->begin = dfix->buffer;
config->end = dfix->buffer + sizeof(dfix->buffer);
errcode = pt_encoder_init(&dfix->encoder, config);
ptu_int_eq(errcode, 0);
errcode = pt_qry_decoder_init(&dfix->decoder, config);
ptu_int_eq(errcode, 0);
dfix->decoder.ip.ip = pt_dfix_bad_ip;
dfix->decoder.ip.have_ip = 1;
dfix->decoder.ip.suppressed = 0;
dfix->last_ip = dfix->decoder.ip;
if (dfix->header)
dfix->header(dfix);
return ptu_passed();
}
static struct ptunit_result ptu_dfix_fini(struct ptu_decoder_fixture *dfix)
{
pt_qry_decoder_fini(&dfix->decoder);
pt_encoder_fini(&dfix->encoder);
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of an empty buffer. */
static struct ptunit_result
ptu_dfix_header_sync(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of a buffer containing packets that
* should be skipped for unconditional indirect branch queries.
*/
static struct ptunit_result
ptu_dfix_header_indir(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
pt_encode_pad(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0);
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of a buffer containing packets that
* should be skipped for unconditional indirect branch queries including a PSB.
*/
static struct ptunit_result
ptu_dfix_header_indir_psb(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
/* The psb must be empty since the tests won't skip status events.
* On the other hand, we do need to provide an address since tests
* may want to update last-ip, which requires a last-ip, of course.
*/
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0);
pt_encode_psb(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0);
pt_encode_fup(encoder, pt_dfix_sext_ip, pt_ipc_sext_48);
pt_encode_mnt(encoder, 0ull);
pt_encode_psbend(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
pt_encode_mnt(encoder, 0ull);
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of a buffer containing packets that
* should be skipped for conditional branch queries.
*/
static struct ptunit_result
ptu_dfix_header_cond(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
/* The psb must be empty since the tests won't skip status events.
* On the other hand, we do need to provide an address since tests
* may want to update last-ip, which requires a last-ip, of course.
*/
pt_encode_pad(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_psb(encoder);
pt_encode_tsc(encoder, 0);
pt_encode_pad(encoder);
pt_encode_fup(encoder, pt_dfix_sext_ip, pt_ipc_sext_48);
pt_encode_mnt(encoder, 0ull);
pt_encode_psbend(encoder);
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0);
pt_encode_pad(encoder);
pt_encode_mnt(encoder, 0ull);
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of a buffer containing packets that
* should be skipped for event queries.
*/
static struct ptunit_result
ptu_dfix_header_event(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
pt_encode_pad(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0x1000);
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
/* Synchronize the decoder at the beginnig of a buffer containing packets that
* should be skipped for event queries including a PSB.
*/
static struct ptunit_result
ptu_dfix_header_event_psb(struct ptu_decoder_fixture *dfix)
{
struct pt_query_decoder *decoder = &dfix->decoder;
struct pt_encoder *encoder = &dfix->encoder;
/* The psb must be empty since the tests won't skip status events.
* On the other hand, we do need to provide an address since tests
* may want to update last-ip, which requires a last-ip, of course.
*/
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0);
pt_encode_psb(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
pt_encode_tsc(encoder, 0x1000);
pt_encode_fup(encoder, pt_dfix_sext_ip, pt_ipc_sext_48);
pt_encode_psbend(encoder);
pt_encode_cbr(encoder, 1);
pt_encode_pad(encoder);
/* Synchronize the decoder at the beginning of the buffer. */
decoder->pos = decoder->config.begin;
return ptu_passed();
}
static struct ptu_decoder_fixture dfix_raw;
static struct ptu_decoder_fixture dfix_empty;
static struct ptu_decoder_fixture dfix_indir;
static struct ptu_decoder_fixture dfix_indir_psb;
static struct ptu_decoder_fixture dfix_cond;
static struct ptu_decoder_fixture dfix_event;
static struct ptu_decoder_fixture dfix_event_psb;
static void init_fixtures(void)
{
dfix_raw.init = ptu_dfix_init;
dfix_raw.fini = ptu_dfix_fini;
dfix_empty = dfix_raw;
dfix_empty.header = ptu_dfix_header_sync;
dfix_indir = dfix_raw;
dfix_indir.header = ptu_dfix_header_indir;
dfix_indir_psb = dfix_raw;
dfix_indir_psb.header = ptu_dfix_header_indir_psb;
dfix_cond = dfix_raw;
dfix_cond.header = ptu_dfix_header_cond;
dfix_event = dfix_raw;
dfix_event.header = ptu_dfix_header_event;
dfix_event_psb = dfix_raw;
dfix_event_psb.header = ptu_dfix_header_event_psb;
}
int main(int argc, char **argv)
{
struct ptunit_suite suite;
init_fixtures();
suite = ptunit_mk_suite(argc, argv);
ptu_run_f(suite, indir_not_synced, dfix_raw);
ptu_run_f(suite, cond_not_synced, dfix_raw);
ptu_run_f(suite, event_not_synced, dfix_raw);
ptu_run_f(suite, indir_null, dfix_empty);
ptu_run_f(suite, indir_empty, dfix_empty);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_suppressed);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_update_16);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_update_32);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_update_48);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_sext_48);
ptu_run_fp(suite, indir, dfix_empty, pt_ipc_full);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_suppressed);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_update_16);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_update_32);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_update_48);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_sext_48);
ptu_run_fp(suite, indir_tnt, dfix_empty, pt_ipc_full);
ptu_run_f(suite, indir_cutoff_fail, dfix_empty);
ptu_run_f(suite, indir_skip_tnt_fail, dfix_empty);
ptu_run_f(suite, indir_skip_tip_pge_fail, dfix_empty);
ptu_run_f(suite, indir_skip_tip_pgd_fail, dfix_empty);
ptu_run_f(suite, indir_skip_fup_tip_fail, dfix_empty);
ptu_run_f(suite, indir_skip_fup_tip_pgd_fail, dfix_empty);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_suppressed);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_update_16);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_update_32);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_update_48);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_sext_48);
ptu_run_fp(suite, indir, dfix_indir, pt_ipc_full);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_suppressed);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_update_16);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_update_32);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_update_48);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_sext_48);
ptu_run_fp(suite, indir_tnt, dfix_indir, pt_ipc_full);
ptu_run_f(suite, indir_cutoff_fail, dfix_indir);
ptu_run_f(suite, indir_skip_tnt_fail, dfix_indir);
ptu_run_f(suite, indir_skip_tip_pge_fail, dfix_indir);
ptu_run_f(suite, indir_skip_tip_pgd_fail, dfix_indir);
ptu_run_f(suite, indir_skip_fup_tip_fail, dfix_indir);
ptu_run_f(suite, indir_skip_fup_tip_pgd_fail, dfix_indir);
ptu_run_fp(suite, indir, dfix_indir_psb, pt_ipc_suppressed);
ptu_run_fp(suite, indir, dfix_indir_psb, pt_ipc_sext_48);
ptu_run_fp(suite, indir, dfix_indir_psb, pt_ipc_full);
ptu_run_fp(suite, indir_tnt, dfix_indir_psb, pt_ipc_suppressed);
ptu_run_fp(suite, indir_tnt, dfix_indir_psb, pt_ipc_sext_48);
ptu_run_fp(suite, indir_tnt, dfix_indir_psb, pt_ipc_full);
ptu_run_f(suite, indir_cutoff_fail, dfix_indir_psb);
ptu_run_f(suite, indir_skip_tnt_fail, dfix_indir_psb);
ptu_run_f(suite, indir_skip_tip_pge_fail, dfix_indir_psb);
ptu_run_f(suite, indir_skip_tip_pgd_fail, dfix_indir_psb);
ptu_run_f(suite, indir_skip_fup_tip_fail, dfix_indir_psb);
ptu_run_f(suite, indir_skip_fup_tip_pgd_fail, dfix_indir_psb);
ptu_run_f(suite, cond_null, dfix_empty);
ptu_run_f(suite, cond_empty, dfix_empty);
ptu_run_f(suite, cond, dfix_empty);
ptu_run_f(suite, cond_skip_tip_fail, dfix_empty);
ptu_run_f(suite, cond_skip_tip_pge_fail, dfix_empty);
ptu_run_f(suite, cond_skip_tip_pgd_fail, dfix_empty);
ptu_run_f(suite, cond_skip_fup_tip_fail, dfix_empty);
ptu_run_f(suite, cond_skip_fup_tip_pgd_fail, dfix_empty);
ptu_run_f(suite, cond, dfix_cond);
ptu_run_f(suite, cond_skip_tip_fail, dfix_cond);
ptu_run_f(suite, cond_skip_tip_pge_fail, dfix_cond);
ptu_run_f(suite, cond_skip_tip_pgd_fail, dfix_cond);
ptu_run_f(suite, cond_skip_fup_tip_fail, dfix_cond);
ptu_run_f(suite, cond_skip_fup_tip_pgd_fail, dfix_cond);
ptu_run_f(suite, event_null, dfix_empty);
ptu_run_f(suite, event_bad_size, dfix_empty);
ptu_run_f(suite, event_small_size, dfix_empty);
ptu_run_f(suite, event_big_size, dfix_empty);
ptu_run_f(suite, event_empty, dfix_empty);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_update_16, 0);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_update_32, 0);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_update_48, 0);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_enabled, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_enabled_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_update_16, 0);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_update_32, 0);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_update_48, 0);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_disabled, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_disabled_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_suppressed,
0);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_update_16,
0);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_update_32,
0);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_update_48,
0);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_async_disabled, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_async_disabled_suppressed_fail, dfix_empty);
ptu_run_f(suite, event_async_disabled_cutoff_fail_a, dfix_empty);
ptu_run_f(suite, event_async_disabled_cutoff_fail_b, dfix_empty);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_update_16, 0);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_update_32, 0);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_update_48, 0);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_async_branch, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_async_branch_suppressed_fail, dfix_empty);
ptu_run_f(suite, event_async_branch_cutoff_fail_a, dfix_empty);
ptu_run_f(suite, event_async_branch_cutoff_fail_b, dfix_empty);
ptu_run_fp(suite, event_paging, dfix_empty, 0, 0);
ptu_run_fp(suite, event_paging, dfix_empty, pt_pl_pip_nr, 0);
ptu_run_f(suite, event_paging_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_async_paging, dfix_empty, 0, 0);
ptu_run_fp(suite, event_async_paging, dfix_empty, pt_pl_pip_nr, 0);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_empty, 0, 0);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_empty,
pt_pl_pip_nr, 0);
ptu_run_f(suite, event_async_paging_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_update_16, 0);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_update_32, 0);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_update_48, 0);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_overflow_fup, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_overflow_fup_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty,
pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty, pt_ipc_update_16,
0);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty, pt_ipc_update_32,
0);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty, pt_ipc_update_48,
0);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty, pt_ipc_sext_48,
0);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_empty, pt_ipc_full,
0);
ptu_run_f(suite, event_overflow_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_stop, dfix_empty, 0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_suppressed,
0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_update_16, 0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_update_32, 0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_update_48, 0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_sext_48, 0);
ptu_run_fp(suite, event_exec_mode_tip, dfix_empty, pt_ipc_full, 0);
ptu_run_f(suite, event_exec_mode_tip_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty,
pt_ipc_suppressed, 0);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty,
pt_ipc_update_16, 0);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty,
pt_ipc_update_32, 0);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty,
pt_ipc_update_48, 0);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty, pt_ipc_sext_48,
0);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_empty, pt_ipc_full,
0);
ptu_run_f(suite, event_exec_mode_tip_pge_cutoff_fail, dfix_empty);
ptu_run_f(suite, event_exec_mode_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_suppressed,
pt_mob_tsx_intx, 0);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_update_16, 0, 0);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_update_32,
pt_mob_tsx_intx, 0);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_update_48,
pt_mob_tsx_intx, 0);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_sext_48, 0, 0);
ptu_run_fp(suite, event_tsx_fup, dfix_empty, pt_ipc_full, 0, 0);
ptu_run_f(suite, event_tsx_fup_cutoff_fail, dfix_empty);
ptu_run_f(suite, event_tsx_cutoff_fail, dfix_empty);
ptu_run_f(suite, event_skip_tip_fail, dfix_empty);
ptu_run_f(suite, event_skip_tnt_8_fail, dfix_empty);
ptu_run_f(suite, event_skip_tnt_64_fail, dfix_empty);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_suppressed);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_update_16);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_update_32);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_update_48);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_sext_48);
ptu_run_fp(suite, sync_event, dfix_empty, pt_ipc_full);
ptu_run_f(suite, sync_event_cutoff_fail, dfix_empty);
ptu_run_f(suite, sync_event_incomplete_fail, dfix_empty);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_suppressed);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_update_16);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_update_32);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_update_48);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_sext_48);
ptu_run_fp(suite, sync_ovf_event, dfix_empty, pt_ipc_full);
ptu_run_f(suite, sync_ovf_event_cutoff_fail, dfix_empty);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_update_16, 0x1000);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_update_32, 0x1000);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_update_48, 0x1000);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_sext_48, 0x1000);
ptu_run_fp(suite, event_enabled, dfix_event, pt_ipc_full, 0x1000);
ptu_run_f(suite, event_enabled_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_update_16, 0x1000);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_update_32, 0x1000);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_update_48, 0x1000);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_sext_48, 0x1000);
ptu_run_fp(suite, event_disabled, dfix_event, pt_ipc_full, 0x1000);
ptu_run_f(suite, event_disabled_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_async_disabled_suppressed_fail, dfix_event);
ptu_run_f(suite, event_async_disabled_cutoff_fail_a, dfix_event);
ptu_run_f(suite, event_async_disabled_cutoff_fail_b, dfix_event);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_async_branch_suppressed_fail, dfix_event);
ptu_run_f(suite, event_async_branch_cutoff_fail_a, dfix_event);
ptu_run_f(suite, event_async_branch_cutoff_fail_b, dfix_event);
ptu_run_fp(suite, event_paging, dfix_event, 0, 0x1000);
ptu_run_fp(suite, event_paging, dfix_event, pt_pl_pip_nr, 0x1000);
ptu_run_f(suite, event_paging_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_async_paging, dfix_event, 0, 0x1000);
ptu_run_fp(suite, event_async_paging, dfix_event, pt_pl_pip_nr, 0x1000);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_event, 0, 0x1000);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_event,
pt_pl_pip_nr, 0x1000);
ptu_run_f(suite, event_async_paging_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_overflow_fup, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_overflow_fup_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event,
pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_overflow_tip_pge, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_overflow_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_stop, dfix_event, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_exec_mode_tip_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event,
pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event,
pt_ipc_update_16, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event,
pt_ipc_update_32, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event,
pt_ipc_update_48, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_exec_mode_tip_pge_cutoff_fail, dfix_event);
ptu_run_f(suite, event_exec_mode_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_suppressed, 0,
0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_update_16,
pt_mob_tsx_intx, 0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_update_32, 0,
0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_update_48, 0,
0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_sext_48,
pt_mob_tsx_intx, 0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event, pt_ipc_full,
pt_mob_tsx_intx, 0x1000);
ptu_run_f(suite, event_tsx_fup_cutoff_fail, dfix_event);
ptu_run_f(suite, event_tsx_cutoff_fail, dfix_event);
ptu_run_f(suite, event_skip_tip_fail, dfix_event);
ptu_run_f(suite, event_skip_tnt_8_fail, dfix_event);
ptu_run_f(suite, event_skip_tnt_64_fail, dfix_event);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_suppressed);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_update_16);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_update_32);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_update_48);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_sext_48);
ptu_run_fp(suite, sync_event, dfix_event, pt_ipc_full);
ptu_run_f(suite, sync_event_cutoff_fail, dfix_event);
ptu_run_f(suite, sync_event_incomplete_fail, dfix_event);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_suppressed);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_update_16);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_update_32);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_update_48);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_sext_48);
ptu_run_fp(suite, sync_ovf_event, dfix_event, pt_ipc_full);
ptu_run_f(suite, sync_ovf_event_cutoff_fail, dfix_event);
ptu_run_fp(suite, event_enabled, dfix_event_psb, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_enabled, dfix_event_psb, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_enabled, dfix_event_psb, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_enabled_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_disabled, dfix_event_psb, pt_ipc_suppressed,
0x1000);
ptu_run_fp(suite, event_disabled, dfix_event_psb, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_disabled, dfix_event_psb, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_disabled_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_update_16, 0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_update_32, 0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_update_48, 0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_sext_48, 0x1000);
ptu_run_fp(suite, event_async_disabled, dfix_event_psb,
pt_ipc_full, 0x1000);
ptu_run_f(suite, event_async_disabled_suppressed_fail, dfix_event_psb);
ptu_run_f(suite, event_async_disabled_cutoff_fail_a, dfix_event_psb);
ptu_run_f(suite, event_async_disabled_cutoff_fail_b, dfix_event_psb);
ptu_run_fp(suite, event_async_branch, dfix_event_psb,
pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event_psb, pt_ipc_update_16,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event_psb, pt_ipc_update_32,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event_psb, pt_ipc_update_48,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event_psb, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_async_branch, dfix_event_psb, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_async_branch_suppressed_fail, dfix_event_psb);
ptu_run_f(suite, event_async_branch_cutoff_fail_a, dfix_event_psb);
ptu_run_f(suite, event_async_branch_cutoff_fail_b, dfix_event_psb);
ptu_run_fp(suite, event_paging, dfix_event_psb, 0, 0x1000);
ptu_run_fp(suite, event_paging, dfix_event_psb, pt_pl_pip_nr, 0x1000);
ptu_run_f(suite, event_paging_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_async_paging, dfix_event_psb, 0, 0x1000);
ptu_run_fp(suite, event_async_paging, dfix_event_psb, pt_pl_pip_nr,
0x1000);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_event_psb, 0,
0x1000);
ptu_run_fp(suite, event_async_paging_suppressed, dfix_event_psb,
pt_pl_pip_nr, 0x1000);
ptu_run_f(suite, event_async_paging_cutoff_fail, dfix_event_psb);
ptu_run_f(suite, event_overflow_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_stop, dfix_event_psb, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event_psb,
pt_ipc_suppressed, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event_psb, pt_ipc_sext_48,
0x1000);
ptu_run_fp(suite, event_exec_mode_tip, dfix_event_psb, pt_ipc_full,
0x1000);
ptu_run_f(suite, event_exec_mode_tip_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event_psb,
pt_ipc_sext_48, 0x1000);
ptu_run_fp(suite, event_exec_mode_tip_pge, dfix_event_psb,
pt_ipc_full, 0x1000);
ptu_run_f(suite, event_exec_mode_tip_pge_cutoff_fail, dfix_event_psb);
ptu_run_f(suite, event_exec_mode_cutoff_fail, dfix_event_psb);
ptu_run_fp(suite, event_tsx_fup, dfix_event_psb, pt_ipc_suppressed, 0,
0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event_psb, pt_ipc_sext_48,
pt_mob_tsx_intx, 0x1000);
ptu_run_fp(suite, event_tsx_fup, dfix_event_psb, pt_ipc_full,
pt_mob_tsx_intx, 0x1000);
ptu_run_f(suite, event_tsx_fup_cutoff_fail, dfix_event_psb);
ptu_run_f(suite, event_tsx_cutoff_fail, dfix_event_psb);
ptu_run_f(suite, event_skip_tip_fail, dfix_event_psb);
ptu_run_f(suite, event_skip_tnt_8_fail, dfix_event_psb);
ptu_run_f(suite, event_skip_tnt_64_fail, dfix_event_psb);
ptu_run_f(suite, time_null_fail, dfix_empty);
ptu_run_f(suite, time_initial, dfix_empty);
ptu_run_f(suite, time, dfix_empty);
ptu_run_f(suite, cbr_null, dfix_empty);
ptu_run_f(suite, cbr_initial, dfix_empty);
ptu_run_f(suite, cbr, dfix_empty);
ptunit_report(&suite);
return suite.nr_fails;
}