summaryrefslogtreecommitdiffstats
path: root/package/comgt/files-old/3g.sh
diff options
context:
space:
mode:
Diffstat (limited to 'package/comgt/files-old/3g.sh')
-rw-r--r--package/comgt/files-old/3g.sh119
1 files changed, 119 insertions, 0 deletions
diff --git a/package/comgt/files-old/3g.sh b/package/comgt/files-old/3g.sh
new file mode 100644
index 000000000..616beec4c
--- /dev/null
+++ b/package/comgt/files-old/3g.sh
@@ -0,0 +1,119 @@
+set_3g_led() {
+ # set on WRT54G3G only
+ [ -f /proc/diag/model ] || return 0
+ grep -q "WRT54G3G" /proc/diag/model >/dev/null || return 0
+ echo "$1" > /proc/diag/led/3g_green
+ echo "$2" > /proc/diag/led/3g_blue
+ grep -q "WRT54G3G$" /proc/diag/model >/dev/null || return 0
+ echo "$3" > /proc/diag/led/3g_blink
+}
+
+scan_3g() {
+ local device
+ config_get device "$1" device
+
+ # try to figure out the device if it's invalid
+ [ -n "$device" -a -e "$device" ] || {
+ for device in /dev/ttyUSB0 /dev/ttyUSB1 /dev/ttyUSB2 /dev/tts/2 /dev/usb/tts/0 /dev/noz0; do
+ [ -e "$device" ] && {
+ config_set "$1" device "$device"
+ break
+ }
+ done
+ }
+
+ # enable 3G with the 3G button by default
+ local button
+ config_get button "$1" button
+ [ -z "$button" ] && {
+ config_set "$1" button 1
+ }
+}
+
+stop_interface_3g() {
+ stop_interface_ppp "$1"
+ set_3g_led 0 0 0
+ killall gcom >/dev/null 2>/dev/null
+}
+
+setup_interface_3g() {
+ local iface="$1"
+ local config="$2"
+ local chat="/etc/chatscripts/3g.chat"
+
+ local device
+ config_get device "$config" device
+
+ local maxwait
+ config_get maxwait "$config" maxwait
+ maxwait=${maxwait:-20}
+ while [ ! -e "$device" -a $maxwait -gt 0 ];do # wait for driver loading to catch up
+ maxwait=$(($maxwait - 1))
+ sleep 1
+ done
+
+ for module in slhc ppp_generic ppp_async; do
+ /sbin/insmod $module 2>&- >&-
+ done
+
+ local apn
+ config_get apn "$config" apn
+
+ local service
+ config_get service "$config" service
+
+ local pincode
+ config_get pincode "$config" pincode
+
+ local mtu
+ config_get mtu "$config" mtu
+
+ set_3g_led 1 0 1
+
+ # figure out hardware specific commands for the card
+ case "$service" in
+ cdma|evdo) chat="/etc/chatscripts/evdo.chat";;
+ *)
+ cardinfo=$(gcom -d "$device" -s /etc/gcom/getcardinfo.gcom)
+ if echo "$cardinfo" | grep Novatel; then
+ case "$service" in
+ umts_only) CODE=2;;
+ gprs_only) CODE=1;;
+ *) CODE=0;;
+ esac
+ mode="AT\$NWRAT=${CODE},2"
+ elif echo "$cardinfo" | grep Option; then
+ case "$service" in
+ umts_only) CODE=1;;
+ gprs_only) CODE=0;;
+ *) CODE=3;;
+ esac
+ mode="AT_OPSYS=${CODE}"
+ fi
+ # Don't assume Option to be default as it breaks with Huawei Cards/Sticks
+
+ test -z "$pincode" || {
+ PINCODE="$pincode" gcom -d "$device" -s /etc/gcom/setpin.gcom || {
+ echo "$config(3g): Failed to set the PIN code."
+ set_3g_led 0 0 0
+ return 1
+ }
+ }
+ test -z "$mode" || {
+ MODE="$mode" gcom -d "$device" -s /etc/gcom/setmode.gcom
+ }
+ esac
+ set_3g_led 1 0 0
+
+ config_set "$config" "connect" "${apn:+USE_APN=$apn }/usr/sbin/chat -t5 -v -E -f $chat"
+ start_pppd "$config" \
+ noaccomp \
+ nopcomp \
+ novj \
+ nobsdcomp \
+ noauth \
+ lock \
+ crtscts \
+ ${mtu:+mtu $mtu mru $mtu} \
+ 115200 "$device"
+}