diff options
author | Felix Fietkau <nbd@openwrt.org> | 2009-12-19 22:19:19 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2009-12-19 22:19:19 +0000 |
commit | da80071315d3fd2dd612a5ba3c31ba8bce1f8bb5 (patch) | |
tree | 283ef747c3b58b5ed3ca260a9220d906715811ae /package | |
parent | 6a2c27b4e81f8dca7cc1d8cb6990dd8f815aefad (diff) | |
download | upstream-da80071315d3fd2dd612a5ba3c31ba8bce1f8bb5.tar.gz upstream-da80071315d3fd2dd612a5ba3c31ba8bce1f8bb5.tar.bz2 upstream-da80071315d3fd2dd612a5ba3c31ba8bce1f8bb5.zip |
madwifi: fix antenna selection for ubnt loco2/loco5
SVN-Revision: 18853
Diffstat (limited to 'package')
-rwxr-xr-x | package/madwifi/files/lib/wifi/madwifi.sh | 50 |
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 b2bec7d25c..29e9f37918 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 |