On 07/18/2013 04:48:58 AM, Zhang Ying-B40530 wrote:
-----Original Message-----
From: Wood Scott-B07421
Sent: Wednesday, July 17, 2013 2:07 AM
To: Zhang Ying-B40530
Cc: Wood Scott-B07421; u-boot@lists.denx.de; aflem...@gmail.com; Xie
Xiaobo-R63061
Subject: Re: [PATCH 6/7 v8] NAND: TPL : introduce the TPL based on
the SPL
On 07/16/2013 05:04:55 AM, Zhang Ying-B40530 wrote:
>
>
> -----Original Message-----
> From: Wood Scott-B07421
> Sent: Tuesday, July 16, 2013 7:56 AM
> To: Zhang Ying-B40530
> Cc: u-boot@lists.denx.de; aflem...@gmail.com; Xie Xiaobo-R63061;
> Zhang Ying-B40530
> Subject: Re: [PATCH 6/7 v8] NAND: TPL : introduce the TPL based on
> the SPL
>
> How about something like:
>
> # $@ is output, $(1) and $(2) are inputs, $(3) is padded
intermediate,
> $(4) is pad-to
> SPL_PAD_APPEND = \
> $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(4) -I binary -O
> binary \
> $(1) $(obj)$(3); \
> cat $(obj)$(3) $(obj)$(2) > $@; \
> rm $(obj)$(3)
>
> $(obj)u-boot-with-spl.bin: $(obj)spl/u-boot-spl.bin
> $(obj)tpl/u-boot-with-tpl.bin
> $(call
>
SPL_PAD_APPEND,$<,u-boot-with-tpl.bin,spl/u-boot-spl-pad.bin,$(CONFIG_SPL_PAD_TO))
>
> $(obj)u-boot-with-tpl.bin: $(obj)tpl/u-boot-tpl.bin $(obj)u-boot.bin
> $(call
>
SPL_PAD_APPEND,$<,u-boot.bin,tpl/u-boot-tpl-pad.bin,$(CONFIG_TPL_PAD_TO))
> [Zhang Ying]
> According to your advice, how to do for those don't have TPL?
They would use the rule for u-boot-with-spl.bin, and the TPL rule
would
be ignored. No ifdef needed.
[Zhang Ying]
But, Don't u-boot-with-spl.bin contain tpl/u-boot-with-tpl.bin in the
following rule?
$(obj)u-boot-with-spl.bin: $(obj)spl/u-boot-spl.bin
$(obj)tpl/u-boot-with-tpl.bin
$(call
SPL_PAD_APPEND,$<,u-boot-with-tpl.bin,spl/u-boot-spl-pad.bin,$(CONFIG_SPL_PAD_TO))
Oh, right -- replace that with a variable that says what the SPL
payload should be.
You're defining a function called "nand_load_image" ind
include/nand.h. There's nothing eLBC-specific about that. It is
entirely possible that another implementation will want to export that
function in an ordinary SPL -- or even possibly in the main U-Boot
image.
In fact, there's already a common definition for this, which is
nand_spl_load_image(). Use that.
[Zhang Ying]
There has a prolem:
nand_spl_simple.c: In function 'nand_init':
nand_spl_simple.c:265:2: error: too many arguments to function
'board_nand_init'
This because the functionality "board_nand_init" is called and
parameter is not null,
but board_nand_init prototype is declared to "void
board_nand_init(void)".
Whether board_nand_init() takes a parameter depends on whether
CONFIG_SYS_NAND_SELF_INIT is defined. Apparently nand_spl_simple.c
doesn't support CONFIG_SYS_NAND_SELF_INIT.
But I wasn't saying to use nand_spl_simple.c -- I was saying to use the
same function name and arguments for nand_spl_load_image(). This would
mean the caller of nand_spl_load_image() would be the same regardless
of whether nand_spl_simple.c or fsl_elbc_spl.c is used.
Note that fsl_ifc_spl.c also uses nand_spl_load_image().
-Scott
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot