[U-Boot] [PATCH v2 3/3] bootm: use genimg_get_kernel_addr()

Simon Glass sjg at chromium.org
Fri Aug 15 05:48:09 CEST 2014


Hi York,

On 14 August 2014 19:42, York Sun <yorksun at freescale.com> wrote:
> Tom,
>
> I tested with "bootm 806f0000". My FIT image is loaded there. I don't have
> load_addr variable. My default load_addr (from CONFIG macro) is different
> from this address.

Yes unfortunately this is completely wrong. I did not catch this in my
review unfortunately, perhaps because the & was removed in the code I
reviewed.

fit_uname_config and fit_uname_kernel must be passed back from
genimg_get_kernel_addr() - that function will need two new parameters.

Regards,
Simon

>
> York
>
> ________________________________
> From: Tom Rini
> Sent: Thu, 14/08/2014 18:38
> To: Sun York-R58495 <yorksun at freescale.com>
> CC: Bryan Wu <cooloney at gmail.com>; sjg at chromium.org; swarren at wwwdotorg.org;
> u-boot at lists.denx.de
>
> Subject: Re: [U-Boot] [PATCH v2 3/3] bootm: use genimg_get_kernel_addr()
>
> On Thu, Aug 14, 2014 at 06:00:31PM -0700, York Sun wrote:
>> On 08/04/2014 05:43 PM, Bryan Wu wrote:
>> > Use the new API which is originally taken out from boot_get_kernel
>> > of bootm.c
>> >
>> > Signed-off-by: Bryan Wu <pengw at nvidia.com>
>> > Tested-by: Stephen Warren <swarren at nvidia.com>
>> > Reviewed-by: Stephen Warren <swarren at nvidia.com>
>> > ---
>> >  common/bootm.c | 25 +++++--------------------
>> >  1 file changed, 5 insertions(+), 20 deletions(-)
>> >
>> > diff --git a/common/bootm.c b/common/bootm.c
>> > index 7ec2ed8..621bff2 100644
>> > --- a/common/bootm.c
>> > +++ b/common/bootm.c
>>
>> <snip>
>>
>> >      bootstage_mark(BOOTSTAGE_ID_CHECK_MAGIC);
>> >
>> > @@ -807,6 +788,10 @@ static const void *boot_get_kernel(cmd_tbl_t
>> > *cmdtp, int flag, int argc,
>> >  #endif
>> >  #if defined(CONFIG_FIT)
>> >      case IMAGE_FORMAT_FIT:
>> > +           if (!fit_parse_conf(argv[0], load_addr, &img_addr,
>> > +                                   fit_uname_config))
>> > +                   fit_parse_subimage(argv[0], load_addr, &img_addr,
>> > +                                   fit_uname_kernel);
>> >              os_noffset = fit_image_load(images, img_addr,
>> >                              &fit_uname_kernel, &fit_uname_config,
>> >                              IH_ARCH_DEFAULT, IH_TYPE_KERNEL,
>> >
>>
>> Did anyone test this addition? It breaks my booting. The variable img_addr
>> get
>> changed for calling fit_parse_conf(). If I don't use load_addr variable
>> and run
>> "bootm <addr>" with a FIT image, this will fail. It took me hours to
>> figure out.
>
> How exactly are you booting?  I tested a fit with bootm addr#conf at 1 or
> so.
>
> --
> Tom


More information about the U-Boot mailing list