diff options
author | Felix Fietkau <nbd@openwrt.org> | 2011-10-27 20:29:10 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2011-10-27 20:29:10 +0000 |
commit | f964407745d464e18b101a75fe72dd7bf3c48fcb (patch) | |
tree | 9c6758474beaa0db71cb4f0a4ba560c800c4c45e /package/comgt | |
parent | c096dc0413bca75c86bf6550f3bc2a7c762b32e7 (diff) | |
download | upstream-f964407745d464e18b101a75fe72dd7bf3c48fcb.tar.gz upstream-f964407745d464e18b101a75fe72dd7bf3c48fcb.tar.bz2 upstream-f964407745d464e18b101a75fe72dd7bf3c48fcb.zip |
comgt: delay 3g bringup for sierra wireless cards until the card has locked on to the carrier, this helps with avoiding firmware hangs (thx, chris)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@28636 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/comgt')
-rw-r--r-- | package/comgt/Makefile | 1 | ||||
-rw-r--r-- | package/comgt/files-netifd/3g.sh | 7 |
2 files changed, 8 insertions, 0 deletions
diff --git a/package/comgt/Makefile b/package/comgt/Makefile index c071c8ca19..d853276a45 100644 --- a/package/comgt/Makefile +++ b/package/comgt/Makefile @@ -73,6 +73,7 @@ define Package/comgt/install $(INSTALL_DATA) ./files/setmode.gcom $(1)/etc/gcom/setmode.gcom $(INSTALL_DATA) ./files/getcardinfo.gcom $(1)/etc/gcom/getcardinfo.gcom $(INSTALL_DATA) ./files/getstrength.gcom $(1)/etc/gcom/getstrength.gcom + $(INSTALL_DATA) ./files/getcarrier.gcom $(1)/etc/gcom/getcarrier.gcom $(INSTALL_DIR) $(1)/etc/hotplug.d/tty $(INSTALL_DATA) $(FILES_DIR)/3g.usb $(1)/etc/hotplug.d/tty/30-3g $(Package/comgt/install/$(COMGT_VARIANT)) diff --git a/package/comgt/files-netifd/3g.sh b/package/comgt/files-netifd/3g.sh index cbf8bd1e66..cf96435a85 100644 --- a/package/comgt/files-netifd/3g.sh +++ b/package/comgt/files-netifd/3g.sh @@ -50,6 +50,8 @@ proto_3g_setup() { *) CODE=3;; esac export MODE="AT_OPSYS=${CODE}" + elif echo "$cardinfo" | grep -q "Sierra Wireless"; then + SIERRA=1 fi if [ -n "$pincode" ]; then @@ -60,6 +62,11 @@ proto_3g_setup() { } fi [ -n "$MODE" ] && gcom -d "$device" -s /etc/gcom/setmode.gcom + + # wait for carrier to avoid firmware stability bugs + [ -n "$SIERRA" ] && { + gcom -d "$device" -s /etc/gcom/getcarrier.gcom || return 1 + } ;; esac |