summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTravis Kemen <thepeople@openwrt.org>2008-10-23 03:09:33 +0000
committerTravis Kemen <thepeople@openwrt.org>2008-10-23 03:09:33 +0000
commit5506db71c3c78936a7ac47a7d500751377a2a36c (patch)
treedc0112840de2723d391804dbf7726ac91a8b6870
parent6d6878bb10e3b54af25178ec45c8d4e6bab159e7 (diff)
downloadmtk-20170518-5506db71c3c78936a7ac47a7d500751377a2a36c.zip
mtk-20170518-5506db71c3c78936a7ac47a7d500751377a2a36c.tar.gz
mtk-20170518-5506db71c3c78936a7ac47a7d500751377a2a36c.tar.bz2
Simplify antenna selection and remove the need for gpioctl for the nanostation2.
SVN-Revision: 13032
-rwxr-xr-xpackage/madwifi/files/lib/wifi/madwifi.sh31
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 379ec07..4bb5be5 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