Subject: objtool: Remove check preventing branches within alternative From: Julien Thierry <[email protected]> Date: Fri, 27 Mar 2020 15:28:42 +0000
From: Julien Thierry <[email protected]> While jumping from outside an alternative region to the middle of an alternative region is very likely wrong, jumping from an alternative region into the same region is valid. It is a common pattern on arm64. The first pattern is unlikely to happen in practice and checking only for this adds a lot of complexity. Just remove the current check. Suggested-by: Josh Poimboeuf <[email protected]> Signed-off-by: Julien Thierry <[email protected]> Signed-off-by: Peter Zijlstra (Intel) <[email protected]> Link: https://lkml.kernel.org/r/[email protected] --- tools/objtool/check.c | 6 ------ 1 file changed, 6 deletions(-) --- a/tools/objtool/check.c +++ b/tools/objtool/check.c @@ -2180,12 +2180,6 @@ static int validate_branch(struct objtoo sec = insn->sec; - if (insn->alt_group && list_empty(&insn->alts)) { - WARN_FUNC("don't know how to handle branch to middle of alternative instruction group", - sec, insn->offset); - return 1; - } - while (1) { next_insn = next_insn_same_sec(file, insn);

