mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 14:53:58 -04:00
ASAN reported a memory leak in bpf_get_ksyms(): it allocates a struct ksyms internally and never frees it. Move struct ksyms to trace_helpers.h and return it from the bpf_get_ksyms(), giving ownership to the caller. Add filtered_syms and filtered_cnt fields to the ksyms to hold the filtered array of symbols, previously returned by bpf_get_ksyms(). Fixup the call sites: kprobe_multi_test and bench_trigger. Signed-off-by: Ihor Solodrai <ihor.solodrai@linux.dev> Acked-by: Eduard Zingerman <eddyz87@gmail.com> Link: https://lore.kernel.org/r/20260223190736.649171-10-ihor.solodrai@linux.dev Signed-off-by: Alexei Starovoitov <ast@kernel.org>
67 lines
1.8 KiB
C
67 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __TRACE_HELPER_H
|
|
#define __TRACE_HELPER_H
|
|
|
|
#include <bpf/libbpf.h>
|
|
|
|
#ifdef __x86_64__
|
|
#define SYS_PREFIX "__x64_"
|
|
#elif defined(__s390x__)
|
|
#define SYS_PREFIX "__s390x_"
|
|
#elif defined(__aarch64__)
|
|
#define SYS_PREFIX "__arm64_"
|
|
#elif defined(__riscv)
|
|
#define SYS_PREFIX "__riscv_"
|
|
#else
|
|
#define SYS_PREFIX ""
|
|
#endif
|
|
|
|
#define __ALIGN_MASK(x, mask) (((x)+(mask))&~(mask))
|
|
#define ALIGN(x, a) __ALIGN_MASK(x, (typeof(x))(a)-1)
|
|
|
|
struct ksym {
|
|
long addr;
|
|
char *name;
|
|
};
|
|
|
|
struct ksyms {
|
|
struct ksym *syms;
|
|
size_t sym_cap;
|
|
size_t sym_cnt;
|
|
char **filtered_syms;
|
|
size_t filtered_cnt;
|
|
};
|
|
|
|
typedef int (*ksym_cmp_t)(const void *p1, const void *p2);
|
|
typedef int (*ksym_search_cmp_t)(const void *p1, const struct ksym *p2);
|
|
|
|
int load_kallsyms(void);
|
|
struct ksym *ksym_search(long key);
|
|
long ksym_get_addr(const char *name);
|
|
|
|
struct ksyms *load_kallsyms_local(void);
|
|
struct ksym *ksym_search_local(struct ksyms *ksyms, long key);
|
|
long ksym_get_addr_local(struct ksyms *ksyms, const char *name);
|
|
void free_kallsyms_local(struct ksyms *ksyms);
|
|
|
|
struct ksyms *load_kallsyms_custom_local(ksym_cmp_t cmp_cb);
|
|
struct ksym *search_kallsyms_custom_local(struct ksyms *ksyms, const void *p1,
|
|
ksym_search_cmp_t cmp_cb);
|
|
|
|
/* open kallsyms and find addresses on the fly, faster than load + search. */
|
|
int kallsyms_find(const char *sym, unsigned long long *addr);
|
|
|
|
void read_trace_pipe(void);
|
|
int read_trace_pipe_iter(void (*cb)(const char *str, void *data),
|
|
void *data, int iter);
|
|
|
|
ssize_t get_uprobe_offset(const void *addr);
|
|
ssize_t get_rel_offset(uintptr_t addr);
|
|
|
|
int read_build_id(const char *path, char *build_id, size_t size);
|
|
|
|
int bpf_get_ksyms(struct ksyms **ksymsp, bool kernel);
|
|
int bpf_get_addrs(unsigned long **addrsp, size_t *cntp, bool kernel);
|
|
|
|
#endif
|