1d5915816SJoel Fernandes #ifdef CONFIG_PREEMPTIRQ_EVENTS 2d5915816SJoel Fernandes 3d5915816SJoel Fernandes #undef TRACE_SYSTEM 4d5915816SJoel Fernandes #define TRACE_SYSTEM preemptirq 5d5915816SJoel Fernandes 6d5915816SJoel Fernandes #if !defined(_TRACE_PREEMPTIRQ_H) || defined(TRACE_HEADER_MULTI_READ) 7d5915816SJoel Fernandes #define _TRACE_PREEMPTIRQ_H 8d5915816SJoel Fernandes 9d5915816SJoel Fernandes #include <linux/ktime.h> 10d5915816SJoel Fernandes #include <linux/tracepoint.h> 11d5915816SJoel Fernandes #include <linux/string.h> 12d5915816SJoel Fernandes #include <asm/sections.h> 13d5915816SJoel Fernandes 14d5915816SJoel Fernandes DECLARE_EVENT_CLASS(preemptirq_template, 15d5915816SJoel Fernandes 16d5915816SJoel Fernandes TP_PROTO(unsigned long ip, unsigned long parent_ip), 17d5915816SJoel Fernandes 18d5915816SJoel Fernandes TP_ARGS(ip, parent_ip), 19d5915816SJoel Fernandes 20d5915816SJoel Fernandes TP_STRUCT__entry( 21d5915816SJoel Fernandes __field(u32, caller_offs) 22d5915816SJoel Fernandes __field(u32, parent_offs) 23d5915816SJoel Fernandes ), 24d5915816SJoel Fernandes 25d5915816SJoel Fernandes TP_fast_assign( 26d5915816SJoel Fernandes __entry->caller_offs = (u32)(ip - (unsigned long)_stext); 27d5915816SJoel Fernandes __entry->parent_offs = (u32)(parent_ip - (unsigned long)_stext); 28d5915816SJoel Fernandes ), 29d5915816SJoel Fernandes 30d5915816SJoel Fernandes TP_printk("caller=%pF parent=%pF", 31d5915816SJoel Fernandes (void *)((unsigned long)(_stext) + __entry->caller_offs), 32d5915816SJoel Fernandes (void *)((unsigned long)(_stext) + __entry->parent_offs)) 33d5915816SJoel Fernandes ); 34d5915816SJoel Fernandes 35d5915816SJoel Fernandes #ifndef CONFIG_PROVE_LOCKING 36d5915816SJoel Fernandes DEFINE_EVENT(preemptirq_template, irq_disable, 37d5915816SJoel Fernandes TP_PROTO(unsigned long ip, unsigned long parent_ip), 38d5915816SJoel Fernandes TP_ARGS(ip, parent_ip)); 39d5915816SJoel Fernandes 40d5915816SJoel Fernandes DEFINE_EVENT(preemptirq_template, irq_enable, 41d5915816SJoel Fernandes TP_PROTO(unsigned long ip, unsigned long parent_ip), 42d5915816SJoel Fernandes TP_ARGS(ip, parent_ip)); 43d5915816SJoel Fernandes #endif 44d5915816SJoel Fernandes 45d5915816SJoel Fernandes #ifdef CONFIG_DEBUG_PREEMPT 46d5915816SJoel Fernandes DEFINE_EVENT(preemptirq_template, preempt_disable, 47d5915816SJoel Fernandes TP_PROTO(unsigned long ip, unsigned long parent_ip), 48d5915816SJoel Fernandes TP_ARGS(ip, parent_ip)); 49d5915816SJoel Fernandes 50d5915816SJoel Fernandes DEFINE_EVENT(preemptirq_template, preempt_enable, 51d5915816SJoel Fernandes TP_PROTO(unsigned long ip, unsigned long parent_ip), 52d5915816SJoel Fernandes TP_ARGS(ip, parent_ip)); 53d5915816SJoel Fernandes #endif 54d5915816SJoel Fernandes 55d5915816SJoel Fernandes #endif /* _TRACE_PREEMPTIRQ_H */ 56d5915816SJoel Fernandes 57d5915816SJoel Fernandes #include <trace/define_trace.h> 58d5915816SJoel Fernandes 59250d0c77SArnd Bergmann #endif /* !CONFIG_PREEMPTIRQ_EVENTS */ 60d5915816SJoel Fernandes 61250d0c77SArnd Bergmann #if !defined(CONFIG_PREEMPTIRQ_EVENTS) || defined(CONFIG_PROVE_LOCKING) 62d5915816SJoel Fernandes #define trace_irq_enable(...) 63d5915816SJoel Fernandes #define trace_irq_disable(...) 64d5915816SJoel Fernandes #define trace_irq_enable_rcuidle(...) 65d5915816SJoel Fernandes #define trace_irq_disable_rcuidle(...) 66250d0c77SArnd Bergmann #endif 67250d0c77SArnd Bergmann 68250d0c77SArnd Bergmann #if !defined(CONFIG_PREEMPTIRQ_EVENTS) || !defined(CONFIG_DEBUG_PREEMPT) 69250d0c77SArnd Bergmann #define trace_preempt_enable(...) 70250d0c77SArnd Bergmann #define trace_preempt_disable(...) 71d5915816SJoel Fernandes #define trace_preempt_enable_rcuidle(...) 72d5915816SJoel Fernandes #define trace_preempt_disable_rcuidle(...) 73d5915816SJoel Fernandes #endif 74