From eb915722cde72bbb0d177899add6397a2e8958a1 Mon Sep 17 00:00:00 2001 From: Seth Jennings Date: Mon, 24 Mar 2014 10:46:52 -0500 Subject: [PATCH] do not proceed with output generation if no changed funcs If there are no changed functions, print notice and exit. Signed-off-by: Seth Jennings --- kpatch-build/create-diff-object.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/kpatch-build/create-diff-object.c b/kpatch-build/create-diff-object.c index ff9a07a..d002023 100644 --- a/kpatch-build/create-diff-object.c +++ b/kpatch-build/create-diff-object.c @@ -829,16 +829,17 @@ out: return; } -void kpatch_include_changed_functions(struct kpatch_elf *kelf) +int kpatch_include_changed_functions(struct kpatch_elf *kelf) { struct symbol *sym; - int i; + int i, changed_nr = 0; log_debug("\n=== Inclusion Tree ===\n"); for_each_symbol(i, sym, &kelf->symbols) { if (sym->status == CHANGED && sym->type == STT_FUNC) { + changed_nr++; log_normal("changed function: %s\n", sym->name); if (!sym->include) kpatch_include_symbol(sym, 0); @@ -847,6 +848,8 @@ void kpatch_include_changed_functions(struct kpatch_elf *kelf) if (sym->type == STT_FILE) sym->include = 1; } + + return changed_nr; } int kpatch_copy_symbols(int startndx, struct kpatch_elf *src, @@ -1363,7 +1366,10 @@ int main(int argc, char *argv[]) */ kpatch_replace_sections_syms(kelf_patched); - kpatch_include_changed_functions(kelf_patched); + if (!kpatch_include_changed_functions(kelf_patched)) { + log_normal("no changed functions were found\n"); + return 3; /* 1 is ERROR, 2 is DIFF_FATAL */ + } kpatch_dump_kelf(kelf_patched); /* Generate the output elf */