[U-Boot] [RFC] arm926ejs: fix jump to RAM nand_boot

Wolfgang Denk wd at denx.de
Mon Nov 1 20:23:17 CET 2010


Dear Albert ARIBAUD,

In message <4CCEF2E4.5080003 at free.fr> you wrote:
>
> Also, I understand why the second RFC change I did was harmful to tx25. 
> Contrary to u-boot itself, u-boot-spl is not compiled to be position 
> independent; it actually loads at a given address then copies itself, 
> without relocating, to its home location.

It copies _itself_? Not the U-Boot payload?

Heiko, is this intentional?  Do we really first load the whole image,
then copy the U-Boot payload to some other address, then relocate it
to yet another one?


> I also think I might have found out what hit tx25.
> 
> include/configs/tx25 defines the size of u-boot which SPL will use to 
> load from NAND into RAM. currently it is defined thus:
> 
> #define CONFIG_SYS_NAND_U_BOOT_SIZE	0x30000

Arghh...

> Wolfgang, please try the following:
> 
> - on u-boot-testing, branch reloc_tests, revert commit 7fab02d... 
> (that's "arm926ejs: fix jump to RAM nand_boot") as this 'fix' is a mistake.
> 
> - in include/configs/tx25.h, increasing CONFIG_SYS_NAND_U_BOOT_SIZE to 
> 0x31000
> 
> Let me know if building tx25 after these two corrections makes things 
> better.

Bingo.

Both the ELDK and the CS compiled versions run fine now:

with ELDK:

U-Boot 2010.12-rc1-00030-g7fec359 (Nov 01 2010 - 20:13:53)

U-Boot code: 81200000 -> 81224E64  BSS: -> 8122DF68
CPU:   Freescale i.MX25 at 399 MHz

monitor len: 0002DF68
ramsize: 02000000
TLB table at: 81ff0000
Top of RAM usable for U-Boot at: 81ff0000
Reserving 183k for U-Boot at: 81fc2000
Reserving 1024k for malloc() at: 81ec2000
Reserving 24 Bytes for Board Info at: 81ec1fe8
Reserving 92 Bytes for Global Data at: 81ec1f8c
New Stack Pointer is: 81ec1f88
RAM Configuration:
Bank #0: 80000000 32 MiB
relocation Offset is: 00dc2000
monitor flash len: 00024E64
Now running in RAM - U-Boot at: 81fc2000
...

with CS:

U-Boot 2010.12-rc1-00030-g7fec359 (Nov 01 2010 - 20:18:09)

U-Boot code: 81200000 -> 812237E8  BSS: -> 8122C8F0
CPU:   Freescale i.MX25 at 399 MHz

monitor len: 0002C8F0
ramsize: 02000000
TLB table at: 81ff0000
Top of RAM usable for U-Boot at: 81ff0000
Reserving 178k for U-Boot at: 81fc3000
Reserving 1024k for malloc() at: 81ec3000
Reserving 24 Bytes for Board Info at: 81ec2fe8
Reserving 92 Bytes for Global Data at: 81ec2f8c
New Stack Pointer is: 81ec2f88
RAM Configuration:
Bank #0: 80000000 32 MiB
relocation Offset is: 00dc3000
monitor flash len: 000237E8
Now running in RAM - U-Boot at: 81fc3000
...


Note that the CS tool chain gives somewhat smaller code...

Thanks a lot!


Guess we should submit the temporary changes now as formal patches?

Best regards,

Wolfgang Denk

-- 
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
You go slow, be gentle. It's no one-way street -- you  know  how  you
feel and that's all. It's how the girl feels too. Don't press. If the
girl feels anything for you at all, you'll know.
	-- Kirk, "Charlie X", stardate 1535.8


More information about the U-Boot mailing list