[U-Boot-Users] Antw: Re: Cannot boot reliably vxWorks on PPC44x

Niklaus Giger Niklaus.Giger at netstal.com
Wed Apr 4 15:30:24 CEST 2007



>>> Stefan Roese<sr at denx.de> 04.04.07 15:19:53 >>>
>Hi Niklaus,
>
>On Friday 02 March 2007 16:26, Niklaus Giger wrote:
>> BTW, the boot cmd of vxWorks expects a parameter, therefore I think
>> it would make sense to apply a patch like
>> diff --git a/common/cmd_elf.c b/common/cmd_elf.c
>> old mode 100644
>> new mode 100755
>> index 0e3d56f..dc4eb27
>> --- a/common/cmd_elf.c
>> +++ b/common/cmd_elf.c
>> @@ -213,7 +213,7 @@ int do_bootvx (cmd_tbl_t *cmdtp, int flag, int argc,
>> char *argv[])
>>                         (char *) bootaddr);
>>         printf ("## Starting vxWorks at 0x%08lx ...\n", addr);
>>
>> -       ((void (*)(void)) addr) ();
>> +       ((void (*)(int)) addr) (2); /* 0 => BOOT_NORMAL 2=> BOOT_CLEAR */
>>
>>         puts ("## vxWorks terminated\n");
>>         return 1;
>
>Are you sure that this parameter is supported. A quick "googling" only showed 
>this parameter in the VxWorks function reboot(), and I don't think this is 
>the entry point of the VxWorks image.
It is also used by the function void usrInit (int startType) and gets passed
afterward to various init functions, e.g. usrBootLineInit. My board specific
code tested its value, which made me discover this bug.

Best regards

Niklaus






More information about the U-Boot mailing list