diff mbox series

[U-Boot,v3] imximage: Remove failure when no IVT offset is found

Message ID 1520594700-23965-1-git-send-email-festevam@gmail.com
State Awaiting Upstream
Headers show
Series [U-Boot,v3] imximage: Remove failure when no IVT offset is found | expand

Commit Message

Fabio Estevam March 9, 2018, 11:25 a.m. UTC
From: Fabio Estevam <fabio.estevam@nxp.com>

Sometimes imximage throws the following error:

  CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
  CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
  MKIMAGE u-boot-dtb.imx
Error: No BOOT_FROM tag in board/freescale/vf610twr/imximage.cfg.cfgtmp
arch/arm/mach-imx/Makefile:100: recipe for target 'u-boot-dtb.imx' failed

Later on, when running mkimage for the u-boot.imx it will succeed in
finding the IVT offset.

Looks like some race condition happening during parallel build when
processing mkimage for u-boot-dtb.imx and u-boot.imx.

A proper fix still needs to be implemented, but as a workaround let's
remove the error when the IVT offset is not found.

It is useful to have such message, especially during bring-up phase,
but the build error that it causes is severe, so better avoid the
build error for now.

The error checking can be re-implemented later when we have a proper
fix.

Reported-by: Breno Lima <breno.lima@nxp.com>
Reported-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Signed-off-by: Fabio Estevam <fabio.estevam@nxp.com>
---
Changes since v2:
- Use my NXP address in the From field.

 tools/imximage.c | 5 -----
 1 file changed, 5 deletions(-)

Comments

Stefano Babic March 9, 2018, 12:08 p.m. UTC | #1
On 09/03/2018 12:25, Fabio Estevam wrote:
> From: Fabio Estevam <fabio.estevam@nxp.com>
> 
> Sometimes imximage throws the following error:
> 
>   CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
>   CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
>   MKIMAGE u-boot-dtb.imx
> Error: No BOOT_FROM tag in board/freescale/vf610twr/imximage.cfg.cfgtmp
> arch/arm/mach-imx/Makefile:100: recipe for target 'u-boot-dtb.imx' failed
> 
> Later on, when running mkimage for the u-boot.imx it will succeed in
> finding the IVT offset.
> 
> Looks like some race condition happening during parallel build when
> processing mkimage for u-boot-dtb.imx and u-boot.imx.
> 
> A proper fix still needs to be implemented, but as a workaround let's
> remove the error when the IVT offset is not found.
> 
> It is useful to have such message, especially during bring-up phase,
> but the build error that it causes is severe, so better avoid the
> build error for now.
> 
> The error checking can be re-implemented later when we have a proper
> fix.
> 
> Reported-by: Breno Lima <breno.lima@nxp.com>
> Reported-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
> Signed-off-by: Fabio Estevam <fabio.estevam@nxp.com>
> ---
> Changes since v2:
> - Use my NXP address in the From field.
> 
>  tools/imximage.c | 5 -----
>  1 file changed, 5 deletions(-)
> 
> diff --git a/tools/imximage.c b/tools/imximage.c
> index eb7e682..ed9d935 100644
> --- a/tools/imximage.c
> +++ b/tools/imximage.c
> @@ -777,11 +777,6 @@ static uint32_t parse_cfg_file(struct imx_header *imxhdr, char *name)
>  	(*set_dcd_rst)(imxhdr, dcd_len, name, lineno);
>  	fclose(fd);
>  
> -	/* Exit if there is no BOOT_FROM field specifying the flash_offset */
> -	if (imximage_ivt_offset == FLASH_OFFSET_UNDEFINED) {
> -		fprintf(stderr, "Error: No BOOT_FROM tag in %s\n", name);
> -		exit(EXIT_FAILURE);
> -	}
>  	return dcd_len;
>  }

As discussed, applied as fix for the release - thanks !

Best regards,
Stefano Babic
Trent Piepho April 6, 2018, 11:56 p.m. UTC | #2
On Fri, 2018-03-09 at 08:25 -0300, Fabio Estevam wrote:
> From: Fabio Estevam <fabio.estevam@nxp.com>
> 
> Sometimes imximage throws the following error:
> 
>   CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
>   CFGS    board/freescale/vf610twr/imximage.cfg.cfgtmp
>   MKIMAGE u-boot-dtb.imx
> Error: No BOOT_FROM tag in
> board/freescale/vf610twr/imximage.cfg.cfgtmp
> arch/arm/mach-imx/Makefile:100: recipe for target 'u-boot-dtb.imx'
> failed
> 
> Later on, when running mkimage for the u-boot.imx it will succeed in
> finding the IVT offset.
> 
> Looks like some race condition happening during parallel build when
> processing mkimage for u-boot-dtb.imx and u-boot.imx.
> 
> A proper fix still needs to be implemented, but as a workaround let's
> remove the error when the IVT offset is not found.

I think the real problem here is that the command to produce an imx
from a bin file:

%.imx: %.bin                          
        $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@

Creates, as part of the command, a temp file, imximage.cfg.cfgtmp.  If
two or more images are made, they both create temp files with the same
name.  The "CFGS" commands can run in parallel with each other and with
the "MKIMAGE" that uses the cfgtmp file they both produce.

Usual make practice would dictate that when creating intermediate
files, give them unique names, otherwise the operation can not be run
in parallel on different inputs.

I think the original idea was that all the imx image targets would
share a common cfgtmp file.  But this doesn't work since each imx image
is created via an independent submake.
diff mbox series

Patch

diff --git a/tools/imximage.c b/tools/imximage.c
index eb7e682..ed9d935 100644
--- a/tools/imximage.c
+++ b/tools/imximage.c
@@ -777,11 +777,6 @@  static uint32_t parse_cfg_file(struct imx_header *imxhdr, char *name)
 	(*set_dcd_rst)(imxhdr, dcd_len, name, lineno);
 	fclose(fd);
 
-	/* Exit if there is no BOOT_FROM field specifying the flash_offset */
-	if (imximage_ivt_offset == FLASH_OFFSET_UNDEFINED) {
-		fprintf(stderr, "Error: No BOOT_FROM tag in %s\n", name);
-		exit(EXIT_FAILURE);
-	}
 	return dcd_len;
 }