Search Linux Wireless

Re: [PATCH] b43: remove rate index warning

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thursday 06 November 2008 17:20:24 Johannes Berg wrote:
> I frequently run into this warning, and added some
> debugging to see why, and got this:
> 
> b43 bad rx: 00000000: 2f d2 e2 63 cf a7 14 04 28 18 c8 5f 88 4a a2 00
>                       bogus junk       | plcp            | fctl| dur
> 
> b43 bad rx: 00000010: 00 11 24 91 07 4d 00 06 25 ff 8f 78 00 06 25 ff
>                       my MAC address   | BSSID           | AP MAC
> b43 bad rx: 00000020: 8f 76 20 74 00 00 42 07 00 20 00 00 00 00 aa aa
>                            | seq | QoS | CCMP IV               | data
>                       ...
> 
> As you can see, there are 6 bogus bytes (sometimes only five) and then
> the frame. I don't know why, and I don't see how to recover, so let's
> just drop these frames.
> 

I don't know why this happens, but I also see it on the opensource firmware.
It might probably be a DMA programming error of some kind. (or just a silicon bug).
But yeah, let's just drop them for now.

> Signed-off-by: Johannes Berg <johannes@xxxxxxxxxxxxxxxx>

Signed-off-by: Michael Buesch <mb@xxxxxxxxx>

> ---
>  drivers/net/wireless/b43/xmit.c |    4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> --- everything.orig/drivers/net/wireless/b43/xmit.c	2008-11-06 16:52:53.000000000 +0100
> +++ everything/drivers/net/wireless/b43/xmit.c	2008-11-06 17:10:06.000000000 +0100
> @@ -46,7 +46,6 @@ static int b43_plcp_get_bitrate_idx_cck(
>  	case 0x6E:
>  		return 3;
>  	}
> -	B43_WARN_ON(1);
>  	return -1;
>  }
>  
> @@ -73,7 +72,6 @@ static u8 b43_plcp_get_bitrate_idx_ofdm(
>  	case 0xC:
>  		return base + 7;
>  	}
> -	B43_WARN_ON(1);
>  	return -1;
>  }
>  
> @@ -608,6 +606,8 @@ void b43_rx(struct b43_wldev *dev, struc
>  						phytype == B43_PHYTYPE_A);
>  	else
>  		status.rate_idx = b43_plcp_get_bitrate_idx_cck(plcp);
> +	if (unlikely(status.rate_idx == -1))
> +		goto drop;
>  	status.antenna = !!(phystat0 & B43_RX_PHYST0_ANT);
>  
>  	/*
> 
> 
> 
> 



-- 
Greetings Michael.
--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux