#undef TRACE_SYSTEM #define TRACE_SYSTEM printk #if !defined(_TRACE_PRINTK_H) || defined(TRACE_HEADER_MULTI_READ) #define _TRACE_PRINTK_H #include <linux/tracepoint.h> TRACE_EVENT_CONDITION(console, TP_PROTO(const char *log_buf, unsigned start, unsigned end, unsigned log_buf_len), TP_ARGS(log_buf, start, end, log_buf_len), TP_CONDITION(start != end), TP_STRUCT__entry( __dynamic_array(char, msg, end - start + 1) ), TP_fast_assign( if ((start & (log_buf_len - 1)) > (end & (log_buf_len - 1))) { memcpy(__get_dynamic_array(msg), log_buf + (start & (log_buf_len - 1)), log_buf_len - (start & (log_buf_len - 1))); memcpy((char *)__get_dynamic_array(msg) + log_buf_len - (start & (log_buf_len - 1)), log_buf, end & (log_buf_len - 1)); } else memcpy(__get_dynamic_array(msg), log_buf + (start & (log_buf_len - 1)), end - start); ((char *)__get_dynamic_array(msg))[end - start] = 0; ), TP_printk("%s", __get_str(msg)) ); #endif /* _TRACE_PRINTK_H */ /* This part must be outside protection */ #include <trace/define_trace.h>