swh:1:snp:77163734605b0ec556b01d897b7bb4a7e30d46b6
Raw File
Tip revision: 28a33cbc24e4256c143dce96c7d93bf423229f92 authored by Linus Torvalds on 21 July 2012, 20:58:29 UTC
Linux 3.5
Tip revision: 28a33cb
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