tracing: Add trace_seq_has_overflowed() and trace_handle_return()
[deliverable/linux.git] / include / linux / trace_seq.h
CommitLineData
9504504c
SR
1#ifndef _LINUX_TRACE_SEQ_H
2#define _LINUX_TRACE_SEQ_H
3
6d723736
SR
4#include <linux/fs.h>
5
78be6914
WZ
6#include <asm/page.h>
7
9504504c
SR
8/*
9 * Trace sequences are used to allow a function to call several other functions
6d3f1e12 10 * to create a string of data to use (up to a max of PAGE_SIZE).
9504504c
SR
11 */
12
13struct trace_seq {
14 unsigned char buffer[PAGE_SIZE];
15 unsigned int len;
16 unsigned int readpos;
d184b31c 17 int full;
9504504c
SR
18};
19
20static inline void
21trace_seq_init(struct trace_seq *s)
22{
23 s->len = 0;
24 s->readpos = 0;
d184b31c 25 s->full = 0;
9504504c
SR
26}
27
7b039cb4
SRRH
28/**
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
19a7fe20
SRRH
43/**
44 * trace_seq_has_overflowed - return true if the trace_seq took too much
45 * @s: trace sequence descriptor
46 *
47 * Returns true if too much data was added to the trace_seq and it is
48 * now full and will not take anymore.
49 */
50static inline bool trace_seq_has_overflowed(struct trace_seq *s)
51{
52 return s->full || s->len > PAGE_SIZE - 1;
53}
54
9504504c
SR
55/*
56 * Currently only defined when tracing is enabled.
57 */
58#ifdef CONFIG_TRACING
b9075fa9
JP
59extern __printf(2, 3)
60int trace_seq_printf(struct trace_seq *s, const char *fmt, ...);
61extern __printf(2, 0)
62int trace_seq_vprintf(struct trace_seq *s, const char *fmt, va_list args);
9504504c
SR
63extern int
64trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary);
a63ce5b3 65extern int trace_print_seq(struct seq_file *m, struct trace_seq *s);
36aabfff
SRRH
66extern int trace_seq_to_user(struct trace_seq *s, char __user *ubuf,
67 int cnt);
9504504c
SR
68extern int trace_seq_puts(struct trace_seq *s, const char *str);
69extern int trace_seq_putc(struct trace_seq *s, unsigned char c);
36aabfff 70extern int trace_seq_putmem(struct trace_seq *s, const void *mem, unsigned int len);
9504504c 71extern int trace_seq_putmem_hex(struct trace_seq *s, const void *mem,
36aabfff 72 unsigned int len);
38eff289 73extern int trace_seq_path(struct trace_seq *s, const struct path *path);
9504504c 74
4449bf92
SRRH
75extern int trace_seq_bitmask(struct trace_seq *s, const unsigned long *maskp,
76 int nmaskbits);
77
9504504c
SR
78#else /* CONFIG_TRACING */
79static inline int trace_seq_printf(struct trace_seq *s, const char *fmt, ...)
9504504c
SR
80{
81 return 0;
82}
83static inline int
84trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary)
85{
86 return 0;
87}
88
4449bf92
SRRH
89static inline int
90trace_seq_bitmask(struct trace_seq *s, const unsigned long *maskp,
91 int nmaskbits)
92{
93 return 0;
94}
95
a63ce5b3 96static inline int trace_print_seq(struct seq_file *m, struct trace_seq *s)
9504504c 97{
a63ce5b3 98 return 0;
9504504c 99}
36aabfff
SRRH
100static inline int trace_seq_to_user(struct trace_seq *s, char __user *ubuf,
101 int cnt)
9504504c
SR
102{
103 return 0;
104}
105static inline int trace_seq_puts(struct trace_seq *s, const char *str)
106{
107 return 0;
108}
23de29de 109static inline int trace_seq_putc(struct trace_seq *s, unsigned char c)
9504504c
SR
110{
111 return 0;
112}
113static inline int
36aabfff 114trace_seq_putmem(struct trace_seq *s, const void *mem, unsigned int len)
9504504c
SR
115{
116 return 0;
117}
118static inline int trace_seq_putmem_hex(struct trace_seq *s, const void *mem,
36aabfff 119 unsigned int len)
9504504c
SR
120{
121 return 0;
122}
38eff289 123static inline int trace_seq_path(struct trace_seq *s, const struct path *path)
9504504c
SR
124{
125 return 0;
126}
127#endif /* CONFIG_TRACING */
128
129#endif /* _LINUX_TRACE_SEQ_H */
This page took 0.789435 seconds and 5 git commands to generate.