[U-Boot-Users] [PATCH] net/eth.c: Fix env_enetaddr signed overflow

Ben Warren bwarren at qstreams.com
Mon Nov 19 16:15:50 CET 2007


Shinya Kuribayashi wrote:
> My colleague founded this problem months ago. I'd like to see this bug
> fixed in 1.3.0. Please apply.
>
> ---
> net/eth.c: Fix env_enetaddr signed overflow
>
> Assigning the output of simple_strtoul(CB:A9:87:65:43:21) to `char', we are
> warned as below:
>
>   U-Boot 1.2.0 (Aug 30 2007 - 08:27:37)
>   
>   DRAM:  256 MB
>   Flash: 32 MB
>   In:    serial
>   Out:   serial
>   Err:   serial
>   Net:   NEC-Candy
>   Warning: NEC-Candy MAC addresses don't match:
>   Address in SROM is         00:00:4C:80:92:A2
>   Address in environment is  FFFFFFCB:FFFFFFA9:FFFFFF87:65:43:21
>
> This patch changes env_enetaddr type from `char' to `unsigned char'.
>
> Cc: Masaki Ishikawa <ishikawa-masaki at cnt.mxe.nes.nec.co.jp>
> Signed-off-by: Shinya Kuribayashi <shinya.kuribayashi at necel.com>
> ---
>
>  net/eth.c |    3 ++-
>  1 files changed, 2 insertions(+), 1 deletions(-)
>
> diff --git a/net/eth.c b/net/eth.c
> index 1b56a35..64ef312 100644
> --- a/net/eth.c
> +++ b/net/eth.c
> @@ -138,7 +138,8 @@ int eth_register(struct eth_device* dev)
>  
>  int eth_initialize(bd_t *bis)
>  {
> -	char enetvar[32], env_enetaddr[6];
> +	char enetvar[32];
> +	unsigned char env_enetaddr[6];
>  	int i, eth_number = 0;
>  	char *tmp, *end;
>  
>
>   
This looks harmless enough, but is in a place that is touched by every 
board on every architecture, and the bug doesn't really seem to hurt 
anything other than printing garbage. IMHO it should wait until the next 
release. I will apply it to a 'for_1.3.1' branch of the net tree.

regards,
Ben




More information about the U-Boot mailing list