swh:1:snp:77163734605b0ec556b01d897b7bb4a7e30d46b6
Raw File
Tip revision: 29594404d7fe73cd80eaa4ee8c43dcc53970c60e authored by Linus Torvalds on 11 December 2012, 03:30:57 UTC
Linux 3.7
Tip revision: 2959440
printk.h
#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>
back to top