1 /* SPDX-License-Identifier: GPL-2.0 */
3 #define TRACE_SYSTEM printk
5 #if !defined(_TRACE_PRINTK_H) || defined(TRACE_HEADER_MULTI_READ)
6 #define _TRACE_PRINTK_H
8 #include <linux/tracepoint.h>
11 TP_PROTO(const char *text
, size_t len
),
16 __dynamic_array(char, msg
, len
+ 1)
21 * Each trace entry is printed in a new line.
22 * If the msg finishes with '\n', cut it off
23 * to avoid blank lines in the trace.
25 if ((len
> 0) && (text
[len
-1] == '\n'))
28 memcpy(__get_str(msg
), text
, len
);
29 __get_str(msg
)[len
] = 0;
32 TP_printk("%s", __get_str(msg
))
34 #endif /* _TRACE_PRINTK_H */
36 /* This part must be outside protection */
37 #include <trace/define_trace.h>