mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
Merge branch 'objtool/urgent' into objtool/core
Conflicts: tools/objtool/elf.c tools/objtool/elf.h tools/objtool/orc_gen.c tools/objtool/check.c Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
This commit is contained in:
commit
d832c0051f
8 changed files with 120 additions and 9 deletions
|
@ -563,8 +563,10 @@ static int read_relocs(struct elf *elf)
|
|||
break;
|
||||
default: return -1;
|
||||
}
|
||||
reloc->sym = find_symbol_by_index(elf, symndx);
|
||||
|
||||
reloc->sec = sec;
|
||||
reloc->idx = i;
|
||||
reloc->sym = find_symbol_by_index(elf, symndx);
|
||||
if (!reloc->sym) {
|
||||
WARN("can't find reloc entry symbol %d for %s",
|
||||
symndx, sec->name);
|
||||
|
@ -747,6 +749,8 @@ struct section *elf_create_section(struct elf *elf, const char *name,
|
|||
elf_hash_add(elf->section_hash, &sec->hash, sec->idx);
|
||||
elf_hash_add(elf->section_name_hash, &sec->name_hash, str_hash(sec->name));
|
||||
|
||||
elf->changed = true;
|
||||
|
||||
return sec;
|
||||
}
|
||||
|
||||
|
@ -880,11 +884,14 @@ static int elf_rebuild_rela_reloc_section(struct section *sec, int nr)
|
|||
return 0;
|
||||
}
|
||||
|
||||
int elf_rebuild_reloc_section(struct section *sec)
|
||||
int elf_rebuild_reloc_section(struct elf *elf, struct section *sec)
|
||||
{
|
||||
struct reloc *reloc;
|
||||
int nr;
|
||||
|
||||
sec->changed = true;
|
||||
elf->changed = true;
|
||||
|
||||
nr = 0;
|
||||
list_for_each_entry(reloc, &sec->reloc_list, list)
|
||||
nr++;
|
||||
|
@ -896,7 +903,54 @@ int elf_rebuild_reloc_section(struct section *sec)
|
|||
}
|
||||
}
|
||||
|
||||
int elf_write(const struct elf *elf)
|
||||
int elf_write_insn(struct elf *elf, struct section *sec,
|
||||
unsigned long offset, unsigned int len,
|
||||
const char *insn)
|
||||
{
|
||||
Elf_Data *data = sec->data;
|
||||
|
||||
if (data->d_type != ELF_T_BYTE || data->d_off) {
|
||||
WARN("write to unexpected data for section: %s", sec->name);
|
||||
return -1;
|
||||
}
|
||||
|
||||
memcpy(data->d_buf + offset, insn, len);
|
||||
elf_flagdata(data, ELF_C_SET, ELF_F_DIRTY);
|
||||
|
||||
elf->changed = true;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int elf_write_reloc(struct elf *elf, struct reloc *reloc)
|
||||
{
|
||||
struct section *sec = reloc->sec;
|
||||
|
||||
if (sec->sh.sh_type == SHT_REL) {
|
||||
reloc->rel.r_info = GELF_R_INFO(reloc->sym->idx, reloc->type);
|
||||
reloc->rel.r_offset = reloc->offset;
|
||||
|
||||
if (!gelf_update_rel(sec->data, reloc->idx, &reloc->rel)) {
|
||||
WARN_ELF("gelf_update_rel");
|
||||
return -1;
|
||||
}
|
||||
} else {
|
||||
reloc->rela.r_info = GELF_R_INFO(reloc->sym->idx, reloc->type);
|
||||
reloc->rela.r_addend = reloc->addend;
|
||||
reloc->rela.r_offset = reloc->offset;
|
||||
|
||||
if (!gelf_update_rela(sec->data, reloc->idx, &reloc->rela)) {
|
||||
WARN_ELF("gelf_update_rela");
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
elf->changed = true;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int elf_write(struct elf *elf)
|
||||
{
|
||||
struct section *sec;
|
||||
Elf_Scn *s;
|
||||
|
@ -913,6 +967,8 @@ int elf_write(const struct elf *elf)
|
|||
WARN_ELF("gelf_update_shdr");
|
||||
return -1;
|
||||
}
|
||||
|
||||
sec->changed = false;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -925,6 +981,8 @@ int elf_write(const struct elf *elf)
|
|||
return -1;
|
||||
}
|
||||
|
||||
elf->changed = false;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue