hc
2024-03-22 f63cd4c03ea42695d5f9b0e1798edd196923aae6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_TRACE_H
#define _LINUX_TRACE_H
 
#ifdef CONFIG_TRACING
 
#define TRACE_EXPORT_FUNCTION    BIT(0)
#define TRACE_EXPORT_EVENT    BIT(1)
#define TRACE_EXPORT_MARKER    BIT(2)
 
/*
 * The trace export - an export of Ftrace output. The trace_export
 * can process traces and export them to a registered destination as
 * an addition to the current only output of Ftrace - i.e. ring buffer.
 *
 * If you want traces to be sent to some other place rather than ring
 * buffer only, just need to register a new trace_export and implement
 * its own .write() function for writing traces to the storage.
 *
 * next        - pointer to the next trace_export
 * write    - copy traces which have been delt with ->commit() to
 *          the destination
 * flags    - which ftrace to be exported
 */
struct trace_export {
   struct trace_export __rcu    *next;
   void (*write)(struct trace_export *, const void *, unsigned int);
   int flags;
};
 
int register_ftrace_export(struct trace_export *export);
int unregister_ftrace_export(struct trace_export *export);
 
struct trace_array;
 
void trace_printk_init_buffers(void);
int trace_array_printk(struct trace_array *tr, unsigned long ip,
       const char *fmt, ...);
int trace_array_init_printk(struct trace_array *tr);
void trace_array_put(struct trace_array *tr);
struct trace_array *trace_array_get_by_name(const char *name);
int trace_array_destroy(struct trace_array *tr);
#endif    /* CONFIG_TRACING */
 
#endif    /* _LINUX_TRACE_H */