Lines Matching refs:sec_name
446 char *sec_name; member
807 zfree(&prog->sec_name); in bpf_program__exit()
838 const char *name, size_t sec_idx, const char *sec_name, in bpf_object__init_prog() argument
843 sec_name, name, sec_off, insn_data_sz); in bpf_object__init_prog()
864 if (sec_name[0] == '?') { in bpf_object__init_prog()
867 sec_name++; in bpf_object__init_prog()
877 prog->sec_name = strdup(sec_name); in bpf_object__init_prog()
878 if (!prog->sec_name) in bpf_object__init_prog()
892 pr_warn("sec '%s': failed to allocate memory for prog '%s'\n", sec_name, name); in bpf_object__init_prog()
899 const char *sec_name, int sec_idx) in bpf_object__add_programs() argument
927 sec_name, sec_off); in bpf_object__add_programs()
933 sec_name, sec_off); in bpf_object__add_programs()
938 pr_warn("sec '%s': program '%s' is static and not supported\n", sec_name, name); in bpf_object__add_programs()
943 sec_name, name, sec_off / BPF_INSN_SZ, sec_off, prog_sz / BPF_INSN_SZ, prog_sz); in bpf_object__add_programs()
953 sec_name, name); in bpf_object__add_programs()
960 err = bpf_object__init_prog(obj, prog, name, sec_idx, sec_name, in bpf_object__add_programs()
1325 map->name, mname, prog->name, prog->sec_name, prog->type, in bpf_map__init_kern_struct_ops()
1331 map->name, mname, prog->name, prog->sec_name, prog->type, in bpf_map__init_kern_struct_ops()
1385 static int init_struct_ops_maps(struct bpf_object *obj, const char *sec_name, in init_struct_ops_maps() argument
1401 datasec_id = btf__find_by_name_kind(btf, sec_name, in init_struct_ops_maps()
1405 sec_name); in init_struct_ops_maps()
1418 vsi->type, sec_name); in init_struct_ops_maps()
1447 if (sec_name[0] == '?') { in init_struct_ops_maps()
1450 sec_name++; in init_struct_ops_maps()
1457 map->def.map_flags = strcmp(sec_name, STRUCT_OPS_LINK_SEC) == 0 ? BPF_F_LINK : 0; in init_struct_ops_maps()
1473 var_name, sec_name); in init_struct_ops_maps()
1491 const char *sec_name; in bpf_object_init_struct_ops() local
1500 sec_name = elf_sec_name(obj, elf_sec_by_idx(obj, sec_idx)); in bpf_object_init_struct_ops()
1501 if (!sec_name) in bpf_object_init_struct_ops()
1504 err = init_struct_ops_maps(obj, sec_name, sec_idx, desc->data); in bpf_object_init_struct_ops()
2017 const char *sec_name; in bpf_object__init_global_data_maps() local
2032 sec_name = elf_sec_name(obj, elf_sec_by_idx(obj, sec_idx)); in bpf_object__init_global_data_maps()
2034 sec_name, sec_idx, in bpf_object__init_global_data_maps()
2040 sec_name = elf_sec_name(obj, elf_sec_by_idx(obj, sec_idx)); in bpf_object__init_global_data_maps()
2042 sec_name, sec_idx, in bpf_object__init_global_data_maps()
2047 sec_name = elf_sec_name(obj, elf_sec_by_idx(obj, sec_idx)); in bpf_object__init_global_data_maps()
2049 sec_name, sec_idx, in bpf_object__init_global_data_maps()
2990 const char *sec_name, int sec_idx, in init_arena_map_data() argument
2999 sec_name, mmap_sz, data_sz); in init_arena_map_data()
3306 const char *sec_name; in bpf_object__init_btf() local
3325 sec_name = btf__name_by_offset(obj->btf, sec->sec_name_off); in bpf_object__init_btf()
3326 if (str_is_empty(sec_name)) in bpf_object__init_btf()
3328 scn = elf_sec_by_name(obj, sec_name); in bpf_object__init_btf()
3356 const char *sec_name = btf__name_by_offset(btf, t->name_off); in btf_fixup_datasec() local
3361 if (!sec_name) { in btf_fixup_datasec()
3372 if (strcmp(sec_name, KCONFIG_SEC) == 0 || strcmp(sec_name, KSYMS_SEC) == 0) in btf_fixup_datasec()
3384 err = find_elf_sec_sz(obj, sec_name, &size); in btf_fixup_datasec()
3387 sec_name, size, errstr(err)); in btf_fixup_datasec()
3403 pr_debug("sec '%s': unexpected non-VAR type found\n", sec_name); in btf_fixup_datasec()
3414 sec_name, i); in btf_fixup_datasec()
3421 sec_name, var_name); in btf_fixup_datasec()
3701 const char *sec_name; in elf_sec_by_name() local
3704 sec_name = elf_sec_name(obj, scn); in elf_sec_by_name()
3705 if (!sec_name) in elf_sec_by_name()
3708 if (strcmp(sec_name, name) != 0) in elf_sec_by_name()
4251 const char *ext_name, *sec_name; in bpf_object__collect_externs() local
4319 sec_name = btf__name_by_offset(obj->btf, sec->name_off); in bpf_object__collect_externs()
4321 if (strcmp(sec_name, KCONFIG_SEC) == 0) { in bpf_object__collect_externs()
4347 } else if (strcmp(sec_name, KSYMS_SEC) == 0) { in bpf_object__collect_externs()
4353 pr_warn("unrecognized extern section '%s'\n", sec_name); in bpf_object__collect_externs()
4780 const char *relo_sec_name, *sec_name; in bpf_object__collect_prog_relos() local
4801 sec_name = elf_sec_name(obj, scn); in bpf_object__collect_prog_relos()
4802 if (!relo_sec_name || !sec_name) in bpf_object__collect_prog_relos()
4806 relo_sec_name, sec_idx, sec_name); in bpf_object__collect_prog_relos()
4855 relo_sec_name, i, sec_name, insn_idx); in bpf_object__collect_prog_relos()
6033 const char *sec_name; in bpf_object__relocate_core() local
6060 sec_name = btf__name_by_offset(obj->btf, sec->sec_name_off); in bpf_object__relocate_core()
6061 if (str_is_empty(sec_name)) { in bpf_object__relocate_core()
6066 pr_debug("sec '%s': found %d CO-RE relocations\n", sec_name, sec->num_info); in bpf_object__relocate_core()
6083 sec_name, i, insn_idx); in bpf_object__relocate_core()
7729 attach_name = strchr(prog->sec_name, '/'); in libbpf_prepare_prog_load()
7789 prog->name, prog->sec_name); in bpf_object_load_prog()
8242 static const struct bpf_sec_def *find_sec_def(const char *sec_name);
8250 prog->sec_def = find_sec_def(prog->sec_name); in bpf_object_init_progs()
8254 prog->name, prog->sec_name); in bpf_object_init_progs()
9594 return prog->sec_name; in bpf_program__section_name()
10006 static bool sec_def_matches(const struct bpf_sec_def *sec_def, const char *sec_name) in sec_def_matches() argument
10012 if (str_has_pfx(sec_name, sec_def->sec)) in sec_def_matches()
10023 if (strncmp(sec_name, sec_def->sec, len) != 0) in sec_def_matches()
10026 if (sec_name[len] == '\0' || sec_name[len] == '/') in sec_def_matches()
10031 return strcmp(sec_name, sec_def->sec) == 0; in sec_def_matches()
10034 static const struct bpf_sec_def *find_sec_def(const char *sec_name) in find_sec_def() argument
10042 if (sec_def_matches(sec_def, sec_name)) in find_sec_def()
10049 if (sec_def_matches(sec_def, sec_name)) in find_sec_def()
12080 if (strcmp(prog->sec_name, "kprobe") == 0 || strcmp(prog->sec_name, "kretprobe") == 0) in attach_kprobe()
12083 opts.retprobe = str_has_pfx(prog->sec_name, "kretprobe/"); in attach_kprobe()
12085 func_name = prog->sec_name + sizeof("kretprobe/") - 1; in attach_kprobe()
12087 func_name = prog->sec_name + sizeof("kprobe/") - 1; in attach_kprobe()
12114 if (strcmp(prog->sec_name, "ksyscall") == 0 || strcmp(prog->sec_name, "kretsyscall") == 0) in attach_ksyscall()
12117 opts.retprobe = str_has_pfx(prog->sec_name, "kretsyscall/"); in attach_ksyscall()
12119 syscall_name = prog->sec_name + sizeof("kretsyscall/") - 1; in attach_ksyscall()
12121 syscall_name = prog->sec_name + sizeof("ksyscall/") - 1; in attach_ksyscall()
12137 if (strcmp(prog->sec_name, "kprobe.multi") == 0 || in attach_kprobe_multi()
12138 strcmp(prog->sec_name, "kretprobe.multi") == 0) in attach_kprobe_multi()
12141 opts.retprobe = str_has_pfx(prog->sec_name, "kretprobe.multi/"); in attach_kprobe_multi()
12143 spec = prog->sec_name + sizeof("kretprobe.multi/") - 1; in attach_kprobe_multi()
12145 spec = prog->sec_name + sizeof("kprobe.multi/") - 1; in attach_kprobe_multi()
12169 if (strcmp(prog->sec_name, "kprobe.session") == 0) in attach_kprobe_session()
12172 spec = prog->sec_name + sizeof("kprobe.session/") - 1; in attach_kprobe_session()
12192 n = sscanf(prog->sec_name, "%m[^/]/%m[^:]:%m[^\n]", in attach_uprobe_multi()
12208 prog->sec_name); in attach_uprobe_multi()
12709 n = sscanf(prog->sec_name, "%m[^/]/%m[^:]:%m[^\n]", in attach_uprobe()
12718 prog->name, prog->sec_name); in attach_uprobe()
12745 prog->sec_name); in attach_uprobe()
12821 const char *sec_name; in attach_usdt() local
12824 sec_name = bpf_program__section_name(prog); in attach_usdt()
12825 if (strcmp(sec_name, "usdt") == 0) { in attach_usdt()
12831 n = sscanf(sec_name, "usdt/%m[^:]:%m[^:]:%m[^:]", &path, &provider, &name); in attach_usdt()
12834 sec_name); in attach_usdt()
12939 char *sec_name, *tp_cat, *tp_name; in attach_tp() local
12944 if (strcmp(prog->sec_name, "tp") == 0 || strcmp(prog->sec_name, "tracepoint") == 0) in attach_tp()
12947 sec_name = strdup(prog->sec_name); in attach_tp()
12948 if (!sec_name) in attach_tp()
12952 if (str_has_pfx(prog->sec_name, "tp/")) in attach_tp()
12953 tp_cat = sec_name + sizeof("tp/") - 1; in attach_tp()
12955 tp_cat = sec_name + sizeof("tracepoint/") - 1; in attach_tp()
12958 free(sec_name); in attach_tp()
12965 free(sec_name); in attach_tp()
13028 if (!str_has_pfx(prog->sec_name, prefixes[i])) in attach_raw_tp()
13033 if (prog->sec_name[pfx_len] == '\0') in attach_raw_tp()
13036 if (prog->sec_name[pfx_len] != '/') in attach_raw_tp()
13039 tp_name = prog->sec_name + pfx_len + 1; in attach_raw_tp()
13045 prog->name, prog->sec_name); in attach_raw_tp()