[U-Boot] [PATCH 2/6] common/cmd_boot: keep ARM v7M in thumb mode during do_go_exec()

Kamil Lulko rev13 at wp.pl
Wed Apr 15 12:33:43 CEST 2015


2015-04-14 20:07 GMT+02:00 Matt Porter <mporter at konsulko.com>:
>
> On ARM v7M, the processor will return to ARM mode when executing
> a blx instruction with bit 0 of the address == 0. Always set it
> to 1 to stay in thumb mode.
>
> Signed-off-by: Matt Porter <mporter at konsulko.com>
> ---
>  common/cmd_boot.c | 4 ++++
>  1 file changed, 4 insertions(+)
>
> diff --git a/common/cmd_boot.c b/common/cmd_boot.c
> index 8f2e070..20ce652 100644
> --- a/common/cmd_boot.c
> +++ b/common/cmd_boot.c
> @@ -38,6 +38,10 @@ static int do_go(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
>          * pass address parameter as argv[0] (aka command name),
>          * and all remaining args
>          */
> +#ifdef CONFIG_CPU_V7M
> +       /* For ARM V7M, set bit zero to stay in Thumb mode */
> +       addr++;
> +#endif
>         rc = do_go_exec ((void *)addr, argc - 1, argv + 1);
>         if (rc != 0) rcode = 1;
>
> --
> 2.1.0
>
>

I think addr |= 1 would be better - there is always a possibility that
kernel image has the zero bit already set (this is the case in my own
Buildroot build setup I am using for STM32F4 builds). Anyways -
keeping this bit set should be the responsibility of kernel image
build process so such machine specific quirk can be kept out of the
common code.

/Kamil


More information about the U-Boot mailing list