Commit 05f9cdd5 authored by Andrii Nakryiko's avatar Andrii Nakryiko Committed by Alexei Starovoitov

libbpf: Move feature detection code into its own file

It's quite a lot of well isolated code, so it seems like a good
candidate to move it out of libbpf.c to reduce its size.
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Acked-by: default avatarJohn Fastabend <john.fastabend@gmail.com>
Link: https://lore.kernel.org/bpf/20240124022127.2379740-24-andrii@kernel.org
parent d6dd1d49
libbpf-y := libbpf.o bpf.o nlattr.o btf.o libbpf_errno.o str_error.o \ libbpf-y := libbpf.o bpf.o nlattr.o btf.o libbpf_errno.o str_error.o \
netlink.o bpf_prog_linfo.o libbpf_probes.o hashmap.o \ netlink.o bpf_prog_linfo.o libbpf_probes.o hashmap.o \
btf_dump.o ringbuf.o strset.o linker.o gen_loader.o relo_core.o \ btf_dump.o ringbuf.o strset.o linker.o gen_loader.o relo_core.o \
usdt.o zip.o elf.o usdt.o zip.o elf.o features.o
...@@ -11,8 +11,6 @@ ...@@ -11,8 +11,6 @@
#include "libbpf_internal.h" #include "libbpf_internal.h"
#include "str_error.h" #include "str_error.h"
#define STRERR_BUFSIZE 128
/* A SHT_GNU_versym section holds 16-bit words. This bit is set if /* A SHT_GNU_versym section holds 16-bit words. This bit is set if
* the symbol is hidden and can only be seen when referenced using an * the symbol is hidden and can only be seen when referenced using an
* explicit version number. This is a GNU extension. * explicit version number. This is a GNU extension.
......
This diff is collapsed.
This diff is collapsed.
...@@ -361,10 +361,20 @@ enum kern_feature_id { ...@@ -361,10 +361,20 @@ enum kern_feature_id {
__FEAT_CNT, __FEAT_CNT,
}; };
struct kern_feature_cache; enum kern_feature_result {
FEAT_UNKNOWN = 0,
FEAT_SUPPORTED = 1,
FEAT_MISSING = 2,
};
struct kern_feature_cache {
enum kern_feature_result res[__FEAT_CNT];
};
bool feat_supported(struct kern_feature_cache *cache, enum kern_feature_id feat_id); bool feat_supported(struct kern_feature_cache *cache, enum kern_feature_id feat_id);
bool kernel_supports(const struct bpf_object *obj, enum kern_feature_id feat_id); bool kernel_supports(const struct bpf_object *obj, enum kern_feature_id feat_id);
int probe_kern_syscall_wrapper(void);
int probe_memcg_account(void); int probe_memcg_account(void);
int bump_rlimit_memlock(void); int bump_rlimit_memlock(void);
...@@ -626,4 +636,6 @@ int elf_resolve_syms_offsets(const char *binary_path, int cnt, ...@@ -626,4 +636,6 @@ int elf_resolve_syms_offsets(const char *binary_path, int cnt,
int elf_resolve_pattern_offsets(const char *binary_path, const char *pattern, int elf_resolve_pattern_offsets(const char *binary_path, const char *pattern,
unsigned long **poffsets, size_t *pcnt); unsigned long **poffsets, size_t *pcnt);
int probe_fd(int fd);
#endif /* __LIBBPF_LIBBPF_INTERNAL_H */ #endif /* __LIBBPF_LIBBPF_INTERNAL_H */
...@@ -2,5 +2,8 @@ ...@@ -2,5 +2,8 @@
#ifndef __LIBBPF_STR_ERROR_H #ifndef __LIBBPF_STR_ERROR_H
#define __LIBBPF_STR_ERROR_H #define __LIBBPF_STR_ERROR_H
#define STRERR_BUFSIZE 128
char *libbpf_strerror_r(int err, char *dst, int len); char *libbpf_strerror_r(int err, char *dst, int len);
#endif /* __LIBBPF_STR_ERROR_H */ #endif /* __LIBBPF_STR_ERROR_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment