From 60d9f8044c383a6cedac2bafae85e28677cd889f Mon Sep 17 00:00:00 2001
From: Felix Fietkau <nbd@openwrt.org>
Date: Sun, 11 Oct 2009 01:01:12 +0000
Subject: [PATCH] mac80211: fix autochannel / fixed channel selection, add
 commands for unencrypted sta mode

SVN-Revision: 18024
---
 package/mac80211/files/lib/wifi/mac80211.sh | 21 ++++++++++++++-------
 1 file changed, 14 insertions(+), 7 deletions(-)

diff --git a/package/mac80211/files/lib/wifi/mac80211.sh b/package/mac80211/files/lib/wifi/mac80211.sh
index 1a8272aca8..c11da4279b 100644
--- a/package/mac80211/files/lib/wifi/mac80211.sh
+++ b/package/mac80211/files/lib/wifi/mac80211.sh
@@ -68,8 +68,8 @@ disable_mac80211() (
 )
 get_freq() {
 	local phy="$1"
-	local channel="$2"
-	iw "$phy" info | grep -E -m1 "(\* ${channel:-....} MHz${channel:+|\\[$channel\\]})" | grep MHz | awk '{print $2}'
+	local chan="$2"
+	iw "$phy" info | grep -E -m1 "(\* ${chan:-....} MHz${chan:+|\\[$chan\\]})" | grep MHz | awk '{print $2}'
 }
 enable_mac80211() {
 	local device="$1"
@@ -79,9 +79,15 @@ enable_mac80211() {
 	find_mac80211_phy "$device" || return 0
 	config_get phy "$device" phy
 	local i=0
+	fixed=""
 
+	[ "$channel" = "auto" -o "$channel" = "0" ] || {
+		fixed=1
+	}
+
+	export channel fixed
 	# convert channel to frequency
-	local freq="$(get_freq "$phy" "$channel")"
+	local freq="$(get_freq "$phy" "${fixed:+$channel}")"
 
 	wifi_fixup_hwmode "$device" "g"
 	for vif in $vifs; do
@@ -141,7 +147,7 @@ enable_mac80211() {
 
 		# We attempt to set teh channel for all interfaces, although
 		# mac80211 may not support it or the driver might not yet
-		[ -z "$channel" ] || iw dev "$ifname" set channel "$channel" 
+		[ -n "$fixed" ] && iw dev "$ifname" set channel "$channel"
 
 		local key keystring
 
@@ -222,12 +228,13 @@ enable_mac80211() {
 			;;
 			adhoc)
 				config_get bssid "$vif" bssid
-				iw dev "$ifname" ibss join "$ssid" ${freq:+$freq fixed-freq} $bssid
+				iw dev "$ifname" ibss join "$ssid" $freq ${fixed:+fixed-freq} $bssid
 			;;
 			sta|mesh)
-				# Fixup... sometimes you have to scan to get beaconing going
-				iw dev "$ifname" scan &> /dev/null
 				case "$enc" in												 
+					*)
+						iw dev "$ifname" connect "$ssid"
+					;;
 					wep)
 						if [ -e "$keymgmt" ]; then
 							[ -n "$keystring" ] &&
-- 
2.30.2