]> www.infradead.org Git - linux.git/commitdiff
objtool: Convert ANNOTATE_NOENDBR to ANNOTATE
authorPeter Zijlstra <peterz@infradead.org>
Thu, 28 Nov 2024 09:38:53 +0000 (10:38 +0100)
committerPeter Zijlstra <peterz@infradead.org>
Mon, 2 Dec 2024 11:01:41 +0000 (12:01 +0100)
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: Josh Poimboeuf <jpoimboe@kernel.org>
Link: https://lore.kernel.org/r/20241128094311.042140333@infradead.org
include/linux/objtool.h
include/linux/objtool_types.h
tools/include/linux/objtool_types.h
tools/objtool/check.c

index d98531ecc68735ddb1414d261ddaba53509e948f..b5e9c0ab4048e9c8cc3fadcb45d46ae2982f521f 100644 (file)
 #define STACK_FRAME_NON_STANDARD_FP(func)
 #endif
 
-#define ANNOTATE_NOENDBR                                       \
-       "986: \n\t"                                             \
-       ".pushsection .discard.noendbr\n\t"                     \
-       ".long 986b\n\t"                                        \
-       ".popsection\n\t"
-
 #define ASM_REACHABLE                                                  \
        "998:\n\t"                                                      \
        ".pushsection .discard.reachable\n\t"                           \
@@ -64,6 +58,8 @@
        ".long " __stringify(type) "\n\t"                               \
        ".popsection\n\t"
 
+#define ANNOTATE_NOENDBR       ASM_ANNOTATE(ANNOTYPE_NOENDBR)
+
 #else /* __ASSEMBLY__ */
 
 /*
 #endif
 .endm
 
-.macro ANNOTATE_NOENDBR
-.Lhere_\@:
-       .pushsection .discard.noendbr
-       .long   .Lhere_\@
-       .popsection
-.endm
-
 /*
  * Use objtool to validate the entry requirement that all code paths do
  * VALIDATE_UNRET_END before RET.
        .popsection
 .endm
 
+#define ANNOTATE_NOENDBR       ANNOTATE type=ANNOTYPE_NOENDBR
+
 #endif /* __ASSEMBLY__ */
 
 #else /* !CONFIG_OBJTOOL */
index 453a4f4ef39d441d1e047b2a06e6700bf1e51b21..4884f8cf84291025853d596b7f28bd5985608c6b 100644 (file)
@@ -54,4 +54,9 @@ struct unwind_hint {
 #define UNWIND_HINT_TYPE_SAVE          6
 #define UNWIND_HINT_TYPE_RESTORE       7
 
+/*
+ * Annotate types
+ */
+#define ANNOTYPE_NOENDBR               1
+
 #endif /* _LINUX_OBJTOOL_TYPES_H */
index 453a4f4ef39d441d1e047b2a06e6700bf1e51b21..4884f8cf84291025853d596b7f28bd5985608c6b 100644 (file)
@@ -54,4 +54,9 @@ struct unwind_hint {
 #define UNWIND_HINT_TYPE_SAVE          6
 #define UNWIND_HINT_TYPE_RESTORE       7
 
+/*
+ * Annotate types
+ */
+#define ANNOTYPE_NOENDBR               1
+
 #endif /* _LINUX_OBJTOOL_TYPES_H */
index b0efc8ee16d6d3a72500cc8d695c3325df08d8cb..a74ff26860f7243f011e876bf8597242ec2c844a 100644 (file)
@@ -2412,32 +2412,12 @@ static int read_annotate(struct objtool_file *file, void (*func)(int type, struc
        return 0;
 }
 
-static void __annotate_nop(int type, struct instruction *insn)
+static void __annotate_noendbr(int type, struct instruction *insn)
 {
-}
-
-static int read_noendbr_hints(struct objtool_file *file)
-{
-       struct instruction *insn;
-       struct section *rsec;
-       struct reloc *reloc;
-
-       rsec = find_section_by_name(file->elf, ".rela.discard.noendbr");
-       if (!rsec)
-               return 0;
-
-       for_each_reloc(rsec, reloc) {
-               insn = find_insn(file, reloc->sym->sec,
-                                reloc->sym->offset + reloc_addend(reloc));
-               if (!insn) {
-                       WARN("bad .discard.noendbr entry");
-                       return -1;
-               }
-
-               insn->noendbr = 1;
-       }
+       if (type != ANNOTYPE_NOENDBR)
+               return;
 
-       return 0;
+       insn->noendbr = 1;
 }
 
 static int read_retpoline_hints(struct objtool_file *file)
@@ -2713,12 +2693,10 @@ static int decode_sections(struct objtool_file *file)
        if (ret)
                return ret;
 
-       read_annotate(file, __annotate_nop);
-
        /*
         * Must be before read_unwind_hints() since that needs insn->noendbr.
         */
-       ret = read_noendbr_hints(file);
+       ret = read_annotate(file, __annotate_noendbr);
        if (ret)
                return ret;