summaryrefslogtreecommitdiffstats
path: root/package/madwifi/files/lib/wifi
diff options
context:
space:
mode:
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2009-12-19 22:19:19 +0000
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2009-12-19 22:19:19 +0000
commit013d58fbe3352de582575a22444f0c9f729fcdac (patch)
treee1fe72818ff78ecb22bceb6664d37ad2585be6cc /package/madwifi/files/lib/wifi
parentf87f98d0c5b344b0973990cc628caf4afab4f928 (diff)
madwifi: fix antenna selection for ubnt loco2/loco5
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@18853 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/madwifi/files/lib/wifi')
-rwxr-xr-xpackage/madwifi/files/lib/wifi/madwifi.sh50
1 files changed, 41 insertions, 9 deletions
diff --git a/package/madwifi/files/lib/wifi/madwifi.sh b/package/madwifi/files/lib/wifi/madwifi.sh
index b2bec7d25..29e9f3791 100755
--- a/package/madwifi/files/lib/wifi/madwifi.sh
+++ b/package/madwifi/files/lib/wifi/madwifi.sh
@@ -88,6 +88,7 @@ enable_atheros() {
config_get antrx "$device" rxantenna
config_get anttx "$device" txantenna
config_get_bool softled "$device" softled 1
+ config_get antenna "$device" antenna
devname="$(cat /proc/sys/dev/$device/dev_name)"
local antgpio=
@@ -96,6 +97,13 @@ enable_atheros() {
NanoStation2) antgpio=7; invert=1;;
NanoStation5) antgpio=1; invert=1;;
"NanoStation Loco2") antgpio=2;;
+ "NanoStation Loco5")
+ case "$antenna" in
+ horizontal) antdiv=0; anttx=1; antrx=1;;
+ vertical) antdiv=0; anttx=2; antrx=2;;
+ *) antdiv=1; anttx=0; antrx=0;;
+ esac
+ ;;
esac
if [ -n "$invert" ]; then
_set="clear"
@@ -106,21 +114,33 @@ enable_atheros() {
fi
if [ -n "$antgpio" ]; then
softled=0
- config_get antenna "$device" antenna
- case "$antenna" in
- external) antdiv=0; antrx=1; anttx=1 ;;
- horizontal) antdiv=0; antrx=1; anttx=1 ;;
- vertical) antdiv=0; antrx=2; anttx=2 ;;
- auto) antdiv=1; antrx=0; anttx=0 ;;
+ case "$devname" in
+ "NanoStation Loco2")
+ antdiv=0
+ antrx=1
+ anttx=1
+ case "$antenna" in
+ horizontal) gpioval=0;;
+ *) gpioval=1;;
+ esac
+ ;;
+ *)
+ case "$antenna" in
+ external) antdiv=0; antrx=1; anttx=1; gpioval=1;;
+ horizontal) antdiv=0; antrx=1; anttx=1; gpioval=0;;
+ vertical) antdiv=0; antrx=2; anttx=2; gpioval=0;;
+ auto) antdiv=1; antrx=0; anttx=0; gpioval=0;;
+ esac
+ ;;
esac
[ -x "$(which gpioctl 2>/dev/null)" ] || antenna=
gpioctl "dirout" "$antgpio" >/dev/null 2>&1
- case "$antenna" in
- horizontal|vertical|auto)
+ case "$gpioval" in
+ 0)
gpioctl "$_clear" "$antgpio" >/dev/null 2>&1
;;
- external)
+ 1)
gpioctl "$_set" "$antgpio" >/dev/null 2>&1
;;
esac
@@ -358,6 +378,18 @@ detect_atheros() {
config_get type "$dev" type
devname="$(cat /proc/sys/dev/$dev/dev_name)"
case "$devname" in
+ "NanoStation Loco2")
+ EXTRA_DEV="
+# Ubiquiti NanoStation Loco2 features
+ option antenna vertical # (horizontal|vertical)
+"
+ ;;
+ "NanoStation Loco5")
+ EXTRA_DEV="
+# Ubiquiti NanoStation Loco5 features
+ option antenna auto # (auto|horizontal|vertical)
+"
+ ;;
NanoStation*)
EXTRA_DEV="
# Ubiquiti NanoStation features