mirror of
https://github.com/dynup/kpatch
synced 2025-01-05 04:29:31 +00:00
create-diff-object: reduce indentation in kpatch_create_patches_sections()
Reverse the if condition and use a 'continue' statement to reduce indentation and improve readability. Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
This commit is contained in:
parent
e2c66d7fb0
commit
74c9c99931
@ -2719,9 +2719,12 @@ static void kpatch_create_patches_sections(struct kpatch_elf *kelf,
|
|||||||
|
|
||||||
/* count patched functions */
|
/* count patched functions */
|
||||||
nr = 0;
|
nr = 0;
|
||||||
list_for_each_entry(sym, &kelf->symbols, list)
|
list_for_each_entry(sym, &kelf->symbols, list) {
|
||||||
if (sym->type == STT_FUNC && sym->status == CHANGED && !sym->parent)
|
if (sym->type != STT_FUNC || sym->status != CHANGED ||
|
||||||
nr++;
|
sym->parent)
|
||||||
|
continue;
|
||||||
|
nr++;
|
||||||
|
}
|
||||||
|
|
||||||
/* create text/rela section pair */
|
/* create text/rela section pair */
|
||||||
sec = create_section_pair(kelf, ".kpatch.funcs", sizeof(*funcs), nr);
|
sec = create_section_pair(kelf, ".kpatch.funcs", sizeof(*funcs), nr);
|
||||||
@ -2739,72 +2742,70 @@ static void kpatch_create_patches_sections(struct kpatch_elf *kelf,
|
|||||||
/* populate sections */
|
/* populate sections */
|
||||||
index = 0;
|
index = 0;
|
||||||
list_for_each_entry(sym, &kelf->symbols, list) {
|
list_for_each_entry(sym, &kelf->symbols, list) {
|
||||||
if (sym->type == STT_FUNC && sym->status == CHANGED && !sym->parent) {
|
if (sym->type != STT_FUNC || sym->status != CHANGED ||
|
||||||
if (sym->bind == STB_LOCAL) {
|
sym->parent)
|
||||||
if (lookup_local_symbol(table, sym->name,
|
continue;
|
||||||
&result))
|
|
||||||
ERROR("lookup_local_symbol %s",
|
|
||||||
sym->name);
|
|
||||||
} else {
|
|
||||||
if(lookup_global_symbol(table, sym->name,
|
|
||||||
&result))
|
|
||||||
ERROR("lookup_global_symbol %s",
|
|
||||||
sym->name);
|
|
||||||
}
|
|
||||||
log_debug("lookup for %s @ 0x%016lx len %lu\n",
|
|
||||||
sym->name, result.value, result.size);
|
|
||||||
|
|
||||||
/*
|
if (sym->bind == STB_LOCAL) {
|
||||||
* Convert global symbols to local so other objects in
|
if (lookup_local_symbol(table, sym->name, &result))
|
||||||
* the patch module (like the patch callback object's init
|
ERROR("lookup_local_symbol %s", sym->name);
|
||||||
* code) won't link to this function and call it before
|
} else {
|
||||||
* its relocations have been applied.
|
if (lookup_global_symbol(table, sym->name, &result))
|
||||||
*/
|
ERROR("lookup_global_symbol %s", sym->name);
|
||||||
sym->bind = STB_LOCAL;
|
|
||||||
sym->sym.st_info = (unsigned char)
|
|
||||||
GELF_ST_INFO(sym->bind, sym->type);
|
|
||||||
|
|
||||||
/* add entry in text section */
|
|
||||||
funcs[index].old_addr = result.value;
|
|
||||||
funcs[index].old_size = result.size;
|
|
||||||
funcs[index].new_size = sym->sym.st_size;
|
|
||||||
funcs[index].sympos = result.pos;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Add a relocation that will populate
|
|
||||||
* the funcs[index].new_addr field at
|
|
||||||
* module load time.
|
|
||||||
*/
|
|
||||||
ALLOC_LINK(rela, &relasec->relas);
|
|
||||||
rela->sym = sym;
|
|
||||||
rela->type = ABSOLUTE_RELA_TYPE;
|
|
||||||
rela->addend = 0;
|
|
||||||
rela->offset = (unsigned int)(index * sizeof(*funcs));
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Add a relocation that will populate
|
|
||||||
* the funcs[index].name field.
|
|
||||||
*/
|
|
||||||
ALLOC_LINK(rela, &relasec->relas);
|
|
||||||
rela->sym = strsym;
|
|
||||||
rela->type = ABSOLUTE_RELA_TYPE;
|
|
||||||
rela->addend = offset_of_string(&kelf->strings, sym->name);
|
|
||||||
rela->offset = (unsigned int)(index * sizeof(*funcs) +
|
|
||||||
offsetof(struct kpatch_patch_func, name));
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Add a relocation that will populate
|
|
||||||
* the funcs[index].objname field.
|
|
||||||
*/
|
|
||||||
ALLOC_LINK(rela, &relasec->relas);
|
|
||||||
rela->sym = strsym;
|
|
||||||
rela->type = ABSOLUTE_RELA_TYPE;
|
|
||||||
rela->addend = objname_offset;
|
|
||||||
rela->offset = (unsigned int)(index * sizeof(*funcs) +
|
|
||||||
offsetof(struct kpatch_patch_func,objname));
|
|
||||||
|
|
||||||
index++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
log_debug("lookup for %s @ 0x%016lx len %lu\n",
|
||||||
|
sym->name, result.value, result.size);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Convert global symbols to local so other objects in the
|
||||||
|
* patch module (like the patch callback object's init code)
|
||||||
|
* won't link to this function and call it before its
|
||||||
|
* relocations have been applied.
|
||||||
|
*/
|
||||||
|
sym->bind = STB_LOCAL;
|
||||||
|
sym->sym.st_info = (unsigned char)
|
||||||
|
GELF_ST_INFO(sym->bind, sym->type);
|
||||||
|
|
||||||
|
/* add entry in text section */
|
||||||
|
funcs[index].old_addr = result.value;
|
||||||
|
funcs[index].old_size = result.size;
|
||||||
|
funcs[index].new_size = sym->sym.st_size;
|
||||||
|
funcs[index].sympos = result.pos;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add a relocation that will populate the
|
||||||
|
* funcs[index].new_addr field at module load time.
|
||||||
|
*/
|
||||||
|
ALLOC_LINK(rela, &relasec->relas);
|
||||||
|
rela->sym = sym;
|
||||||
|
rela->type = ABSOLUTE_RELA_TYPE;
|
||||||
|
rela->addend = 0;
|
||||||
|
rela->offset = (unsigned int)(index * sizeof(*funcs));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add a relocation that will populate the funcs[index].name
|
||||||
|
* field.
|
||||||
|
*/
|
||||||
|
ALLOC_LINK(rela, &relasec->relas);
|
||||||
|
rela->sym = strsym;
|
||||||
|
rela->type = ABSOLUTE_RELA_TYPE;
|
||||||
|
rela->addend = offset_of_string(&kelf->strings, sym->name);
|
||||||
|
rela->offset = (unsigned int)(index * sizeof(*funcs) +
|
||||||
|
offsetof(struct kpatch_patch_func, name));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add a relocation that will populate the funcs[index].objname
|
||||||
|
* field.
|
||||||
|
*/
|
||||||
|
ALLOC_LINK(rela, &relasec->relas);
|
||||||
|
rela->sym = strsym;
|
||||||
|
rela->type = ABSOLUTE_RELA_TYPE;
|
||||||
|
rela->addend = objname_offset;
|
||||||
|
rela->offset = (unsigned int)(index * sizeof(*funcs) +
|
||||||
|
offsetof(struct kpatch_patch_func,objname));
|
||||||
|
|
||||||
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* sanity check, index should equal nr */
|
/* sanity check, index should equal nr */
|
||||||
|
Loading…
Reference in New Issue
Block a user