|  | #undef TRACE_SYSTEM | 
|  | #define TRACE_SYSTEM rtc | 
|  |  | 
|  | #if !defined(_TRACE_RTC_H) || defined(TRACE_HEADER_MULTI_READ) | 
|  | #define _TRACE_RTC_H | 
|  |  | 
|  | #include <linux/rtc.h> | 
|  | #include <linux/tracepoint.h> | 
|  |  | 
|  | DECLARE_EVENT_CLASS(rtc_time_alarm_class, | 
|  |  | 
|  | TP_PROTO(time64_t secs, int err), | 
|  |  | 
|  | TP_ARGS(secs, err), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(time64_t, secs) | 
|  | __field(int, err) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->secs = secs; | 
|  | __entry->err = err; | 
|  | ), | 
|  |  | 
|  | TP_printk("UTC (%lld) (%d)", | 
|  | __entry->secs, __entry->err | 
|  | ) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_time_alarm_class, rtc_set_time, | 
|  |  | 
|  | TP_PROTO(time64_t secs, int err), | 
|  |  | 
|  | TP_ARGS(secs, err) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_time_alarm_class, rtc_read_time, | 
|  |  | 
|  | TP_PROTO(time64_t secs, int err), | 
|  |  | 
|  | TP_ARGS(secs, err) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_time_alarm_class, rtc_set_alarm, | 
|  |  | 
|  | TP_PROTO(time64_t secs, int err), | 
|  |  | 
|  | TP_ARGS(secs, err) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_time_alarm_class, rtc_read_alarm, | 
|  |  | 
|  | TP_PROTO(time64_t secs, int err), | 
|  |  | 
|  | TP_ARGS(secs, err) | 
|  | ); | 
|  |  | 
|  | TRACE_EVENT(rtc_irq_set_freq, | 
|  |  | 
|  | TP_PROTO(int freq, int err), | 
|  |  | 
|  | TP_ARGS(freq, err), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(int, freq) | 
|  | __field(int, err) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->freq = freq; | 
|  | __entry->err = err; | 
|  | ), | 
|  |  | 
|  | TP_printk("set RTC periodic IRQ frequency:%u (%d)", | 
|  | __entry->freq, __entry->err | 
|  | ) | 
|  | ); | 
|  |  | 
|  | TRACE_EVENT(rtc_irq_set_state, | 
|  |  | 
|  | TP_PROTO(int enabled, int err), | 
|  |  | 
|  | TP_ARGS(enabled, err), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(int, enabled) | 
|  | __field(int, err) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->enabled = enabled; | 
|  | __entry->err = err; | 
|  | ), | 
|  |  | 
|  | TP_printk("%s RTC 2^N Hz periodic IRQs (%d)", | 
|  | __entry->enabled ? "enable" : "disable", | 
|  | __entry->err | 
|  | ) | 
|  | ); | 
|  |  | 
|  | TRACE_EVENT(rtc_alarm_irq_enable, | 
|  |  | 
|  | TP_PROTO(unsigned int enabled, int err), | 
|  |  | 
|  | TP_ARGS(enabled, err), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(unsigned int, enabled) | 
|  | __field(int, err) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->enabled = enabled; | 
|  | __entry->err = err; | 
|  | ), | 
|  |  | 
|  | TP_printk("%s RTC alarm IRQ (%d)", | 
|  | __entry->enabled ? "enable" : "disable", | 
|  | __entry->err | 
|  | ) | 
|  | ); | 
|  |  | 
|  | DECLARE_EVENT_CLASS(rtc_offset_class, | 
|  |  | 
|  | TP_PROTO(long offset, int err), | 
|  |  | 
|  | TP_ARGS(offset, err), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(long, offset) | 
|  | __field(int, err) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->offset = offset; | 
|  | __entry->err = err; | 
|  | ), | 
|  |  | 
|  | TP_printk("RTC offset: %ld (%d)", | 
|  | __entry->offset, __entry->err | 
|  | ) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_offset_class, rtc_set_offset, | 
|  |  | 
|  | TP_PROTO(long offset, int err), | 
|  |  | 
|  | TP_ARGS(offset, err) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_offset_class, rtc_read_offset, | 
|  |  | 
|  | TP_PROTO(long offset, int err), | 
|  |  | 
|  | TP_ARGS(offset, err) | 
|  | ); | 
|  |  | 
|  | DECLARE_EVENT_CLASS(rtc_timer_class, | 
|  |  | 
|  | TP_PROTO(struct rtc_timer *timer), | 
|  |  | 
|  | TP_ARGS(timer), | 
|  |  | 
|  | TP_STRUCT__entry( | 
|  | __field(struct rtc_timer *, timer) | 
|  | __field(ktime_t, expires) | 
|  | __field(ktime_t, period) | 
|  | ), | 
|  |  | 
|  | TP_fast_assign( | 
|  | __entry->timer = timer; | 
|  | __entry->expires = timer->node.expires; | 
|  | __entry->period = timer->period; | 
|  | ), | 
|  |  | 
|  | TP_printk("RTC timer:(%p) expires:%lld period:%lld", | 
|  | __entry->timer, __entry->expires, __entry->period | 
|  | ) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_timer_class, rtc_timer_enqueue, | 
|  |  | 
|  | TP_PROTO(struct rtc_timer *timer), | 
|  |  | 
|  | TP_ARGS(timer) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_timer_class, rtc_timer_dequeue, | 
|  |  | 
|  | TP_PROTO(struct rtc_timer *timer), | 
|  |  | 
|  | TP_ARGS(timer) | 
|  | ); | 
|  |  | 
|  | DEFINE_EVENT(rtc_timer_class, rtc_timer_fired, | 
|  |  | 
|  | TP_PROTO(struct rtc_timer *timer), | 
|  |  | 
|  | TP_ARGS(timer) | 
|  | ); | 
|  |  | 
|  | #endif /* _TRACE_RTC_H */ | 
|  |  | 
|  | /* This part must be outside protection */ | 
|  | #include <trace/define_trace.h> |