blob: f3a12566bed057143cbc966530f5df525043a67e [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Steven Rostedt2e26ca72010-05-05 10:52:31 -04002#undef TRACE_SYSTEM
3#define TRACE_SYSTEM napi
4
5#if !defined(_TRACE_NAPI_H) || defined(TRACE_HEADER_MULTI_READ)
Neil Horman4ea7e382009-05-21 07:36:08 +00006#define _TRACE_NAPI_H_
7
8#include <linux/netdevice.h>
9#include <linux/tracepoint.h>
Neil Horman3e4b10d2010-08-23 18:43:51 +090010#include <linux/ftrace.h>
Neil Horman4ea7e382009-05-21 07:36:08 +000011
Neil Horman3e4b10d2010-08-23 18:43:51 +090012#define NO_DEV "(no_device)"
13
14TRACE_EVENT(napi_poll,
15
Jesper Dangaard Brouer1db19db2016-07-07 18:01:32 +020016 TP_PROTO(struct napi_struct *napi, int work, int budget),
Neil Horman3e4b10d2010-08-23 18:43:51 +090017
Jesper Dangaard Brouer1db19db2016-07-07 18:01:32 +020018 TP_ARGS(napi, work, budget),
Neil Horman3e4b10d2010-08-23 18:43:51 +090019
20 TP_STRUCT__entry(
21 __field( struct napi_struct *, napi)
Jesper Dangaard Brouer02a19872016-07-15 23:55:20 +020022 __string( dev_name, napi->dev ? napi->dev->name : NO_DEV)
Jesper Dangaard Brouer1db19db2016-07-07 18:01:32 +020023 __field( int, work)
24 __field( int, budget)
Neil Horman3e4b10d2010-08-23 18:43:51 +090025 ),
26
27 TP_fast_assign(
28 __entry->napi = napi;
Jesper Dangaard Brouer02a19872016-07-15 23:55:20 +020029 __assign_str(dev_name, napi->dev ? napi->dev->name : NO_DEV);
Jesper Dangaard Brouer1db19db2016-07-07 18:01:32 +020030 __entry->work = work;
31 __entry->budget = budget;
Neil Horman3e4b10d2010-08-23 18:43:51 +090032 ),
33
Jesper Dangaard Brouer1db19db2016-07-07 18:01:32 +020034 TP_printk("napi poll on napi struct %p for device %s work %d budget %d",
35 __entry->napi, __get_str(dev_name),
36 __entry->work, __entry->budget)
Neil Horman3e4b10d2010-08-23 18:43:51 +090037);
38
39#undef NO_DEV
Neil Horman4ea7e382009-05-21 07:36:08 +000040
Steven Rostedt2e26ca72010-05-05 10:52:31 -040041#endif /* _TRACE_NAPI_H_ */
42
43/* This part must be outside protection */
44#include <trace/define_trace.h>