Message ID | 0ca71a4b0ac679ea52bd9fdd1f607195d72b499f.1733245362.git.christophe.leroy@csgroup.eu (mailing list archive) |
---|---|
State | New |
Headers | show |
Series | Implement inline static calls on PPC32 - v4 | expand |
On Tue, Dec 03, 2024 at 08:44:50PM +0100, Christophe Leroy wrote: > Add support for 'bla' instruction. > > This is done by 'flagging' the address as an absolute address so that > arch_jump_destination() can calculate it as expected. Because code is > _always_ 4 bytes aligned, use bit 30 as flag. The AA field already is there, so why not, eh :-) > Also add support for 'b' and 'ba' instructions. Objtool call them jumps. > Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu> Reviewed-by: Segher Boessenkool <segher@kewrnel.crashing.org> > --- a/tools/objtool/arch/powerpc/decode.c > +++ b/tools/objtool/arch/powerpc/decode.c > @@ -55,12 +55,15 @@ int arch_decode_instruction(struct objtool_file *file, const struct section *sec > > switch (opcode) { > case 18: /* b[l][a] */ > - if ((ins & 3) == 1) /* bl */ > + if (ins & 1) /* bl[a] */ > typ = INSN_CALL; > + else /* b[a] */ > + typ = INSN_JUMP_UNCONDITIONAL; > > imm = ins & 0x3fffffc; > if (imm & 0x2000000) > imm -= 0x4000000; > + imm |= ins & 2; /* AA flag */ You could of course put that together with the 3fffffc thing, but you can leave that to the compiler as well :-) Segher
diff --git a/tools/objtool/arch/powerpc/decode.c b/tools/objtool/arch/powerpc/decode.c index 53b55690f320..c1228fef3dec 100644 --- a/tools/objtool/arch/powerpc/decode.c +++ b/tools/objtool/arch/powerpc/decode.c @@ -55,12 +55,15 @@ int arch_decode_instruction(struct objtool_file *file, const struct section *sec switch (opcode) { case 18: /* b[l][a] */ - if ((ins & 3) == 1) /* bl */ + if (ins & 1) /* bl[a] */ typ = INSN_CALL; + else /* b[a] */ + typ = INSN_JUMP_UNCONDITIONAL; imm = ins & 0x3fffffc; if (imm & 0x2000000) imm -= 0x4000000; + imm |= ins & 2; /* AA flag */ break; } @@ -77,6 +80,9 @@ int arch_decode_instruction(struct objtool_file *file, const struct section *sec unsigned long arch_jump_destination(struct instruction *insn) { + if (insn->immediate & 2) + return insn->immediate & ~2; + return insn->offset + insn->immediate; }
Add support for 'bla' instruction. This is done by 'flagging' the address as an absolute address so that arch_jump_destination() can calculate it as expected. Because code is _always_ 4 bytes aligned, use bit 30 as flag. Also add support for 'b' and 'ba' instructions. Objtool call them jumps. Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu> --- tools/objtool/arch/powerpc/decode.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-)