279b7babe4
Added a definition of a parsed trace entry and a function allowing for iterating over these objects. The difference between a parsed and a regular trace entry is that it includes more information gathered while processing the trace file (e.g. lcore, object statistics) and provides a contigous buffer for trace arguments. For now, only lcore and the pointer to the actual trace entry are filled. Tracepoint arguments and object statistics will be added in subsequent patches. Signed-off-by: Konrad Sztyber <konrad.sztyber@intel.com> Change-Id: I4d5e30a7abb4860a5ba9db46f64ceae8bd14646f Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/9433 Community-CI: Broadcom CI <spdk-ci.pdl@broadcom.com> Community-CI: Mellanox Build Bot Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Aleksey Marchuk <alexeymar@mellanox.com>
143 lines
4.6 KiB
C
143 lines
4.6 KiB
C
/*-
|
|
* BSD LICENSE
|
|
*
|
|
* Copyright (c) Intel Corporation. All rights reserved.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* \file
|
|
* Trace parser library
|
|
*/
|
|
|
|
#ifndef SPDK_TRACE_PARSER_H
|
|
#define SPDK_TRACE_PARSER_H
|
|
|
|
#include "spdk/stdinc.h"
|
|
#include "spdk/trace.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** Trace parser object used as a context for the parsing functions */
|
|
struct spdk_trace_parser;
|
|
|
|
enum spdk_trace_parser_mode {
|
|
/** Regular file */
|
|
SPDK_TRACE_PARSER_MODE_FILE,
|
|
/** Shared memory */
|
|
SPDK_TRACE_PARSER_MODE_SHM,
|
|
};
|
|
|
|
/** Describes trace file and options to use when parsing it */
|
|
struct spdk_trace_parser_opts {
|
|
/** Either file name or shared memory name depending on mode */
|
|
const char *filename;
|
|
/** Trace file type, either regular file or shared memory */
|
|
int mode;
|
|
/** Logical core number to parse the traces from (or SPDK_TRACE_MAX_LCORE) for all cores */
|
|
uint16_t lcore;
|
|
};
|
|
|
|
/**
|
|
* Initialize the parser using a specified trace file. This results in parsing the traces, merging
|
|
* entries from multiple cores together and sorting them by their tsc, so it can take a significant
|
|
* amount of time to complete.
|
|
*
|
|
* \param opts Describes the trace file to parse.
|
|
*
|
|
* \return Parser object or NULL in case of any failures.
|
|
*/
|
|
struct spdk_trace_parser *spdk_trace_parser_init(const struct spdk_trace_parser_opts *opts);
|
|
|
|
/**
|
|
* Free any resources tied to a parser object.
|
|
*
|
|
* \param parser Parser to clean up.
|
|
*/
|
|
void spdk_trace_parser_cleanup(struct spdk_trace_parser *parser);
|
|
|
|
/**
|
|
* Return trace flags describing the traces.
|
|
*
|
|
* \param parser Parser object to be used.
|
|
*
|
|
* \return Pointer to the trace flags.
|
|
*/
|
|
const struct spdk_trace_flags *spdk_trace_parser_get_flags(const struct spdk_trace_parser *parser);
|
|
|
|
/**
|
|
* Return the highest tsc out of first entries across all speicifed cores. This value can be used
|
|
* to select entries from the subset of time we have the data from all reactors.
|
|
*
|
|
* \param parser Parser object to be used.
|
|
*
|
|
* \return Offset in tsc.
|
|
*/
|
|
uint64_t spdk_trace_parser_get_tsc_offset(const struct spdk_trace_parser *parser);
|
|
|
|
/** Describes a parsed trace entry */
|
|
struct spdk_trace_parser_entry {
|
|
/** Pointer to trace entry */
|
|
struct spdk_trace_entry *entry;
|
|
/**
|
|
* Index of an object this entry is a part of. It's only available for tracepoints with
|
|
* object_type != OBJECT_NONE. If unavailable, it'll be assigned to UINT64_MAX.
|
|
*/
|
|
uint64_t object_index;
|
|
/** The tsc of when the object tied to this entry was created */
|
|
uint64_t object_start;
|
|
/** Logical core number */
|
|
uint16_t lcore;
|
|
/** Tracepoint arguments */
|
|
union {
|
|
uint64_t integer;
|
|
void *pointer;
|
|
char string[UINT8_MAX + 1];
|
|
} args[SPDK_TRACE_MAX_ARGS_COUNT];
|
|
};
|
|
|
|
/**
|
|
* Return next parsed trace entry. Once no more traces are available, this will return false and
|
|
* entry won't be touched.
|
|
*
|
|
* \param parser Parser object to be used.
|
|
* \param entry Tracepoint entry.
|
|
*
|
|
* \return True if a trace entry was available, false otherwise.
|
|
*/
|
|
bool spdk_trace_parser_next_entry(struct spdk_trace_parser *parser,
|
|
struct spdk_trace_parser_entry *entry);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* SPDK_TRACE_PARSER_H */
|