On Thu, Mar 10, 2022 at 4:12 PM Delyan Kratunov <delyank@xxxxxx> wrote: > > For internal maps, look up the key and value btf types on > open() and not load(), so that `bpf_map_btf_value_type_id` > is usable in `bpftool gen`. > > Signed-off-by: Delyan Kratunov <delyank@xxxxxx> > --- > tools/lib/bpf/libbpf.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/tools/lib/bpf/libbpf.c b/tools/lib/bpf/libbpf.c > index b6f11ce0d6bc..3fb9c926fe6e 100644 > --- a/tools/lib/bpf/libbpf.c > +++ b/tools/lib/bpf/libbpf.c > @@ -1517,6 +1517,9 @@ static char *internal_map_name(struct bpf_object *obj, const char *real_name) > return strdup(map_name); > } > > +static int > +bpf_map_find_btf_info(struct bpf_object *obj, struct bpf_map *map); > + > static int > bpf_object__init_internal_map(struct bpf_object *obj, enum libbpf_map_type type, > const char *real_name, int sec_idx, void *data, size_t data_sz) > @@ -1564,6 +1567,11 @@ bpf_object__init_internal_map(struct bpf_object *obj, enum libbpf_map_type type, > return err; > } > > + err = bpf_map_find_btf_info(obj, map); is there any reason to still do bpf_map_find_btf_info() in bpf_object__create_map()? It's also non-uniform, legacy user maps won't have btf_key_type_id/btf_value_type_id set until load, while internal maps (and BTF-defined maps) will. Let's make it uniform and call bpf_map_find_btf_info() from bpf_object__init_user_maps() early on as well (and not do that at all in bpf_object__create_map()) > + /* intentionally ignoring err, failures are fine because of > + * maps like .rodata.str1.1 > + */ if the intention is to explicitly ignore error, then the most explicit way to express this is: (void)func_that_can_return_error(...); > + > if (data) > memcpy(map->mmaped, data, data_sz); > > -- > 2.34.1