diff options
| author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2011-10-27 20:29:00 +0000 | 
|---|---|---|
| committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2011-10-27 20:29:00 +0000 | 
| commit | 6f48b8ea556c7da4ed75cb95571c02582771fae2 (patch) | |
| tree | ecacc3c9263044b2b810a93fa37b329fc081c11b /package/comgt/files-netifd | |
| parent | 77f19a70c2dc891422a8bb5019a5fc2a1047246a (diff) | |
comgt: port 3g.sh to netifd
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@28634 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/comgt/files-netifd')
| -rw-r--r-- | package/comgt/files-netifd/3g.sh | 83 | ||||
| -rw-r--r-- | package/comgt/files-netifd/3g.usb | 33 | 
2 files changed, 116 insertions, 0 deletions
| diff --git a/package/comgt/files-netifd/3g.sh b/package/comgt/files-netifd/3g.sh new file mode 100644 index 000000000..cbf8bd1e6 --- /dev/null +++ b/package/comgt/files-netifd/3g.sh @@ -0,0 +1,83 @@ +#!/bin/sh +INCLUDE_ONLY=1 + +. ../netifd-proto.sh +. ./ppp.sh +init_proto "$@" + +proto_3g_init_config() { +	no_device=1 +	available=1 +	ppp_generic_init_config +	proto_config_add_string "device" +	proto_config_add_string "apn" +	proto_config_add_string "service" +	proto_config_add_int "pincode" +} + +proto_3g_setup() { +	local interface="$1" +	local chat + +	json_get_var device device +	json_get_var apn apn +	json_get_var service service +	json_get_var pincode pincode + +	[ -e "$device" ] || { +		proto_set_available "$interface" 0 +		return 1 +	} + +	case "$service" in +		cdma|evdo) +			chat="/etc/chatscripts/evdo.chat" +		;; +		*) +			chat="/etc/chatscripts/3g.chat" +			cardinfo=$(gcom -d "$device" -s /etc/gcom/getcardinfo.gcom) +			if echo "$cardinfo" | grep -q Novatel; then +				case "$service" in +					umts_only) CODE=2;; +					gprs_only) CODE=1;; +					*) CODE=0;; +				esac +				export MODE="AT\$NWRAT=${CODE},2" +			elif echo "$cardinfo" | grep -q Option; then +				case "$service" in +					umts_only) CODE=1;; +					gprs_only) CODE=0;; +					*) CODE=3;; +				esac +				export MODE="AT_OPSYS=${CODE}" +			fi + +			if [ -n "$pincode" ]; then +				PINCODE="$pincode" gcom -d "$device" -s /etc/gcom/setpin.gcom || { +					proto_notify_error "$interface" PIN_FAILED +					proto_block_restart "$interface" +					return 1 +				} +			fi +			[ -n "$MODE" ] && gcom -d "$device" -s /etc/gcom/setmode.gcom +		;; +	esac + +	connect="${apn:+USE_APN=$apn }/usr/sbin/chat -t5 -v -E -f $chat" +	ppp_generic_setup "$interface" \ +		noaccomp \ +		nopcomp \ +		novj \ +		nobsdcomp \ +		noauth \ +		lock \ +		crtscts \ +		115200 "$device" +	return 0 +} + +proto_3g_teardown() { +	proto_kill_command "$interface" +} + +add_protocol 3g diff --git a/package/comgt/files-netifd/3g.usb b/package/comgt/files-netifd/3g.usb new file mode 100644 index 000000000..d3859c257 --- /dev/null +++ b/package/comgt/files-netifd/3g.usb @@ -0,0 +1,33 @@ +#!/bin/sh +. /etc/functions.sh +. /lib/netifd/netifd-proto.sh + +find_3g_iface() { +	local cfg="$1" +	local tty="$2" + +	local proto +	config_get proto "$cfg" proto +	[ "$proto" = 3g ] || return 0 + +	local dev +	config_get dev "$cfg" device + +	if [ "${dev##*/}" = "${tty##*/}" ]; then +		if [ "$ACTION" = add ]; then +			available=1 +		else +			available=0 +		fi +		proto_set_available "$cfg" $available +	fi +} + +case "$DEVICENAME" in +	tty*) +		[ -e "/dev/$DEVICENAME" ] || [ "$ACTION" = remove ] || exit 0 +		config_load network +		config_foreach find_3g_iface interface "/dev/$DEVICENAME" +	;; +esac + | 
