// SPDX-License-Identifier: GPL-2.0 /* * event tracer * * Copyright (C) 2022 Google Inc, Steven Rostedt */ #define pr_fmt(fmt) fmt #include #include #include #include /* * Must include the event header that the custom event will attach to, * from the C file, and not in the custom header file. */ #include /* Declare CREATE_CUSTOM_TRACE_EVENTS before including custom header */ #define CREATE_CUSTOM_TRACE_EVENTS #include "trace_custom_sched.h" /* * As the trace events are not exported to modules, the use of * for_each_kernel_tracepoint() is needed to find the trace event * to attach to. The fct() function below, is a callback that * will be called for every event. * * Helper functions are created by the TRACE_CUSTOM_EVENT() macro * update the event. Those are of the form: * * trace_custom_event__update() * * Where is the event to attach. */ static void fct(struct tracepoint *tp, void *priv) { trace_custom_event_sched_switch_update(tp); trace_custom_event_sched_waking_update(tp); } static int __init trace_sched_init(void) { for_each_kernel_tracepoint(fct, NULL); return 0; } static void __exit trace_sched_exit(void) { } module_init(trace_sched_init); module_exit(trace_sched_exit); MODULE_AUTHOR("Steven Rostedt"); MODULE_DESCRIPTION("Custom scheduling events"); MODULE_LICENSE("GPL");