diff options
author | Travis Kemen <thepeople@openwrt.org> | 2008-10-23 03:09:33 +0000 |
---|---|---|
committer | Travis Kemen <thepeople@openwrt.org> | 2008-10-23 03:09:33 +0000 |
commit | 5506db71c3c78936a7ac47a7d500751377a2a36c (patch) | |
tree | dc0112840de2723d391804dbf7726ac91a8b6870 /package | |
parent | 6d6878bb10e3b54af25178ec45c8d4e6bab159e7 (diff) | |
download | upstream-5506db71c3c78936a7ac47a7d500751377a2a36c.tar.gz upstream-5506db71c3c78936a7ac47a7d500751377a2a36c.tar.bz2 upstream-5506db71c3c78936a7ac47a7d500751377a2a36c.zip |
Simplify antenna selection and remove the need for gpioctl for the nanostation2.
SVN-Revision: 13032
Diffstat (limited to 'package')
-rwxr-xr-x | package/madwifi/files/lib/wifi/madwifi.sh | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/package/madwifi/files/lib/wifi/madwifi.sh b/package/madwifi/files/lib/wifi/madwifi.sh index 379ec0747b..4bb5be569e 100755 --- a/package/madwifi/files/lib/wifi/madwifi.sh +++ b/package/madwifi/files/lib/wifi/madwifi.sh @@ -177,34 +177,41 @@ enable_atheros() { config_get antrx "$device" rxantenna config_get anttx "$device" txantenna config_get_bool softled "$device" softled 1 + config_get_bool gpioctl "$device" gpioctl devname="$(cat /proc/sys/dev/$device/dev_name)" antgpio= case "$devname" in - NanoStation2) antgpio=7;; + NanoStation2) antgpio=wifi; [ -n "$gpioctl" ] && gpioctl=0;; NanoStation5) antgpio=1;; esac if [ -n "$antgpio" ]; then softled=0 - config_get polarity "$device" polarity - case "$polarity" in + 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 ;; esac - config_get antenna "$device" antenna + [ -x "$(which gpioctl 2>/dev/null)" ] || antenna= case "$antenna" in - internal) - gpioctl "dirout" "$antgpio" >/dev/null 2>&1 - gpioctl "set" "$antgpio" >/dev/null 2>&1 + horizontal|vertical|auto) + if [ "$gpioctl" = "0" ]; then + echo 0 >/sys/class/leds/$antgpio/brightness 2>&1 + else + gpioctl "dirout" "$antgpio" >/dev/null 2>&1 + gpioctl "set" "$antgpio" >/dev/null 2>&1 + fi ;; external) - gpioctl "dirout" "$antgpio" >/dev/null 2>&1 - gpioctl "clear" "$antgpio" >/dev/null 2>&1 - antdiv=0 - antrx=1 - anttx=1 + if [ "$gpioctl" = "0" ]; then + echo 0 >/sys/class/leds/$antgpio/brightness + else + gpioctl "dirout" "$antgpio" >/dev/null 2>&1 + gpioctl "clear" "$antgpio" >/dev/null 2>&1 + fi ;; esac fi |