2018-10-06 00:22:25 +08:00
|
|
|
// SPDX-License-Identifier: LGPL-2.1
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2009, 2010 Red Hat Inc, Steven Rostedt <srostedt@redhat.com>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "event-parse.h"
|
|
|
|
#include "event-parse-local.h"
|
|
|
|
#include "event-utils.h"
|
|
|
|
|
2019-04-02 00:43:12 +08:00
|
|
|
/**
|
|
|
|
* tep_get_event - returns the event with the given index
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @index: index of the requested event, in the range 0 .. nr_events
|
|
|
|
*
|
|
|
|
* This returns pointer to the element of the events array with the given index
|
|
|
|
* If @tep is NULL, or @index is not in the range 0 .. nr_events, NULL is returned.
|
|
|
|
*/
|
|
|
|
struct tep_event *tep_get_event(struct tep_handle *tep, int index)
|
|
|
|
{
|
|
|
|
if (tep && tep->events && index < tep->nr_events)
|
|
|
|
return tep->events[index];
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2018-10-06 00:22:25 +08:00
|
|
|
/**
|
|
|
|
* tep_get_first_event - returns the first event in the events array
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns pointer to the first element of the events array
|
|
|
|
* If @tep is NULL, NULL is returned.
|
|
|
|
*/
|
2018-11-30 23:44:07 +08:00
|
|
|
struct tep_event *tep_get_first_event(struct tep_handle *tep)
|
2018-10-06 00:22:25 +08:00
|
|
|
{
|
2019-04-02 00:43:12 +08:00
|
|
|
return tep_get_event(tep, 0);
|
2018-10-06 00:22:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_get_events_count - get the number of defined events
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns number of elements in event array
|
|
|
|
* If @tep is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_events_count(struct tep_handle *tep)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (tep)
|
2018-10-06 00:22:25 +08:00
|
|
|
return tep->nr_events;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_flag - set event parser flag
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @flag: flag, or combination of flags to be set
|
|
|
|
* can be any combination from enum tep_flag
|
|
|
|
*
|
2019-04-02 00:43:10 +08:00
|
|
|
* This sets a flag or combination of flags from enum tep_flag
|
|
|
|
*/
|
2018-10-06 00:22:25 +08:00
|
|
|
void tep_set_flag(struct tep_handle *tep, int flag)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (tep)
|
2018-10-06 00:22:25 +08:00
|
|
|
tep->flags |= flag;
|
|
|
|
}
|
|
|
|
|
2019-04-02 00:43:12 +08:00
|
|
|
/**
|
|
|
|
* tep_clear_flag - clear event parser flag
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @flag: flag to be cleared
|
|
|
|
*
|
|
|
|
* This clears a tep flag
|
|
|
|
*/
|
|
|
|
void tep_clear_flag(struct tep_handle *tep, enum tep_flag flag)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
tep->flags &= ~flag;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_test_flag - check the state of event parser flag
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @flag: flag to be checked
|
|
|
|
*
|
|
|
|
* This returns the state of the requested tep flag.
|
|
|
|
* Returns: true if the flag is set, false otherwise.
|
|
|
|
*/
|
|
|
|
bool tep_test_flag(struct tep_handle *tep, enum tep_flag flag)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
return (tep->flags & flag);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-11-30 23:44:10 +08:00
|
|
|
unsigned short tep_data2host2(struct tep_handle *pevent, unsigned short data)
|
2018-10-06 00:22:25 +08:00
|
|
|
{
|
|
|
|
unsigned short swap;
|
|
|
|
|
|
|
|
if (!pevent || pevent->host_bigendian == pevent->file_bigendian)
|
|
|
|
return data;
|
|
|
|
|
|
|
|
swap = ((data & 0xffULL) << 8) |
|
|
|
|
((data & (0xffULL << 8)) >> 8);
|
|
|
|
|
|
|
|
return swap;
|
|
|
|
}
|
|
|
|
|
2018-11-30 23:44:10 +08:00
|
|
|
unsigned int tep_data2host4(struct tep_handle *pevent, unsigned int data)
|
2018-10-06 00:22:25 +08:00
|
|
|
{
|
|
|
|
unsigned int swap;
|
|
|
|
|
|
|
|
if (!pevent || pevent->host_bigendian == pevent->file_bigendian)
|
|
|
|
return data;
|
|
|
|
|
|
|
|
swap = ((data & 0xffULL) << 24) |
|
|
|
|
((data & (0xffULL << 8)) << 8) |
|
|
|
|
((data & (0xffULL << 16)) >> 8) |
|
|
|
|
((data & (0xffULL << 24)) >> 24);
|
|
|
|
|
|
|
|
return swap;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned long long
|
2018-11-30 23:44:10 +08:00
|
|
|
tep_data2host8(struct tep_handle *pevent, unsigned long long data)
|
2018-10-06 00:22:25 +08:00
|
|
|
{
|
|
|
|
unsigned long long swap;
|
|
|
|
|
|
|
|
if (!pevent || pevent->host_bigendian == pevent->file_bigendian)
|
|
|
|
return data;
|
|
|
|
|
|
|
|
swap = ((data & 0xffULL) << 56) |
|
|
|
|
((data & (0xffULL << 8)) << 40) |
|
|
|
|
((data & (0xffULL << 16)) << 24) |
|
|
|
|
((data & (0xffULL << 24)) << 8) |
|
|
|
|
((data & (0xffULL << 32)) >> 8) |
|
|
|
|
((data & (0xffULL << 40)) >> 24) |
|
|
|
|
((data & (0xffULL << 48)) >> 40) |
|
|
|
|
((data & (0xffULL << 56)) >> 56);
|
|
|
|
|
|
|
|
return swap;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_get_header_page_size - get size of the header page
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns size of the header page
|
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_header_page_size(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->header_page_size_size;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-04-02 00:43:12 +08:00
|
|
|
/**
|
|
|
|
* tep_get_header_timestamp_size - get size of the time stamp in the header page
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns size of the time stamp in the header page
|
|
|
|
* If @tep is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_header_timestamp_size(struct tep_handle *tep)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
return tep->header_page_ts_size;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-10-06 00:22:25 +08:00
|
|
|
/**
|
|
|
|
* tep_get_cpus - get the number of CPUs
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns the number of CPUs
|
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_cpus(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->cpus;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_cpus - set the number of CPUs
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This sets the number of CPUs
|
|
|
|
*/
|
|
|
|
void tep_set_cpus(struct tep_handle *pevent, int cpus)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->cpus = cpus;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-04-02 00:43:10 +08:00
|
|
|
* tep_get_long_size - get the size of a long integer on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
2019-04-02 00:43:10 +08:00
|
|
|
* This returns the size of a long integer on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_long_size(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->long_size;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-04-02 00:43:10 +08:00
|
|
|
* tep_set_long_size - set the size of a long integer on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
* @size: size, in bytes, of a long integer
|
|
|
|
*
|
2019-04-02 00:43:10 +08:00
|
|
|
* This sets the size of a long integer on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
*/
|
|
|
|
void tep_set_long_size(struct tep_handle *pevent, int long_size)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->long_size = long_size;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-04-02 00:43:10 +08:00
|
|
|
* tep_get_page_size - get the size of a memory page on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
2019-04-02 00:43:10 +08:00
|
|
|
* This returns the size of a memory page on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_get_page_size(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->page_size;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-04-02 00:43:10 +08:00
|
|
|
* tep_set_page_size - set the size of a memory page on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
* @_page_size: size of a memory page, in bytes
|
|
|
|
*
|
2019-04-02 00:43:10 +08:00
|
|
|
* This sets the size of a memory page on the traced machine
|
2018-10-06 00:22:25 +08:00
|
|
|
*/
|
|
|
|
void tep_set_page_size(struct tep_handle *pevent, int _page_size)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->page_size = _page_size;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-12-01 12:08:12 +08:00
|
|
|
* tep_file_bigendian - get if the file is in big endian order
|
2018-10-06 00:22:25 +08:00
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns if the file is in big endian order
|
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
2018-12-01 12:08:12 +08:00
|
|
|
int tep_file_bigendian(struct tep_handle *pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->file_bigendian;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_file_bigendian - set if the file is in big endian order
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
* @endian: non zero, if the file is in big endian order
|
|
|
|
*
|
|
|
|
* This sets if the file is in big endian order
|
|
|
|
*/
|
|
|
|
void tep_set_file_bigendian(struct tep_handle *pevent, enum tep_endian endian)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->file_bigendian = endian;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_is_host_bigendian - get if the order of the current host is big endian
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This gets if the order of the current host is big endian
|
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_is_host_bigendian(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->host_bigendian;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_host_bigendian - set the order of the local host
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
* @endian: non zero, if the local host has big endian order
|
|
|
|
*
|
|
|
|
* This sets the order of the local host
|
|
|
|
*/
|
|
|
|
void tep_set_host_bigendian(struct tep_handle *pevent, enum tep_endian endian)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->host_bigendian = endian;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_is_latency_format - get if the latency output format is configured
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This gets if the latency output format is configured
|
|
|
|
* If @pevent is NULL, 0 is returned.
|
|
|
|
*/
|
|
|
|
int tep_is_latency_format(struct tep_handle *pevent)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
return pevent->latency_format;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_latency_format - set the latency output format
|
|
|
|
* @pevent: a handle to the tep_handle
|
|
|
|
* @lat: non zero for latency output format
|
|
|
|
*
|
|
|
|
* This sets the latency output format
|
|
|
|
*/
|
|
|
|
void tep_set_latency_format(struct tep_handle *pevent, int lat)
|
|
|
|
{
|
2019-04-02 00:43:11 +08:00
|
|
|
if (pevent)
|
2018-10-06 00:22:25 +08:00
|
|
|
pevent->latency_format = lat;
|
|
|
|
}
|
2019-04-02 00:43:12 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_is_old_format - get if an old kernel is used
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
*
|
|
|
|
* This returns true, if an old kernel is used to generate the tracing events or
|
|
|
|
* false if a new kernel is used. Old kernels did not have header page info.
|
|
|
|
* If @tep is NULL, false is returned.
|
|
|
|
*/
|
|
|
|
bool tep_is_old_format(struct tep_handle *tep)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
return !!(tep->old_format);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_print_raw - set a flag to force print in raw format
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @print_raw: the new value of the print_raw flag
|
|
|
|
*
|
|
|
|
* This sets a flag to force print in raw format
|
|
|
|
*/
|
|
|
|
void tep_set_print_raw(struct tep_handle *tep, int print_raw)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
tep->print_raw = print_raw;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* tep_set_test_filters - set a flag to test a filter string
|
|
|
|
* @tep: a handle to the tep_handle
|
|
|
|
* @test_filters: the new value of the test_filters flag
|
|
|
|
*
|
|
|
|
* This sets a flag to test a filter string. If this flag is set, when
|
|
|
|
* tep_filter_add_filter_str() API as called,it will print the filter string
|
|
|
|
* instead of adding it.
|
|
|
|
*/
|
|
|
|
void tep_set_test_filters(struct tep_handle *tep, int test_filters)
|
|
|
|
{
|
|
|
|
if (tep)
|
|
|
|
tep->test_filters = test_filters;
|
|
|
|
}
|