blob: ea6c9dea79e3aa9905cfe8c5d949a863b8b80f7f [file] [log] [blame]
Steven Rostedt95045042009-04-11 12:59:57 -04001#ifndef _LINUX_TRACE_SEQ_H
2#define _LINUX_TRACE_SEQ_H
3
Steven Rostedt6d723732009-04-10 14:53:50 -04004#include <linux/fs.h>
5
Wu Zhangjin78be6912009-06-14 14:52:30 +08006#include <asm/page.h>
7
Steven Rostedt95045042009-04-11 12:59:57 -04008/*
9 * Trace sequences are used to allow a function to call several other functions
Jiri Olsa6d3f1e12009-10-23 19:36:19 -040010 * to create a string of data to use (up to a max of PAGE_SIZE).
Steven Rostedt95045042009-04-11 12:59:57 -040011 */
12
13struct trace_seq {
14 unsigned char buffer[PAGE_SIZE];
15 unsigned int len;
16 unsigned int readpos;
Johannes Bergd184b312009-11-25 16:10:14 +010017 int full;
Steven Rostedt95045042009-04-11 12:59:57 -040018};
19
20static inline void
21trace_seq_init(struct trace_seq *s)
22{
23 s->len = 0;
24 s->readpos = 0;
Johannes Bergd184b312009-11-25 16:10:14 +010025 s->full = 0;
Steven Rostedt95045042009-04-11 12:59:57 -040026}
27
Steven Rostedt (Red Hat)7b039cb2014-06-26 09:42:41 -040028/**
29 * trace_seq_buffer_ptr - return pointer to next location in buffer
30 * @s: trace sequence descriptor
31 *
32 * Returns the pointer to the buffer where the next write to
33 * the buffer will happen. This is useful to save the location
34 * that is about to be written to and then return the result
35 * of that write.
36 */
37static inline unsigned char *
38trace_seq_buffer_ptr(struct trace_seq *s)
39{
40 return s->buffer + s->len;
41}
42
Steven Rostedt95045042009-04-11 12:59:57 -040043/*
44 * Currently only defined when tracing is enabled.
45 */
46#ifdef CONFIG_TRACING
Joe Perchesb9075fa2011-10-31 17:11:33 -070047extern __printf(2, 3)
48int trace_seq_printf(struct trace_seq *s, const char *fmt, ...);
49extern __printf(2, 0)
50int trace_seq_vprintf(struct trace_seq *s, const char *fmt, va_list args);
Steven Rostedt95045042009-04-11 12:59:57 -040051extern int
52trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary);
Steven Rostedta63ce5b2009-12-07 09:11:39 -050053extern int trace_print_seq(struct seq_file *m, struct trace_seq *s);
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -040054extern int trace_seq_to_user(struct trace_seq *s, char __user *ubuf,
55 int cnt);
Steven Rostedt95045042009-04-11 12:59:57 -040056extern int trace_seq_puts(struct trace_seq *s, const char *str);
57extern int trace_seq_putc(struct trace_seq *s, unsigned char c);
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -040058extern int trace_seq_putmem(struct trace_seq *s, const void *mem, unsigned int len);
Steven Rostedt95045042009-04-11 12:59:57 -040059extern int trace_seq_putmem_hex(struct trace_seq *s, const void *mem,
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -040060 unsigned int len);
Al Viro38eff282012-03-14 21:51:10 -040061extern int trace_seq_path(struct trace_seq *s, const struct path *path);
Steven Rostedt95045042009-04-11 12:59:57 -040062
Steven Rostedt (Red Hat)4449bf92014-05-06 13:10:24 -040063extern int trace_seq_bitmask(struct trace_seq *s, const unsigned long *maskp,
64 int nmaskbits);
65
Steven Rostedt95045042009-04-11 12:59:57 -040066#else /* CONFIG_TRACING */
67static inline int trace_seq_printf(struct trace_seq *s, const char *fmt, ...)
Steven Rostedt95045042009-04-11 12:59:57 -040068{
69 return 0;
70}
71static inline int
72trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary)
73{
74 return 0;
75}
76
Steven Rostedt (Red Hat)4449bf92014-05-06 13:10:24 -040077static inline int
78trace_seq_bitmask(struct trace_seq *s, const unsigned long *maskp,
79 int nmaskbits)
80{
81 return 0;
82}
83
Steven Rostedta63ce5b2009-12-07 09:11:39 -050084static inline int trace_print_seq(struct seq_file *m, struct trace_seq *s)
Steven Rostedt95045042009-04-11 12:59:57 -040085{
Steven Rostedta63ce5b2009-12-07 09:11:39 -050086 return 0;
Steven Rostedt95045042009-04-11 12:59:57 -040087}
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -040088static inline int trace_seq_to_user(struct trace_seq *s, char __user *ubuf,
89 int cnt)
Steven Rostedt95045042009-04-11 12:59:57 -040090{
91 return 0;
92}
93static inline int trace_seq_puts(struct trace_seq *s, const char *str)
94{
95 return 0;
96}
Steven Rostedt23de29d2009-04-20 12:59:29 -040097static inline int trace_seq_putc(struct trace_seq *s, unsigned char c)
Steven Rostedt95045042009-04-11 12:59:57 -040098{
99 return 0;
100}
101static inline int
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -0400102trace_seq_putmem(struct trace_seq *s, const void *mem, unsigned int len)
Steven Rostedt95045042009-04-11 12:59:57 -0400103{
104 return 0;
105}
106static inline int trace_seq_putmem_hex(struct trace_seq *s, const void *mem,
Steven Rostedt (Red Hat)36aabff2014-06-20 17:38:01 -0400107 unsigned int len)
Steven Rostedt95045042009-04-11 12:59:57 -0400108{
109 return 0;
110}
Al Viro38eff282012-03-14 21:51:10 -0400111static inline int trace_seq_path(struct trace_seq *s, const struct path *path)
Steven Rostedt95045042009-04-11 12:59:57 -0400112{
113 return 0;
114}
115#endif /* CONFIG_TRACING */
116
117#endif /* _LINUX_TRACE_SEQ_H */