2023-02-08 13:17:09 +01:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2020-09-15 00:02:56 +02:00
|
|
|
/* Tracing
|
|
|
|
*
|
|
|
|
* Copyright (C) 2020 NVIDIA Corporation
|
|
|
|
* Quentin Young
|
|
|
|
*/
|
|
|
|
|
2020-09-28 21:49:22 +02:00
|
|
|
#if !defined(_LIBFRR_TRACE_H_) || defined(TRACEPOINT_HEADER_MULTI_READ)
|
|
|
|
#define _LIBFRR_TRACE_H_
|
2020-09-15 00:02:56 +02:00
|
|
|
|
2020-09-29 00:13:27 +02:00
|
|
|
#include "trace.h"
|
2020-09-15 00:02:56 +02:00
|
|
|
|
|
|
|
#ifdef HAVE_LTTNG
|
|
|
|
|
|
|
|
#undef TRACEPOINT_PROVIDER
|
|
|
|
#define TRACEPOINT_PROVIDER frr_libfrr
|
|
|
|
|
|
|
|
#undef TRACEPOINT_INCLUDE
|
2020-09-28 21:49:22 +02:00
|
|
|
#define TRACEPOINT_INCLUDE "./libfrr_trace.h"
|
2020-09-15 00:02:56 +02:00
|
|
|
|
|
|
|
#include <lttng/tracepoint.h>
|
2020-09-15 00:04:33 +02:00
|
|
|
|
|
|
|
#include "hash.h"
|
2022-02-28 16:40:31 +01:00
|
|
|
#include "event.h"
|
2020-09-17 20:57:36 +02:00
|
|
|
#include "memory.h"
|
|
|
|
#include "linklist.h"
|
2020-09-18 21:14:09 +02:00
|
|
|
#include "table.h"
|
2020-09-15 00:04:33 +02:00
|
|
|
|
|
|
|
/* clang-format off */
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
hash_get,
|
|
|
|
TP_ARGS(struct hash *, hash, void *, data),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(name, hash->name ? hash->name : "(unnamed)")
|
|
|
|
ctf_integer(unsigned int, index_size, hash->size)
|
|
|
|
ctf_integer(unsigned long, item_count, hash->count)
|
|
|
|
ctf_integer_hex(intptr_t, data_ptr, data)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_LOGLEVEL(frr_libfrr, hash_get, TRACE_INFO)
|
|
|
|
|
2020-09-17 01:29:32 +02:00
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
hash_insert,
|
|
|
|
TP_ARGS(struct hash *, hash, void *, data, unsigned int, key),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(name, hash->name ? hash->name : "(unnamed)")
|
|
|
|
ctf_integer(unsigned int, key, hash->size)
|
|
|
|
ctf_integer(unsigned int, index_size, hash->size)
|
|
|
|
ctf_integer(unsigned long, item_count, hash->count)
|
|
|
|
ctf_integer_hex(intptr_t, data_ptr, data)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_LOGLEVEL(frr_libfrr, hash_insert, TRACE_INFO)
|
|
|
|
|
2020-09-15 00:04:33 +02:00
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
hash_release,
|
|
|
|
TP_ARGS(struct hash *, hash, void *, data, void *, released_item),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(name, hash->name ? hash->name : "(unnamed)")
|
|
|
|
ctf_integer(unsigned int, index_size, hash->size)
|
|
|
|
ctf_integer(unsigned long, item_count, hash->count)
|
|
|
|
ctf_integer_hex(intptr_t, data_ptr, data)
|
|
|
|
ctf_integer_hex(intptr_t, released_item, data)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_LOGLEVEL(frr_libfrr, hash_release, TRACE_INFO)
|
|
|
|
|
|
|
|
#define THREAD_SCHEDULE_ARGS \
|
|
|
|
TP_ARGS(struct thread_master *, master, const char *, funcname, \
|
2022-03-01 22:18:12 +01:00
|
|
|
const char *, schedfrom, int, fromln, struct event **, \
|
2020-09-15 00:04:33 +02:00
|
|
|
thread_ptr, int, fd, int, val, void *, arg, long, time)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT_CLASS(
|
|
|
|
frr_libfrr,
|
|
|
|
thread_operation,
|
|
|
|
THREAD_SCHEDULE_ARGS,
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(threadmaster_name, master->name)
|
|
|
|
ctf_string(function_name, funcname ? funcname : "(unknown function)")
|
|
|
|
ctf_string(scheduled_from, schedfrom ? schedfrom : "(unknown file)")
|
|
|
|
ctf_integer(int, scheduled_on_line, fromln)
|
|
|
|
ctf_integer_hex(intptr_t, thread_addr, thread_ptr ? *thread_ptr : NULL)
|
|
|
|
ctf_integer(int, file_descriptor, fd)
|
|
|
|
ctf_integer(int, event_value, val)
|
|
|
|
ctf_integer_hex(intptr_t, argument_ptr, arg)
|
|
|
|
ctf_integer(long, timer, time)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
#define THREAD_OPERATION_TRACEPOINT_INSTANCE(name) \
|
|
|
|
TRACEPOINT_EVENT_INSTANCE(frr_libfrr, thread_operation, name, \
|
|
|
|
THREAD_SCHEDULE_ARGS) \
|
|
|
|
TRACEPOINT_LOGLEVEL(frr_libfrr, name, TRACE_INFO)
|
|
|
|
|
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_timer)
|
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_event)
|
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_read)
|
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_write)
|
2022-12-10 15:08:37 +01:00
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(event_cancel)
|
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(event_cancel_async)
|
2020-09-15 00:04:33 +02:00
|
|
|
THREAD_OPERATION_TRACEPOINT_INSTANCE(thread_call)
|
|
|
|
|
2020-09-15 06:28:55 +02:00
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
frr_pthread_run,
|
|
|
|
TP_ARGS(
|
|
|
|
char *, name
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(frr_pthread_name, name)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
frr_pthread_stop,
|
|
|
|
TP_ARGS(
|
|
|
|
char *, name
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(frr_pthread_name, name)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2020-09-17 20:57:36 +02:00
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
memalloc,
|
|
|
|
TP_ARGS(
|
|
|
|
struct memtype *, mt, void *, ptr, size_t, size
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(memtype, mt->name)
|
|
|
|
ctf_integer(size_t, size, size)
|
|
|
|
ctf_integer_hex(intptr_t, ptr, ptr)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
memfree,
|
|
|
|
TP_ARGS(
|
|
|
|
struct memtype *, mt, void *, ptr
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_string(memtype, mt->name)
|
|
|
|
ctf_integer_hex(intptr_t, ptr, ptr)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
list_add,
|
|
|
|
TP_ARGS(
|
|
|
|
struct list *, list, const void *, ptr
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_integer_hex(intptr_t, list, list)
|
|
|
|
ctf_integer(unsigned int, count, list->count)
|
|
|
|
ctf_integer_hex(intptr_t, ptr, ptr)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
list_remove,
|
|
|
|
TP_ARGS(
|
|
|
|
struct list *, list, const void *, ptr
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_integer_hex(intptr_t, list, list)
|
|
|
|
ctf_integer(unsigned int, count, list->count)
|
|
|
|
ctf_integer_hex(intptr_t, ptr, ptr)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
list_delete_node,
|
|
|
|
TP_ARGS(
|
|
|
|
struct list *, list, const void *, node
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_integer_hex(intptr_t, list, list)
|
|
|
|
ctf_integer(unsigned int, count, list->count)
|
|
|
|
ctf_integer_hex(intptr_t, node, node)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
list_sort,
|
|
|
|
TP_ARGS(
|
|
|
|
struct list *, list
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_integer_hex(intptr_t, list, list)
|
|
|
|
ctf_integer(unsigned int, count, list->count)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2020-09-18 21:14:09 +02:00
|
|
|
TRACEPOINT_EVENT(
|
|
|
|
frr_libfrr,
|
|
|
|
route_node_get,
|
|
|
|
TP_ARGS(
|
|
|
|
struct route_table *, table, char *, prefix
|
|
|
|
),
|
|
|
|
TP_FIELDS(
|
|
|
|
ctf_integer_hex(intptr_t, table, table)
|
|
|
|
ctf_string(prefix, prefix)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2020-09-15 00:04:33 +02:00
|
|
|
/* clang-format on */
|
|
|
|
|
2020-09-15 00:02:56 +02:00
|
|
|
#include <lttng/tracepoint-event.h>
|
2020-09-15 00:05:47 +02:00
|
|
|
#include <lttng/tracelog.h>
|
2020-09-15 00:02:56 +02:00
|
|
|
|
|
|
|
#endif /* HAVE_LTTNG */
|
|
|
|
|
2020-09-29 00:13:27 +02:00
|
|
|
#endif /* _LIBFRR_TRACE_H_ */
|