diff options
Diffstat (limited to 'tools/lib/bpf')
| -rw-r--r-- | tools/lib/bpf/bpf.h | 2 | ||||
| -rw-r--r-- | tools/lib/bpf/hashmap.h | 12 | ||||
| -rw-r--r-- | tools/lib/bpf/libbpf.c | 10 | 
3 files changed, 18 insertions, 6 deletions
| diff --git a/tools/lib/bpf/bpf.h b/tools/lib/bpf/bpf.h index 1b6015b21ba8..dbef24ebcfcb 100644 --- a/tools/lib/bpf/bpf.h +++ b/tools/lib/bpf/bpf.h @@ -233,6 +233,8 @@ LIBBPF_API int bpf_load_btf(void *btf, __u32 btf_size, char *log_buf,  LIBBPF_API int bpf_task_fd_query(int pid, int fd, __u32 flags, char *buf,  				 __u32 *buf_len, __u32 *prog_id, __u32 *fd_type,  				 __u64 *probe_offset, __u64 *probe_addr); + +enum bpf_stats_type; /* defined in up-to-date linux/bpf.h */  LIBBPF_API int bpf_enable_stats(enum bpf_stats_type type);  #ifdef __cplusplus diff --git a/tools/lib/bpf/hashmap.h b/tools/lib/bpf/hashmap.h index df59fd4fc95b..e0af36b0e5d8 100644 --- a/tools/lib/bpf/hashmap.h +++ b/tools/lib/bpf/hashmap.h @@ -11,14 +11,18 @@  #include <stdbool.h>  #include <stddef.h>  #include <limits.h> -#ifndef __WORDSIZE -#define __WORDSIZE (__SIZEOF_LONG__ * 8) -#endif  static inline size_t hash_bits(size_t h, int bits)  {  	/* shuffle bits and return requested number of upper bits */ -	return (h * 11400714819323198485llu) >> (__WORDSIZE - bits); +#if (__SIZEOF_SIZE_T__ == __SIZEOF_LONG_LONG__) +	/* LP64 case */ +	return (h * 11400714819323198485llu) >> (__SIZEOF_LONG_LONG__ * 8 - bits); +#elif (__SIZEOF_SIZE_T__ <= __SIZEOF_LONG__) +	return (h * 2654435769lu) >> (__SIZEOF_LONG__ * 8 - bits); +#else +#	error "Unsupported size_t size" +#endif  }  typedef size_t (*hashmap_hash_fn)(const void *key, void *ctx); diff --git a/tools/lib/bpf/libbpf.c b/tools/lib/bpf/libbpf.c index 477c679ed945..11e4725b8b1c 100644 --- a/tools/lib/bpf/libbpf.c +++ b/tools/lib/bpf/libbpf.c @@ -4818,7 +4818,13 @@ bpf_core_reloc_fields(struct bpf_object *obj, const char *targ_btf_path)  			err = -EINVAL;  			goto out;  		} -		prog = bpf_object__find_program_by_title(obj, sec_name); +		prog = NULL; +		for (i = 0; i < obj->nr_programs; i++) { +			if (!strcmp(obj->programs[i].section_name, sec_name)) { +				prog = &obj->programs[i]; +				break; +			} +		}  		if (!prog) {  			pr_warn("failed to find program '%s' for CO-RE offset relocation\n",  				sec_name); @@ -6653,7 +6659,7 @@ static const struct bpf_sec_def section_defs[] = {  		.expected_attach_type = BPF_TRACE_ITER,  		.is_attach_btf = true,  		.attach_fn = attach_iter), -	BPF_EAPROG_SEC("xdp_devmap",		BPF_PROG_TYPE_XDP, +	BPF_EAPROG_SEC("xdp_devmap/",		BPF_PROG_TYPE_XDP,  						BPF_XDP_DEVMAP),  	BPF_PROG_SEC("xdp",			BPF_PROG_TYPE_XDP),  	BPF_PROG_SEC("perf_event",		BPF_PROG_TYPE_PERF_EVENT), | 
