[RFC PATCH v1] arm: lib: add __gnu_thumb1_case_si

Pali Rohár pali at kernel.org
Sun Apr 2 12:17:17 CEST 2023


On Saturday 01 April 2023 15:17:59 Tony Dinh wrote:
> Hi Francis,
> 
> On Sat, Apr 1, 2023 at 2:55 PM Francis Laniel
> <francis.laniel at amarulasolutions.com> wrote:
> >
> > The assembly for __gnu_thumb1_case_si was taken from upstream gcc and adapted
> > as width suffix was removed for the add instruction [1].
> >
> > Signed-off-by: Francis Laniel <francis.laniel at amarulasolutions.com>
> > Tested-by: Tony Dinh <mibodhi at gmail.com>
> > [1] https://github.com/gcc-mirror/gcc/blob/4f181f9c7ee3efc509d185fdfda33be9018f1611/libgcc/config/arm/lib1funcs.S#L2156
> 
> Thanks for the patch! I've added Tom, Pali, and Stefan.

Looks good,

Acked-by: Pali Rohár <pali at kernel.org>

> I think we need to do some more testing for other boards that have
> CONFIG_HAS_THUMB2 and CONFIG_SPL_SYS_THUMB_BUILD. My test target
> (Marvell Armada 385 SoC) is somewhat broken right now. So it will take
> some time for me to get that back running to run this test.
> 
> All the best,
> Tony
> 
> > ---
> >  arch/arm/lib/lib1funcs.S | 17 +++++++++++++++++
> >  1 file changed, 17 insertions(+)
> >
> > diff --git a/arch/arm/lib/lib1funcs.S b/arch/arm/lib/lib1funcs.S
> > index 7ff4446dd6..79cedc0aad 100644
> > --- a/arch/arm/lib/lib1funcs.S
> > +++ b/arch/arm/lib/lib1funcs.S
> > @@ -424,4 +424,21 @@ ENTRY(__gnu_thumb1_case_uhi)
> >         ret     lr
> >  ENDPROC(__gnu_thumb1_case_uhi)
> >  .popsection
> > +
> > +/* Taken and adapted from: https://github.com/gcc-mirror/gcc/blob/4f181f9c7ee3efc509d185fdfda33be9018f1611/libgcc/config/arm/lib1funcs.S#L2156 */
> > +.pushsection .text.__gnu_thumb1_case_si, "ax"
> > +ENTRY(__gnu_thumb1_case_si)
> > +       push    {r0, r1}
> > +       mov     r1, lr
> > +       adds    r1, r1, #2      /* Align to word.  */
> > +       lsrs    r1, r1, #2
> > +       lsls    r0, r0, #2
> > +       lsls    r1, r1, #2
> > +       ldr     r0, [r1, r0]
> > +       adds    r0, r0, r1
> > +       mov     lr, r0
> > +       pop     {r0, r1}
> > +       mov     pc, lr          /* We know we were called from thumb code.  */
> > +ENDPROC(__gnu_thumb1_case_si)
> > +.popsection
> >  #endif
> > --
> > 2.34.1
> >


More information about the U-Boot mailing list