objtool: Re-arrange validate_functions()
authorPeter Zijlstra <peterz@infradead.org>
Mon, 23 Mar 2020 19:57:13 +0000 (20:57 +0100)
committerPeter Zijlstra <peterz@infradead.org>
Wed, 25 Mar 2020 17:28:31 +0000 (18:28 +0100)
In preparation to adding a vmlinux.o specific pass, rearrange some
code. No functional changes intended.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Miroslav Benes <mbenes@suse.cz>
Acked-by: Josh Poimboeuf <jpoimboe@redhat.com>
Link: https://lkml.kernel.org/r/20200324160924.924304616@infradead.org
tools/objtool/check.c

index 0c9c9ad..0bfcb39 100644 (file)
@@ -2395,9 +2395,8 @@ static bool ignore_unreachable_insn(struct instruction *insn)
        return false;
 }
 
-static int validate_functions(struct objtool_file *file)
+static int validate_section(struct objtool_file *file, struct section *sec)
 {
-       struct section *sec;
        struct symbol *func;
        struct instruction *insn;
        struct insn_state state;
@@ -2410,36 +2409,45 @@ static int validate_functions(struct objtool_file *file)
               CFI_NUM_REGS * sizeof(struct cfi_reg));
        state.stack_size = initial_func_cfi.cfa.offset;
 
-       for_each_sec(file, sec) {
-               list_for_each_entry(func, &sec->symbol_list, list) {
-                       if (func->type != STT_FUNC)
-                               continue;
+       list_for_each_entry(func, &sec->symbol_list, list) {
+               if (func->type != STT_FUNC)
+                       continue;
 
-                       if (!func->len) {
-                               WARN("%s() is missing an ELF size annotation",
-                                    func->name);
-                               warnings++;
-                       }
+               if (!func->len) {
+                       WARN("%s() is missing an ELF size annotation",
+                            func->name);
+                       warnings++;
+               }
 
-                       if (func->pfunc != func || func->alias != func)
-                               continue;
+               if (func->pfunc != func || func->alias != func)
+                       continue;
 
-                       insn = find_insn(file, sec, func->offset);
-                       if (!insn || insn->ignore || insn->visited)
-                               continue;
+               insn = find_insn(file, sec, func->offset);
+               if (!insn || insn->ignore || insn->visited)
+                       continue;
 
-                       state.uaccess = func->uaccess_safe;
+               state.uaccess = func->uaccess_safe;
 
-                       ret = validate_branch(file, func, insn, state);
-                       if (ret && backtrace)
-                               BT_FUNC("<=== (func)", insn);
-                       warnings += ret;
-               }
+               ret = validate_branch(file, func, insn, state);
+               if (ret && backtrace)
+                       BT_FUNC("<=== (func)", insn);
+               warnings += ret;
        }
 
        return warnings;
 }
 
+static int validate_functions(struct objtool_file *file)
+{
+       struct section *sec;
+       int warnings = 0;
+
+       for_each_sec(file, sec)
+               warnings += validate_section(file, sec);
+
+       return warnings;
+}
+
 static int validate_reachable_instructions(struct objtool_file *file)
 {
        struct instruction *insn;