^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) #undef TRACE_SYSTEM
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) #define TRACE_SYSTEM alarmtimer
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) #if !defined(_TRACE_ALARMTIMER_H) || defined(TRACE_HEADER_MULTI_READ)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) #define _TRACE_ALARMTIMER_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #include <linux/alarmtimer.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #include <linux/rtc.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #include <linux/tracepoint.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) TRACE_DEFINE_ENUM(ALARM_REALTIME);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) TRACE_DEFINE_ENUM(ALARM_BOOTTIME);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) TRACE_DEFINE_ENUM(ALARM_REALTIME_FREEZER);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) TRACE_DEFINE_ENUM(ALARM_BOOTTIME_FREEZER);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define show_alarm_type(type) __print_flags(type, " | ", \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) { 1 << ALARM_REALTIME, "REALTIME" }, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) { 1 << ALARM_BOOTTIME, "BOOTTIME" }, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) { 1 << ALARM_REALTIME_FREEZER, "REALTIME Freezer" }, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) { 1 << ALARM_BOOTTIME_FREEZER, "BOOTTIME Freezer" })
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) TRACE_EVENT(alarmtimer_suspend,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) TP_PROTO(ktime_t expires, int flag),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) TP_ARGS(expires, flag),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) TP_STRUCT__entry(
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) __field(s64, expires)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) __field(unsigned char, alarm_type)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) ),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) TP_fast_assign(
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) __entry->expires = expires;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) __entry->alarm_type = flag;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) ),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) TP_printk("alarmtimer type:%s expires:%llu",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) show_alarm_type((1 << __entry->alarm_type)),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) __entry->expires
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) )
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) );
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) DECLARE_EVENT_CLASS(alarm_class,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) TP_PROTO(struct alarm *alarm, ktime_t now),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) TP_ARGS(alarm, now),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) TP_STRUCT__entry(
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) __field(void *, alarm)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) __field(unsigned char, alarm_type)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) __field(s64, expires)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) __field(s64, now)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) ),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) TP_fast_assign(
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) __entry->alarm = alarm;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) __entry->alarm_type = alarm->type;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) __entry->expires = alarm->node.expires;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) __entry->now = now;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) ),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) TP_printk("alarmtimer:%p type:%s expires:%llu now:%llu",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) __entry->alarm,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) show_alarm_type((1 << __entry->alarm_type)),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) __entry->expires,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) __entry->now
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) )
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) );
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) DEFINE_EVENT(alarm_class, alarmtimer_fired,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) TP_PROTO(struct alarm *alarm, ktime_t now),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) TP_ARGS(alarm, now)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) );
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) DEFINE_EVENT(alarm_class, alarmtimer_start,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) TP_PROTO(struct alarm *alarm, ktime_t now),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) TP_ARGS(alarm, now)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85) );
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) DEFINE_EVENT(alarm_class, alarmtimer_cancel,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) TP_PROTO(struct alarm *alarm, ktime_t now),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) TP_ARGS(alarm, now)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92) );
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) #endif /* _TRACE_ALARMTIMER_H */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96) /* This part must be outside protection */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 97) #include <trace/define_trace.h>