broadcom-wl: fix band reporting
Modify the band reporting for broadcom devices to correctly report HW capability. Currently, 802.11na devices report "bgn"; but should be reporting "an". Signed-off-by: Nathan Hintz <nlhintz@hotmail.com> SVN-Revision: 38749
This commit is contained in:
		| @@ -0,0 +1,41 @@ | |||||||
|  | --- a/driver/wl_iw.c | ||||||
|  | +++ b/driver/wl_iw.c | ||||||
|  | @@ -314,7 +314,7 @@ | ||||||
|  |  ) | ||||||
|  |  { | ||||||
|  |  	int phytype, err; | ||||||
|  | -	uint band[3]; | ||||||
|  | +	uint i, band[3], bands; | ||||||
|  |  	char cap[5]; | ||||||
|  |   | ||||||
|  |  	WL_TRACE(("%s: SIOCGIWNAME\n", dev->name)); | ||||||
|  | @@ -335,16 +335,20 @@ | ||||||
|  |  			break; | ||||||
|  |  		case WLC_PHY_TYPE_LP: | ||||||
|  |  		case WLC_PHY_TYPE_G: | ||||||
|  | -			if (band[0] >= 2) | ||||||
|  | -				strcpy(cap, "abg"); | ||||||
|  | -			else | ||||||
|  | -				strcpy(cap, "bg"); | ||||||
|  | -			break; | ||||||
|  |  		case WLC_PHY_TYPE_N: | ||||||
|  | -			if (band[0] >= 2) | ||||||
|  | -				strcpy(cap, "abgn"); | ||||||
|  | -			else | ||||||
|  | -				strcpy(cap, "bgn"); | ||||||
|  | +			bands = 0; | ||||||
|  | +			for (i = 1; i <= band[0]; i++) { | ||||||
|  | +				bands |= dtoh32(band[i]); | ||||||
|  | +			} | ||||||
|  | +			strcpy(cap, ""); | ||||||
|  | +			if (bands & WLC_BAND_5G) | ||||||
|  | +				strcat(cap, "a"); | ||||||
|  | +			if (bands & WLC_BAND_2G) | ||||||
|  | +				strcat(cap, "bg"); | ||||||
|  | +			if (phytype == WLC_PHY_TYPE_N) | ||||||
|  | +				strcat(cap, "n"); | ||||||
|  | +			break; | ||||||
|  | +		default: | ||||||
|  |  			break; | ||||||
|  |  	} | ||||||
|  |  done: | ||||||
		Reference in New Issue
	
	Block a user
	 Hauke Mehrtens
					Hauke Mehrtens