License cleanup: add SPDX GPL-2.0 license identifier to files with no license
[linux-block.git] / tools / perf / util / probe-file.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
92f6c72e
MH
2#ifndef __PROBE_FILE_H
3#define __PROBE_FILE_H
4
92f6c72e
MH
5#include "probe-event.h"
6
8ec20b17
ACM
7struct strlist;
8struct strfilter;
9
dd975497
MH
10/* Cache of probe definitions */
11struct probe_cache_entry {
12 struct list_head node;
6430a94e 13 bool sdt;
dd975497
MH
14 struct perf_probe_event pev;
15 char *spev;
16 struct strlist *tevlist;
17};
18
19struct probe_cache {
20 int fd;
21 struct list_head entries;
22};
23
180b2061
MH
24enum probe_type {
25 PROBE_TYPE_U = 0,
26 PROBE_TYPE_S,
27 PROBE_TYPE_X,
28 PROBE_TYPE_STRING,
29 PROBE_TYPE_BITFIELD,
30 PROBE_TYPE_END,
31};
32
92f6c72e
MH
33#define PF_FL_UPROBE 1
34#define PF_FL_RW 2
05bf2c8a
MH
35#define for_each_probe_cache_entry(entry, pcache) \
36 list_for_each_entry(entry, &pcache->entries, node)
92f6c72e 37
40218dae
MH
38/* probe-file.c depends on libelf */
39#ifdef HAVE_LIBELF_SUPPORT
e491bc2f 40int open_trace_file(const char *trace_file, bool readwrite);
92f6c72e
MH
41int probe_file__open(int flag);
42int probe_file__open_both(int *kfd, int *ufd, int flag);
43struct strlist *probe_file__get_namelist(int fd);
44struct strlist *probe_file__get_rawlist(int fd);
45int probe_file__add_event(int fd, struct probe_trace_event *tev);
8ec20b17 46
92f6c72e 47int probe_file__del_events(int fd, struct strfilter *filter);
e607f142
NK
48int probe_file__get_events(int fd, struct strfilter *filter,
49 struct strlist *plist);
50int probe_file__del_strlist(int fd, struct strlist *namelist);
51
42bba263
MH
52int probe_cache_entry__get_event(struct probe_cache_entry *entry,
53 struct probe_trace_event **tevs);
54
f045b8c4 55struct probe_cache *probe_cache__new(const char *target, struct nsinfo *nsi);
dd975497
MH
56int probe_cache__add_entry(struct probe_cache *pcache,
57 struct perf_probe_event *pev,
58 struct probe_trace_event *tevs, int ntevs);
6430a94e 59int probe_cache__scan_sdt(struct probe_cache *pcache, const char *pathname);
dd975497
MH
60int probe_cache__commit(struct probe_cache *pcache);
61void probe_cache__purge(struct probe_cache *pcache);
62void probe_cache__delete(struct probe_cache *pcache);
4a0f65c1
MH
63int probe_cache__filter_purge(struct probe_cache *pcache,
64 struct strfilter *filter);
bc062230
MH
65struct probe_cache_entry *probe_cache__find(struct probe_cache *pcache,
66 struct perf_probe_event *pev);
67struct probe_cache_entry *probe_cache__find_by_name(struct probe_cache *pcache,
68 const char *group, const char *event);
1f3736c9 69int probe_cache__show_all_caches(struct strfilter *filter);
180b2061 70bool probe_type_is_available(enum probe_type type);
7ab31d94 71bool kretprobe_offset_is_supported(void);
40218dae 72#else /* ! HAVE_LIBELF_SUPPORT */
f045b8c4 73static inline struct probe_cache *probe_cache__new(const char *tgt __maybe_unused, struct nsinfo *nsi __maybe_unused)
40218dae
MH
74{
75 return NULL;
76}
77#define probe_cache__delete(pcache) do {} while (0)
78#endif
92f6c72e 79#endif