1 /* SPDX-License-Identifier: GPL-2.0 */
4 #define TRACE_SYSTEM rpm
6 #if !defined(_TRACE_RUNTIME_POWER_H) || defined(TRACE_HEADER_MULTI_READ)
7 #define _TRACE_RUNTIME_POWER_H
9 #include <linux/ktime.h>
10 #include <linux/tracepoint.h>
15 * The rpm_internal events are used for tracing some important
16 * runtime pm internal functions.
18 DECLARE_EVENT_CLASS(rpm_internal
,
20 TP_PROTO(struct device
*dev
, int flags
),
25 __string( name
, dev_name(dev
) )
27 __field( int , usage_count
)
28 __field( int , disable_depth
)
29 __field( int , runtime_auto
)
30 __field( int , request_pending
)
31 __field( int , irq_safe
)
32 __field( int , child_count
)
37 __entry
->flags
= flags
;
38 __entry
->usage_count
= atomic_read(
39 &dev
->power
.usage_count
);
40 __entry
->disable_depth
= dev
->power
.disable_depth
;
41 __entry
->runtime_auto
= dev
->power
.runtime_auto
;
42 __entry
->request_pending
= dev
->power
.request_pending
;
43 __entry
->irq_safe
= dev
->power
.irq_safe
;
44 __entry
->child_count
= atomic_read(
45 &dev
->power
.child_count
);
48 TP_printk("%s flags-%x cnt-%-2d dep-%-2d auto-%-1d p-%-1d"
50 __get_str(name
), __entry
->flags
,
52 __entry
->disable_depth
,
53 __entry
->runtime_auto
,
54 __entry
->request_pending
,
59 DEFINE_EVENT(rpm_internal
, rpm_suspend
,
61 TP_PROTO(struct device
*dev
, int flags
),
65 DEFINE_EVENT(rpm_internal
, rpm_resume
,
67 TP_PROTO(struct device
*dev
, int flags
),
71 DEFINE_EVENT(rpm_internal
, rpm_idle
,
73 TP_PROTO(struct device
*dev
, int flags
),
77 DEFINE_EVENT(rpm_internal
, rpm_usage
,
79 TP_PROTO(struct device
*dev
, int flags
),
84 TRACE_EVENT(rpm_return_int
,
85 TP_PROTO(struct device
*dev
, unsigned long ip
, int ret
),
86 TP_ARGS(dev
, ip
, ret
),
89 __string( name
, dev_name(dev
))
90 __field( unsigned long, ip
)
100 TP_printk("%pS:%s ret=%d", (void *)__entry
->ip
, __get_str(name
),
104 #define RPM_STATUS_STRINGS \
105 EM(RPM_INVALID, "RPM_INVALID") \
106 EM(RPM_ACTIVE, "RPM_ACTIVE") \
107 EM(RPM_RESUMING, "RPM_RESUMING") \
108 EM(RPM_SUSPENDED, "RPM_SUSPENDED") \
109 EMe(RPM_SUSPENDING, "RPM_SUSPENDING")
111 /* Enums require being exported to userspace, for user tool parsing. */
114 #define EM(a, b) TRACE_DEFINE_ENUM(a);
115 #define EMe(a, b) TRACE_DEFINE_ENUM(a);
120 * Now redefine the EM() and EMe() macros to map the enums to the strings that
121 * will be printed in the output.
125 #define EM(a, b) { a, b },
126 #define EMe(a, b) { a, b }
128 TRACE_EVENT(rpm_status
,
129 TP_PROTO(struct device
*dev
, enum rpm_status status
),
130 TP_ARGS(dev
, status
),
133 __string(name
, dev_name(dev
))
139 __entry
->status
= status
;
142 TP_printk("%s status=%s", __get_str(name
),
143 __print_symbolic(__entry
->status
, RPM_STATUS_STRINGS
))
146 #endif /* _TRACE_RUNTIME_POWER_H */
148 /* This part must be outside protection */
149 #include <trace/define_trace.h>