[PATCH 1/2] powerpc: merge 32-bit and 64-bit _switch implementation
Nicholas Piggin
npiggin at gmail.com
Tue Mar 28 16:51:12 AEDT 2023
On Tue Mar 28, 2023 at 3:46 AM AEST, Christophe Leroy wrote:
>
>
> Le 25/03/2023 à 14:06, Nicholas Piggin a écrit :
> > The _switch stack frame setup are substantially the same, so are the
> > comments. The difference in how the stack and current are switched,
> > and other hardware and software housekeeping is done is moved into
> > macros.
> >
> > Signed-off-by: Nicholas Piggin <npiggin at gmail.com>
> > ---
> > These patches are mostly just shuffling code around. Better? Worse?
>
> I find it nice, at least for PPC32 part.
>
> For PPC32 generated code is almost the same, only a few reordering at
> the start of the function.
>
> Before the change I have:
>
> 00000238 <_switch>:
> 238: 94 21 ff 30 stwu r1,-208(r1)
> 23c: 7c 08 02 a6 mflr r0
> 240: 90 01 00 d4 stw r0,212(r1)
> 244: 91 a1 00 44 stw r13,68(r1)
Hmm, this is how GCC seems to emits stack prologue code for ppc32.
On ppc64 the mflr r0 comes first, then the non-volatile register
saving, then the LR save, then ther r1 stdu.
Seems a bit pointless to have to different implementations. I
think we'd like to have LR saved before r1 though, otherwise you
get an unreliable backtrace in your last 2 stack frames instead
of just the last one, don't you?
Thanks,
Nick
More information about the Linuxppc-dev
mailing list