162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * event tracer 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2022 Google Inc, Steven Rostedt <rostedt@goodmis.org> 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#define pr_fmt(fmt) fmt 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <linux/trace_events.h> 1162306a36Sopenharmony_ci#include <linux/version.h> 1262306a36Sopenharmony_ci#include <linux/module.h> 1362306a36Sopenharmony_ci#include <linux/sched.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci/* 1662306a36Sopenharmony_ci * Must include the event header that the custom event will attach to, 1762306a36Sopenharmony_ci * from the C file, and not in the custom header file. 1862306a36Sopenharmony_ci */ 1962306a36Sopenharmony_ci#include <trace/events/sched.h> 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci/* Declare CREATE_CUSTOM_TRACE_EVENTS before including custom header */ 2262306a36Sopenharmony_ci#define CREATE_CUSTOM_TRACE_EVENTS 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci#include "trace_custom_sched.h" 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci/* 2762306a36Sopenharmony_ci * As the trace events are not exported to modules, the use of 2862306a36Sopenharmony_ci * for_each_kernel_tracepoint() is needed to find the trace event 2962306a36Sopenharmony_ci * to attach to. The fct() function below, is a callback that 3062306a36Sopenharmony_ci * will be called for every event. 3162306a36Sopenharmony_ci * 3262306a36Sopenharmony_ci * Helper functions are created by the TRACE_CUSTOM_EVENT() macro 3362306a36Sopenharmony_ci * update the event. Those are of the form: 3462306a36Sopenharmony_ci * 3562306a36Sopenharmony_ci * trace_custom_event_<event>_update() 3662306a36Sopenharmony_ci * 3762306a36Sopenharmony_ci * Where <event> is the event to attach. 3862306a36Sopenharmony_ci */ 3962306a36Sopenharmony_cistatic void fct(struct tracepoint *tp, void *priv) 4062306a36Sopenharmony_ci{ 4162306a36Sopenharmony_ci trace_custom_event_sched_switch_update(tp); 4262306a36Sopenharmony_ci trace_custom_event_sched_waking_update(tp); 4362306a36Sopenharmony_ci} 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistatic int __init trace_sched_init(void) 4662306a36Sopenharmony_ci{ 4762306a36Sopenharmony_ci for_each_kernel_tracepoint(fct, NULL); 4862306a36Sopenharmony_ci return 0; 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistatic void __exit trace_sched_exit(void) 5262306a36Sopenharmony_ci{ 5362306a36Sopenharmony_ci} 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_cimodule_init(trace_sched_init); 5662306a36Sopenharmony_cimodule_exit(trace_sched_exit); 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ciMODULE_AUTHOR("Steven Rostedt"); 5962306a36Sopenharmony_ciMODULE_DESCRIPTION("Custom scheduling events"); 6062306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 61