diff options
author | Roman Yeryomin <roman@advem.lv> | 2012-10-06 16:47:03 +0300 |
---|---|---|
committer | Roman Yeryomin <roman@advem.lv> | 2012-12-03 00:13:22 +0200 |
commit | 2f6bc72d25509b1c1c988619bb9ee31896d5fc10 (patch) | |
tree | 80f9a876ed8fa247d925e7764ca5336921399c96 /package/query3g/files | |
parent | 6cc390963c977be2e83118d37057d7a317926d9d (diff) |
add query3g package
Signed-off-by: Roman <roman@nomad.(none)>
Diffstat (limited to 'package/query3g/files')
-rw-r--r-- | package/query3g/files/query3g.gcom | 148 | ||||
-rw-r--r-- | package/query3g/files/query3g.sh | 42 |
2 files changed, 190 insertions, 0 deletions
diff --git a/package/query3g/files/query3g.gcom b/package/query3g/files/query3g.gcom new file mode 100644 index 000000000..f63207805 --- /dev/null +++ b/package/query3g/files/query3g.gcom @@ -0,0 +1,148 @@ +opengt + set com 115200n81 + set comecho off + set senddelay 0.02 + waitquiet 0.2 0.2 + + send "AT\^CURC=0^m" + waitfor 5 "OK","ERROR" + + let $c="AT+CPIN?^m" + let $r="+CPIN" + gosub readatcmd + + let $c="AT+CSQ^m" + let $r="+CSQ" + gosub readatcmd + + let $c="ATE1; +CGMI^m" + gosub readatcmdnr + let $v=$s + + if $toupper($mid($v,0,3)) = "ZTE" goto zte + if $toupper($mid($v,0,3)) = "OPT" goto option + if $toupper($mid($v,0,3)) = "SIE" goto sierra + if $toupper($mid($v,0,3)) = "NOV" goto novatel + if $toupper($mid($v,0,3)) = "HUA" goto huawei + if $toupper($mid($v,0,3)) = "VOD" goto vodafone + if $toupper($mid($v,0,3)) = "NOK" goto vodafone + goto generic + +:vodafone + let $c="AT%NWSTATE=1^m" + let $r="%NWSTATE" + gosub readatcmd + goto next + +:novatel + let $c="AT$CNTI=0^m" + let $r="$CNTI" + gosub readatcmd + goto next + +:sierra + let $c="AT*CNTI=0^m" + let $r="*CNTI" + gosub readatcmd + goto next + +:option + let $c="AT_OCTI?^m" + let $r="_OCTI" + gosub readatcmd + + let $c="AT_OWCTI?^m" + let $r="_OWCTI" + gosub readatcmd + goto next + +:zte + let $c="AT+COPS?^m" + let $r="+COPS" + gosub readatcmd + + let $c="AT+ZPAS?^m" + let $r="+ZPAS" + gosub readatcmd + goto next1 + +:huawei + let $c="AT\^SYSINFOEX^m" + let $r="\^SYSINFOEX" + gosub readatcmd + +:generic + let $c="AT\^SYSINFO^m" + let $r="\^SYSINFO" + gosub readatcmd + +:next + let $c="AT+COPS=3,2; +COPS?^m" + let $r="+COPS" + gosub readatcmd + +:next1 + let $c="AT+CREG=2; +CREG?^m" + let $r="+CREG" + gosub readatcmd + + let $c="AT+CGREG=2; +CGREG?^m" + let $r="+CGREG" + gosub readatcmd + + let $c="AT+CGEQNEG=1^m" + let $r="+CGEQNEG" + gosub readatcmd + + let $c="ATE1; +CGMM^m" + gosub readatcmdnr + print "\nDEVICE:",$v," ",$s,"\n" + + exit 0 + +:readatcmd + let i=5 + send $c +:loop + get 1 "^m" $s + let l=len($r) + if len($s) < l goto loop1 + if $mid($s,1,l) <> $r goto loop1 + print $s + return + +:loop1 + if len($s) < 2 goto loop2 + if $mid($s,1,2) = "ER" return + if $mid($s,1,2) = "CO" return +:loop2 + if i = 0 return + let i=i-1 + sleep 0.25 + goto loop + +:readatcmdnr + let i=10 + send $c +:loop3 + get 1 "^m" $s + if len($s) < 2 goto loop5 + if $mid($s,1,2) = "ER" goto loop4 + if $mid($s,1,2) = "OK" goto loop5 + if $mid($s,1,2) = "AT" goto loop5 + if $mid($s,1,2) = "TE" goto loop5 + if $mid($s,1,1) = "+" goto loop5 + if $mid($s,1,1) = "\^" goto loop5 + let l=len($s) + let $s=$mid($s,1,l) + return + +:loop4 + let $s="" + return + +:loop5 + if i = 0 return + let i=i-1 + sleep 0.25 + goto loop3 diff --git a/package/query3g/files/query3g.sh b/package/query3g/files/query3g.sh new file mode 100644 index 000000000..b591d61a3 --- /dev/null +++ b/package/query3g/files/query3g.sh @@ -0,0 +1,42 @@ +#!/bin/sh + +reset=/usr/bin/usbreset +comgt=/usr/bin/gcom +script=/usr/share/query3g.gcom + +last_reset="x" + +wan_proto="$(uci -q get network.wan.proto)" + +if [ "$wan_proto" = "3g" ]; then + ifdown wan +fi + +for port in 0 1 2 3 4 5 6 7 8 9; do + for tty in $(find /sys/devices/ -name "ttyUSB$port" -type d | sort -u); do + [ -f "$tty/../../idProduct" ] || continue + + local dir="$(cd "$tty/../.."; pwd)" + local uid="$(basename "$dir")" + local dev="/dev/$(basename "$tty")" + local vid="$(cat "$tty/../../idVendor")" + local pid="$(cat "$tty/../../idProduct")" + + if [ "$last_reset" != "$vid:$pid" ]; then + last_reset="$vid:$pid" + $reset "$vid:$pid" >/dev/null + + local try=0 + while [ $((try++)) -lt 5 ] && [ ! -e "$dev" ]; do sleep 1; done + fi + + if $comgt -s "$script" -d "$dev" 2>/dev/null; then + echo "PORT:$dev" + echo "VID:$vid" + echo "PID:$pid" + echo "UID:$uid" + exit 0 + fi + done +done +exit 1 |