[U-Boot-Users] [PATCH v3] Fix initrd length miscalculation in bootm command when using a dtu

Jerry Van Baren gerald.vanbaren at smiths-aerospace.com
Fri May 4 16:22:09 CEST 2007


Stefan Roese wrote:
> Hi Timur,
> 
> On Friday 04 May 2007 15:25, Timur Tabi wrote:
>> I'm glad you fixed the bug, so I'll just add a few comments:
>>> Your comment is actually wrong. The use of "len" is not limited to
>>> that purpose.
>> If you apply my patch, then the comment becomes correct.  My goal was to
>> lock the variables 'len' and 'data' into one purpose.  The reason the
>> bug existed is because the other developer didn't realize this.  He used
>> 'len' thinking it was available.  In a sense, I was trying to implement
>> some "defensive programming", so that the next time someone hacks up
>> do_bootm_linux(), he won't re-introduce the bug.
>>
>> Now, you might say that that won't happen again, but I disagree.  I
>> think it can, for two reasons:
>>
>> 1) It happened once already, last year.  You approved and applied a
>> patch which does overwrite the variable.
>>
>> 2) The libfdt code introduced a number of other bugs relating to dtu
>> usage, which have not yet been fixed.
>>
>> So I believe there is a real possibility that another patch could
>> re-introduce this bug.  If you had applied my patch as-is, that
>> possibility would have been eliminated.  This is why I think my patch is
>> better than yours.
>>
>> But I guess only time will tell who's right. :-)
> 
> You have a point with your variable usage "restriction", and Wolfgang has a 
> point with the "readability" of your patch as it doesn't really tell what is 
> fixed without read the current source. Could be that your implementation is 
> the "better" one, but the patch Wolfgang applied was just less intrusive. 
> 
>>> And please accept my apologies thatt his was so complicated and  took
>>> so  long.  [Nevertheless you still might want to try to find a way to
>>> access the repository I  created  for  you  in  case  you  have  more
>>> patches.]
>> Stefan said he had a testing repo of some kind.  How about we just use
>> that?  If Stefan is willing, he can apply my emailed patches to his repo.
> 
> No, we shouldn't "fork" the code here. Let's focus on the other open issues. 
> You mention other bugs introduced by the libfdt code above. ;-)
> 
> Best regards,
> Stefan

Timur has sent me two libfdt/dtu-related fixes
* fdt_copy_into() had the source and destination addresses reversed
* fdt_check_header() had the wrong sense on ==/!= 0
which I applied to my local repo last night and will push back to 
u-boot-fdt soon (I still have not been successful in figuring out how to 
make a multi-image to test the changes grrrr).  The two bugs I 
introduced in the conversion to libfdt were unrelated to the "len" 
variable, but I probably replicated the "len" bug when I duplicated and 
modified the original code.  I will pull Wolfgang's fix tonight and see 
what needs to be done to make all three bugs go away.

WRT to building a multi-image, I'm looking to combine linux, a dtb, and 
an initrd into a single image to test that path of bootm (the path I had 
the above screwups in).

Timur's hint for me was:
> mkimage -A ppc -T flat_dt -C none -d mpc836x_mds.dtb mpc836x_mds.dtu
> 
> This, of course, creates a dtu with a value of 0 for ih_load.  You
> probably need to specify -a or -e to set that field.
but I don't understand how to build an image with all three pieces in it 
(I tried to use the ":" in the -d source parameter and mkimage just got 
confused, couldn't find the files).  Am I expecting too much???  Should 
I just be wrapping the three pieces individually and loading them 
separately?  What exactly are you doing to test this, Timur?

Best regards,
gvb




More information about the U-Boot mailing list