src_sec
static int init_sec(struct bpf_linker *linker, struct dst_sec *dst_sec, struct src_sec *src_sec)
dst_sec->ephemeral = src_sec->ephemeral;
if (src_sec->ephemeral)
name_off = strset__add_str(linker->strtab_strs, src_sec->sec_name);
shdr->sh_type = src_sec->shdr->sh_type;
shdr->sh_flags = src_sec->shdr->sh_flags;
shdr->sh_addralign = src_sec->shdr->sh_addralign;
shdr->sh_entsize = src_sec->shdr->sh_entsize;
data->d_type = src_sec->data->d_type;
data->d_align = src_sec->data->d_align;
static bool secs_match(struct dst_sec *dst, struct src_sec *src)
static bool sec_content_is_same(struct dst_sec *dst_sec, struct src_sec *src_sec)
if (dst_sec->sec_sz != src_sec->shdr->sh_size)
if (memcmp(dst_sec->raw_data, src_sec->data->d_buf, dst_sec->sec_sz) != 0)
static int extend_sec(struct bpf_linker *linker, struct dst_sec *dst, struct src_sec *src)
static bool is_data_sec(struct src_sec *sec)
static bool is_relo_sec(struct src_sec *sec)
struct src_sec *src_sec;
src_sec = &obj->secs[i];
if (!is_data_sec(src_sec))
dst_sec = find_dst_sec_by_name(linker, src_sec->sec_name);
dst_sec = add_dst_sec(linker, src_sec->sec_name);
err = init_sec(linker, dst_sec, src_sec);
pr_warn("failed to init section '%s'\n", src_sec->sec_name);
if (!secs_match(dst_sec, src_sec)) {
pr_warn("ELF sections %s are incompatible\n", src_sec->sec_name);
if (strcmp(src_sec->sec_name, "license") == 0
|| strcmp(src_sec->sec_name, "version") == 0) {
if (!sec_content_is_same(dst_sec, src_sec)) {
pr_warn("non-identical contents of section '%s' are not supported\n", src_sec->sec_name);
src_sec->skipped = true;
src_sec->dst_id = dst_sec->id;
src_sec->dst_id = dst_sec->id;
err = extend_sec(linker, dst_sec, src_sec);
struct src_sec *symtab = &obj->secs[obj->symtab_sec_idx];
static int linker_sanity_check_elf_symtab(struct src_obj *obj, struct src_sec *sec);
static int linker_sanity_check_elf_relos(struct src_obj *obj, struct src_sec *sec);
static struct src_sec *find_src_sec_by_name(struct src_obj *obj, const char *sec_name)
struct src_sec *sec;
struct src_sec *src_sec = NULL;
src_sec = &obj->secs[sym->st_shndx];
if (src_sec->skipped)
dst_sec = &linker->secs[src_sec->dst_id];
if (strcmp(src_sec->sec_name, JUMPTABLES_SEC) == 0)
src_sec = find_src_sec_by_name(obj, sec_name);
if (!src_sec) {
dst_sec = &linker->secs[src_sec->dst_id];
dst_sym->st_value = src_sec->dst_off + sym->st_value;
dst_sym->st_value = (src_sec ? src_sec->dst_off : 0) + sym->st_value;
struct src_sec *src_symtab = &obj->secs[obj->symtab_sec_idx];
struct src_sec *src_sec, *src_linked_sec;
src_sec = &obj->secs[i];
if (!is_relo_sec(src_sec))
src_linked_sec = &obj->secs[src_sec->shdr->sh_info];
dst_sec = find_dst_sec_by_name(linker, src_sec->sec_name);
dst_sec = add_dst_sec(linker, src_sec->sec_name);
err = init_sec(linker, dst_sec, src_sec);
pr_warn("failed to init section '%s'\n", src_sec->sec_name);
} else if (!secs_match(dst_sec, src_sec)) {
pr_warn("sections %s are not compatible\n", src_sec->sec_name);
src_sec->dst_id = dst_sec->id;
err = extend_sec(linker, dst_sec, src_sec);
src_rel = src_sec->data->d_buf;
dst_rel = dst_sec->raw_data + src_sec->dst_off;
n = src_sec->shdr->sh_size / src_sec->shdr->sh_entsize;
struct src_sec *sec = &obj->secs[src_sym->st_shndx];
struct src_sec *symtab = &obj->secs[obj->symtab_sec_idx];
struct src_sec *sec;
struct src_sec *src_sec;
src_sec = &obj->secs[i];
if (!src_sec->sec_type_id || src_sec->skipped)
dst_sec = &linker->secs[src_sec->dst_id];
t = btf__type_by_id(obj->btf, src_sec->sec_type_id);
dst_var->offset = src_sec->dst_off + src_var->offset;
struct src_sec *src_sec;
src_sec = find_src_sec_by_name(obj, sec_name);
if (!src_sec) {
dst_sec = &linker->secs[src_sec->dst_id];
dst_rec->insn_off += src_sec->dst_off;
src_sec = find_src_sec_by_name(obj, sec_name);
if (!src_sec) {
dst_sec = &linker->secs[src_sec->dst_id];
dst_rec->insn_off += src_sec->dst_off;
src_sec = find_src_sec_by_name(obj, sec_name);
if (!src_sec) {
dst_sec = &linker->secs[src_sec->dst_id];
dst_rec->insn_off += src_sec->dst_off;
static bool is_ignored_sec(struct src_sec *sec)
static struct src_sec *add_src_sec(struct src_obj *obj, const char *sec_name)
struct src_sec *secs = obj->secs, *sec;
struct src_sec *secs;
struct src_sec *sec;
struct src_sec *sec;
static int linker_sanity_check_elf_symtab(struct src_obj *obj, struct src_sec *sec)
struct src_sec *link_sec;
static int linker_sanity_check_elf_relos(struct src_obj *obj, struct src_sec *sec)
struct src_sec *link_sec, *sym_sec;