diff options
Diffstat (limited to 'tools/lib/bpf/btf.c')
| -rw-r--r-- | tools/lib/bpf/btf.c | 47 | 
1 files changed, 36 insertions, 11 deletions
| diff --git a/tools/lib/bpf/btf.c b/tools/lib/bpf/btf.c index 7ff3d5ce44f9..77dc24d58302 100644 --- a/tools/lib/bpf/btf.c +++ b/tools/lib/bpf/btf.c @@ -1179,7 +1179,7 @@ int btf__finalize_data(struct bpf_object *obj, struct btf *btf)  static void *btf_get_raw_data(const struct btf *btf, __u32 *size, bool swap_endian); -int btf__load(struct btf *btf) +int btf__load_into_kernel(struct btf *btf)  {  	__u32 log_buf_size = 0, raw_size;  	char *log_buf = NULL; @@ -1227,6 +1227,7 @@ done:  	free(log_buf);  	return libbpf_err(err);  } +int btf__load(struct btf *) __attribute__((alias("btf__load_into_kernel")));  int btf__fd(const struct btf *btf)  { @@ -1381,21 +1382,35 @@ exit_free:  	return btf;  } -int btf__get_from_id(__u32 id, struct btf **btf) +struct btf *btf__load_from_kernel_by_id_split(__u32 id, struct btf *base_btf)  { -	struct btf *res; -	int err, btf_fd; +	struct btf *btf; +	int btf_fd; -	*btf = NULL;  	btf_fd = bpf_btf_get_fd_by_id(id);  	if (btf_fd < 0) -		return libbpf_err(-errno); - -	res = btf_get_from_fd(btf_fd, NULL); -	err = libbpf_get_error(res); +		return libbpf_err_ptr(-errno); +	btf = btf_get_from_fd(btf_fd, base_btf);  	close(btf_fd); +	return libbpf_ptr(btf); +} + +struct btf *btf__load_from_kernel_by_id(__u32 id) +{ +	return btf__load_from_kernel_by_id_split(id, NULL); +} + +int btf__get_from_id(__u32 id, struct btf **btf) +{ +	struct btf *res; +	int err; + +	*btf = NULL; +	res = btf__load_from_kernel_by_id(id); +	err = libbpf_get_error(res); +  	if (err)  		return libbpf_err(err); @@ -4020,7 +4035,7 @@ static void btf_dedup_merge_hypot_map(struct btf_dedup *d)  		 */  		if (d->hypot_adjust_canon)  			continue; -		 +  		if (t_kind == BTF_KIND_FWD && c_kind != BTF_KIND_FWD)  			d->map[t_id] = c_id; @@ -4393,7 +4408,7 @@ static int btf_dedup_remap_types(struct btf_dedup *d)   * Probe few well-known locations for vmlinux kernel image and try to load BTF   * data out of it to use for target BTF.   */ -struct btf *libbpf_find_kernel_btf(void) +struct btf *btf__load_vmlinux_btf(void)  {  	struct {  		const char *path_fmt; @@ -4439,6 +4454,16 @@ struct btf *libbpf_find_kernel_btf(void)  	return libbpf_err_ptr(-ESRCH);  } +struct btf *libbpf_find_kernel_btf(void) __attribute__((alias("btf__load_vmlinux_btf"))); + +struct btf *btf__load_module_btf(const char *module_name, struct btf *vmlinux_btf) +{ +	char path[80]; + +	snprintf(path, sizeof(path), "/sys/kernel/btf/%s", module_name); +	return btf__parse_split(path, vmlinux_btf); +} +  int btf_type_visit_type_ids(struct btf_type *t, type_id_visit_fn visit, void *ctx)  {  	int i, n, err; | 
