* [PATCH v3 25/28] objtool: Improve naming of group alternatives
2025-11-12 16:02 [PATCH v3 00/28] objtool: Function validation tracing Alexandre Chartre
@ 2025-11-12 16:03 ` Alexandre Chartre
2025-11-13 5:15 ` kernel test robot
0 siblings, 1 reply; 3+ messages in thread
From: Alexandre Chartre @ 2025-11-12 16:03 UTC (permalink / raw)
To: linux-kernel, mingo, jpoimboe, peterz; +Cc: alexandre.chartre
Improve the naming of group alternatives by showing the feature name and
flags used by the alternative.
Signed-off-by: Alexandre Chartre <alexandre.chartre@oracle.com>
---
tools/objtool/check.c | 31 ++------
tools/objtool/disas.c | 106 ++++++++++++++++++++------
tools/objtool/include/objtool/disas.h | 2 +
3 files changed, 90 insertions(+), 49 deletions(-)
diff --git a/tools/objtool/check.c b/tools/objtool/check.c
index 89b35e8a068d0..1aad636a8d630 100644
--- a/tools/objtool/check.c
+++ b/tools/objtool/check.c
@@ -3566,6 +3566,7 @@ static int validate_insn(struct objtool_file *file, struct symbol *func,
/* prev_state is not used if there is no disassembly support */
struct insn_state prev_state __maybe_unused;
struct alternative *alt;
+ char *alt_name = NULL;
u8 visited;
int ret;
@@ -3651,43 +3652,21 @@ static int validate_insn(struct objtool_file *file, struct symbol *func,
return 1;
if (insn->alts) {
- char alt_name[35];
- int i, num_alts;
-
- num_alts = 0;
- for (alt = insn->alts; alt; alt = alt->next) {
- if (alt->type == ALT_TYPE_INSTRUCTIONS)
- num_alts++;
- }
-
- i = 1;
for (alt = insn->alts; alt; alt = alt->next) {
if (trace) {
- switch (alt->type) {
- case ALT_TYPE_EX_TABLE:
- strcpy(alt_name, "EXCEPTION");
- break;
- case ALT_TYPE_JUMP_TABLE:
- strcpy(alt_name, "JUMP");
- break;
- case ALT_TYPE_INSTRUCTIONS:
- snprintf(alt_name, sizeof(alt_name),
- "ALTERNATIVE %d/%d", i, num_alts);
- break;
- }
+ alt_name = disas_alt_name(alt);
trace_alt_begin(insn, alt, alt_name);
}
ret = validate_branch(file, func, alt->insn, *statep);
- if (trace)
+ if (trace) {
trace_alt_end(insn, alt, alt_name);
+ free(alt_name);
+ }
if (ret) {
BT_INSN(insn, "(alt)");
return ret;
}
- if (alt->insn->alt_group)
- i++;
}
-
TRACE_ALT_INFO_NOADDR(insn, "/ ", "DEFAULT");
}
diff --git a/tools/objtool/disas.c b/tools/objtool/disas.c
index ae3b4d20cf35c..2a6c3708ec315 100644
--- a/tools/objtool/disas.c
+++ b/tools/objtool/disas.c
@@ -9,6 +9,7 @@
#include <objtool/arch.h>
#include <objtool/check.h>
#include <objtool/disas.h>
+#include <objtool/special.h>
#include <objtool/warn.h>
#include <bfd.h>
@@ -60,6 +61,21 @@ struct disas_alt {
#define DALT_GROUP(dalt) (DALT_INSN(dalt)->alt_group)
#define DALT_ALTID(dalt) ((dalt)->orig_insn->offset)
+#define ALT_FLAGS_SHIFT 16
+#define ALT_FLAG_NOT (1 << 0)
+#define ALT_FLAG_DIRECT_CALL (1 << 1)
+#define ALT_FEATURE_MASK ((1 << ALT_FLAGS_SHIFT) - 1)
+
+static int alt_feature(unsigned ft_flags)
+{
+ return (ft_flags & ALT_FEATURE_MASK);
+}
+
+static int alt_flags(unsigned ft_flags)
+{
+ return (ft_flags >> ALT_FLAGS_SHIFT);
+}
+
/*
* Wrapper around asprintf() to allocate and format a string.
* Return the allocated string or NULL on error.
@@ -588,38 +604,82 @@ static struct instruction *next_insn_same_alt(struct objtool_file *file,
insn; \
insn = next_insn_same_alt(file, alt_grp, insn))
+/*
+ * Provide a name for an alternative.
+ */
+char *disas_alt_name(struct alternative *alt)
+{
+ char pfx[4] = { 0 };
+ char *str = NULL;
+ const char *name;
+ int feature;
+ int flags;
+ int num;
+
+ switch (alt->type) {
+
+ case ALT_TYPE_EX_TABLE:
+ str = strdup("EXCEPTION");
+ break;
+
+ case ALT_TYPE_JUMP_TABLE:
+ str = strdup("JUMP");
+ break;
+
+ case ALT_TYPE_INSTRUCTIONS:
+ /*
+ * This is a non-default group alternative. Create a name
+ * based on the feature and flags associated with this
+ * alternative. Use either the feature name (it is available)
+ * or the feature number. And add a prefix to show the flags
+ * used.
+ *
+ * Prefix flags characters:
+ *
+ * '!' alternative used when feature not enabled
+ * '+' direct call alternative
+ * '?' unknown flag
+ */
+
+ feature = alt->insn->alt_group->feature;
+ num = alt_feature(feature);
+ flags = alt_flags(feature);
+ str = pfx;
+
+ if (flags & ~(ALT_FLAG_NOT | ALT_FLAG_DIRECT_CALL))
+ *str++ = '?';
+ if (flags & ALT_FLAG_DIRECT_CALL)
+ *str++ = '+';
+ if (flags & ALT_FLAG_NOT)
+ *str++ = '!';
+
+ name = arch_cpu_feature_name(num);
+ if (!name)
+ str = strfmt("%sFEATURE 0x%X", pfx, num);
+ else
+ str = strfmt("%s%s", pfx, name);
+
+ break;
+ }
+
+ return str;
+}
+
/*
* Initialize an alternative. The default alternative should be initialized
* with alt=NULL.
*/
static int disas_alt_init(struct disas_alt *dalt,
struct instruction *orig_insn,
- struct alternative *alt,
- int alt_num)
+ struct alternative *alt)
{
- char *str;
-
dalt->orig_insn = orig_insn;
dalt->alt = alt;
dalt->insn_idx = 0;
- if (!alt) {
- str = strfmt("<alternative.%lx>", orig_insn->offset);
- } else {
- switch (alt->type) {
- case ALT_TYPE_EX_TABLE:
- str = strdup("EXCEPTION");
- break;
- case ALT_TYPE_JUMP_TABLE:
- str = strdup("JUMP");
- break;
- default:
- str = strfmt("ALTERNATIVE %d", alt_num);
- break;
- }
- }
- if (!str)
+ dalt->name = alt ? disas_alt_name(alt) :
+ strfmt("<alternative.%lx>", orig_insn->offset);
+ if (!dalt->name)
return -1;
- dalt->name = str;
dalt->width = strlen(dalt->name);
return 0;
@@ -832,7 +892,7 @@ static void *disas_alt(struct disas_context *dctx,
/*
* Initialize and disassemble the default alternative.
*/
- err = disas_alt_init(&alts[0], orig_insn, NULL, 0);
+ err = disas_alt_init(&alts[0], orig_insn, NULL);
if (err)
goto error;
@@ -851,7 +911,7 @@ static void *disas_alt(struct disas_context *dctx,
break;
}
dalt = &alts[i];
- err = disas_alt_init(dalt, orig_insn, alt, i);
+ err = disas_alt_init(dalt, orig_insn, alt);
if (err)
goto error;
diff --git a/tools/objtool/include/objtool/disas.h b/tools/objtool/include/objtool/disas.h
index 5d2149ffac335..5272acd61dd03 100644
--- a/tools/objtool/include/objtool/disas.h
+++ b/tools/objtool/include/objtool/disas.h
@@ -6,6 +6,7 @@
#ifndef _DISAS_H
#define _DISAS_H
+struct alternative;
struct disas_context;
struct disassemble_info;
@@ -25,6 +26,7 @@ void disas_print_info(FILE *stream, struct instruction *insn, int depth,
void disas_print_insn(FILE *stream, struct disas_context *dctx,
struct instruction *insn, int depth,
const char *format, ...);
+char *disas_alt_name(struct alternative *alt);
#else /* DISAS */
--
2.43.5
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH v3 25/28] objtool: Improve naming of group alternatives
@ 2025-11-13 4:52 kernel test robot
0 siblings, 0 replies; 3+ messages in thread
From: kernel test robot @ 2025-11-13 4:52 UTC (permalink / raw)
To: oe-kbuild; +Cc: lkp
::::::
:::::: Manual check reason: "only suspicious fbc files changed"
::::::
BCC: lkp@intel.com
CC: oe-kbuild-all@lists.linux.dev
In-Reply-To: <20251112160315.2207947-26-alexandre.chartre@oracle.com>
References: <20251112160315.2207947-26-alexandre.chartre@oracle.com>
TO: Alexandre Chartre <alexandre.chartre@oracle.com>
TO: linux-kernel@vger.kernel.org
TO: mingo@kernel.org
TO: jpoimboe@kernel.org
TO: peterz@infradead.org
CC: alexandre.chartre@oracle.com
Hi Alexandre,
kernel test robot noticed the following build errors:
[auto build test ERROR on linus/master]
[also build test ERROR on v6.18-rc5]
[cannot apply to next-20251112]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch#_base_tree_information]
url: https://github.com/intel-lab-lkp/linux/commits/Alexandre-Chartre/objtool-Move-disassembly-functions-to-a-separated-file/20251113-013604
base: linus/master
patch link: https://lore.kernel.org/r/20251112160315.2207947-26-alexandre.chartre%40oracle.com
patch subject: [PATCH v3 25/28] objtool: Improve naming of group alternatives
:::::: branch date: 6 hours ago
:::::: commit date: 6 hours ago
config: powerpc-allnoconfig (https://download.01.org/0day-ci/archive/20251113/202511130627.2BQemoMP-lkp@intel.com/config)
compiler: powerpc-linux-gcc (GCC) 15.1.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20251113/202511130627.2BQemoMP-lkp@intel.com/reproduce)
If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@intel.com>
| Closes: https://lore.kernel.org/r/202511130627.2BQemoMP-lkp@intel.com/
All errors (new ones prefixed by >>):
check.c: In function 'validate_insn':
check.c:3656:29: error: 'trace' undeclared (first use in this function)
3656 | if (trace) {
| ^~~~~
check.c:3656:29: note: each undeclared identifier is reported only once for each function it appears in
>> check.c:3657:44: error: implicit declaration of function 'disas_alt_name' [-Wimplicit-function-declaration]
3657 | alt_name = disas_alt_name(alt);
| ^~~~~~~~~~~~~~
>> check.c:3657:42: error: assignment to 'char *' from 'int' makes pointer from integer without a cast [-Wint-conversion]
3657 | alt_name = disas_alt_name(alt);
| ^
make[5]: *** [tools/build/Makefile.build:85: tools/objtool/check.o] Error 1
make[5]: Target '__build' not remade because of errors.
make[4]: *** [Makefile:87: tools/objtool/objtool-in.o] Error 2
make[4]: Target 'all' not remade because of errors.
make[3]: *** [Makefile:73: objtool] Error 2
make[2]: *** [Makefile:1449: tools/objtool] Error 2
make[2]: Target 'prepare' not remade because of errors.
make[1]: *** [Makefile:248: __sub-make] Error 2
make[1]: Target 'prepare' not remade because of errors.
make: *** [Makefile:248: __sub-make] Error 2
make: Target 'prepare' not remade because of errors.
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v3 25/28] objtool: Improve naming of group alternatives
2025-11-12 16:03 ` [PATCH v3 25/28] objtool: Improve naming of group alternatives Alexandre Chartre
@ 2025-11-13 5:15 ` kernel test robot
0 siblings, 0 replies; 3+ messages in thread
From: kernel test robot @ 2025-11-13 5:15 UTC (permalink / raw)
To: Alexandre Chartre, linux-kernel, mingo, jpoimboe, peterz
Cc: oe-kbuild-all, alexandre.chartre
Hi Alexandre,
kernel test robot noticed the following build errors:
[auto build test ERROR on linus/master]
[also build test ERROR on v6.18-rc5]
[cannot apply to next-20251112]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch#_base_tree_information]
url: https://github.com/intel-lab-lkp/linux/commits/Alexandre-Chartre/objtool-Move-disassembly-functions-to-a-separated-file/20251113-013604
base: linus/master
patch link: https://lore.kernel.org/r/20251112160315.2207947-26-alexandre.chartre%40oracle.com
patch subject: [PATCH v3 25/28] objtool: Improve naming of group alternatives
:::::: branch date: 6 hours ago
:::::: commit date: 6 hours ago
config: powerpc-allnoconfig (https://download.01.org/0day-ci/archive/20251113/202511130627.2BQemoMP-lkp@intel.com/config)
compiler: powerpc-linux-gcc (GCC) 15.1.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20251113/202511130627.2BQemoMP-lkp@intel.com/reproduce)
If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@intel.com>
| Closes: https://lore.kernel.org/r/202511130627.2BQemoMP-lkp@intel.com/
All errors (new ones prefixed by >>):
check.c: In function 'validate_insn':
check.c:3656:29: error: 'trace' undeclared (first use in this function)
3656 | if (trace) {
| ^~~~~
check.c:3656:29: note: each undeclared identifier is reported only once for each function it appears in
>> check.c:3657:44: error: implicit declaration of function 'disas_alt_name' [-Wimplicit-function-declaration]
3657 | alt_name = disas_alt_name(alt);
| ^~~~~~~~~~~~~~
>> check.c:3657:42: error: assignment to 'char *' from 'int' makes pointer from integer without a cast [-Wint-conversion]
3657 | alt_name = disas_alt_name(alt);
| ^
make[5]: *** [tools/build/Makefile.build:85: tools/objtool/check.o] Error 1
make[5]: Target '__build' not remade because of errors.
make[4]: *** [Makefile:87: tools/objtool/objtool-in.o] Error 2
make[4]: Target 'all' not remade because of errors.
make[3]: *** [Makefile:73: objtool] Error 2
make[2]: *** [Makefile:1449: tools/objtool] Error 2
make[2]: Target 'prepare' not remade because of errors.
make[1]: *** [Makefile:248: __sub-make] Error 2
make[1]: Target 'prepare' not remade because of errors.
make: *** [Makefile:248: __sub-make] Error 2
make: Target 'prepare' not remade because of errors.
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-11-13 5:15 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-11-13 4:52 [PATCH v3 25/28] objtool: Improve naming of group alternatives kernel test robot
-- strict thread matches above, loose matches on Subject: below --
2025-11-12 16:02 [PATCH v3 00/28] objtool: Function validation tracing Alexandre Chartre
2025-11-12 16:03 ` [PATCH v3 25/28] objtool: Improve naming of group alternatives Alexandre Chartre
2025-11-13 5:15 ` kernel test robot
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.