Hi Matti i noticed that you remove the ipv6 option/support and this is not mentioned in the commit message. could you elaborate on that one ?
John On 06/12/2016 17:52, Matti Laakso wrote: > Add support for specifying a call profile index instead of APN. A > specific index different from 1 must be used for some service > provider and modem combinations. > > In addition, change the manufacturer detection to use the standard > AT+CGMI command, which produces more predictable output than ATI, > and remove the redundant ipv6 option, since it is more customary > to specify the PDP context type with mobile connections. > > Signed-off-by: Matti Laakso <malaa...@elisanet.fi> > --- > package/network/utils/comgt/Makefile | 2 +- > package/network/utils/comgt/files/getcardinfo.gcom | 2 +- > package/network/utils/comgt/files/ncm.json | 26 ++++----- > package/network/utils/comgt/files/ncm.sh | 65 > ++++++++++------------ > 4 files changed, 44 insertions(+), 51 deletions(-) > > diff --git a/package/network/utils/comgt/Makefile > b/package/network/utils/comgt/Makefile > index 9d99d64..4b6e6ea 100644 > --- a/package/network/utils/comgt/Makefile > +++ b/package/network/utils/comgt/Makefile > @@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk > > PKG_NAME:=comgt > PKG_VERSION:=0.32 > -PKG_RELEASE:=27 > +PKG_RELEASE:=28 > > PKG_SOURCE:=$(PKG_NAME).$(PKG_VERSION).tgz > PKG_SOURCE_URL:=@SF/comgt > diff --git a/package/network/utils/comgt/files/getcardinfo.gcom > b/package/network/utils/comgt/files/getcardinfo.gcom > index 5c69a64..f91665f 100644 > --- a/package/network/utils/comgt/files/getcardinfo.gcom > +++ b/package/network/utils/comgt/files/getcardinfo.gcom > @@ -6,7 +6,7 @@ opengt > flash 0.1 > > :start > - send "ATI^m" > + send "AT+CGMI^m" > get 1 "" $s > print $s > > diff --git a/package/network/utils/comgt/files/ncm.json > b/package/network/utils/comgt/files/ncm.json > index d1f8699..8f74e17 100644 > --- a/package/network/utils/comgt/files/ncm.json > +++ b/package/network/utils/comgt/files/ncm.json > @@ -7,7 +7,7 @@ > "ATV1", > "ATE1", > "ATS0=0", > - "AT+CGDCONT=1,\\\"${pdptype}\\\",\\\"${apn}\\\"" > + > "AT+CGDCONT=${profile},\\\"${pdptype}\\\"${apn:+,\\\"$apn\\\"}" > ], > "modes": { > "preferlte": > "AT^SYSCFGEX=\\\"030201\\\",3fffffff,2,4,7fffffffffffffff,,", > @@ -17,8 +17,8 @@ > "gsm": > "AT^SYSCFGEX=\\\"01\\\",3fffffff,2,4,7fffffffffffffff,,", > "auto": > "AT^SYSCFGEX=\\\"00\\\",3fffffff,2,4,7fffffffffffffff,," > }, > - "connect": > "AT^NDISDUP=1,1,\\\"${apn}\\\"${username:+,\\\"$username\\\"}${password:+,\\\"$password\\\"}${auth:+,$auth}", > - "disconnect": "AT^NDISDUP=1,0" > + "connect": > "AT^NDISDUP=${profile},1${apn:+,\\\"$apn\\\"}${username:+,\\\"$username\\\"}${password:+,\\\"$password\\\"}${auth:+,$auth}", > + "disconnect": "AT^NDISDUP=${profile},0" > }, > "samsung": { > "initialize": [ > @@ -26,7 +26,7 @@ > "AT+CGREG=2", > "AT+CFUN=5", > "AT+MODESELECT=3", > - "AT+CGDCONT=1,\\\"${pdptype}\\\",\\\"${apn}\\\"" > + > "AT+CGDCONT=${profile},\\\"${pdptype}\\\"${apn:+,\\\"$apn\\\"}" > ], > "modes": { > "umts": "AT+CHANGEALLPATH=1" > @@ -34,11 +34,11 @@ > "connect": "AT+CGATT=1", > "disconnect": "AT+CGATT=0" > }, > - "sierra wireless, incorporated": { > + "sierra": { > "initialize": [ > "AT+CFUN=1", > - "AT+CGDCONT=1,\\\"${pdptype}\\\",\\\"${apn}\\\"", > - > "AT$QCPDPP=1${auth:+,$auth}${password:+,\\\"$password\\\"}${username:+,\\\"$username\\\"}" > + > "AT+CGDCONT=${profile},\\\"${pdptype}\\\"${apn:+,\\\"$apn\\\"}", > + > "AT$QCPDPP=${profile},${auth:-0}${password:+,\\\"$password\\\"}${username:+,\\\"$username\\\"}" > ], > "modes": { > "preferlte": "AT!SELRAT=07", > @@ -48,20 +48,20 @@ > "gsm": "AT!SELRAT=02", > "auto": "AT!SELRAT=00" > }, > - "connect": "AT!SCACT=1,1", > - "disconnect": "AT!SCACT=0,1" > + "connect": "AT!SCACT=1,${profile}", > + "disconnect": "AT!SCACT=0,${profile}" > }, > - "sony ericsson": { > + "sony": { > "initialize": [ > "AT+CFUN=1", > - "AT+CGDCONT=1,\\\"${pdptype}\\\",\\\"${apn}\\\"", > - > "AT*EIAAUW=1,1,\\\"${username}\\\",\\\"${password}\\\",${auth:-00111}" > + > "AT+CGDCONT=${profile},\\\"${pdptype}\\\"${apn:+,\\\"$apn\\\"}", > + > "AT*EIAAUW=${profile},1,\\\"${username}\\\",\\\"${password}\\\",${auth:-00111}" > ], > "modes": { > "umts": "AT+CFUN=6", > "gsm": "AT+CFUN=5" > }, > - "connect": "AT*ENAP=1,1", > + "connect": "AT*ENAP=1,${profile}", > "disconnect": "AT*ENAP=0" > } > } > diff --git a/package/network/utils/comgt/files/ncm.sh > b/package/network/utils/comgt/files/ncm.sh > index 14b6347..df60fe8 100644 > --- a/package/network/utils/comgt/files/ncm.sh > +++ b/package/network/utils/comgt/files/ncm.sh > @@ -18,7 +18,7 @@ proto_ncm_init_config() { > proto_config_add_string delay > proto_config_add_string mode > proto_config_add_string pdptype > - proto_config_add_boolean ipv6 > + proto_config_add_int profile > proto_config_add_defaults > } > > @@ -27,22 +27,15 @@ proto_ncm_setup() { > > local manufacturer initialize setmode connect ifname devname devpath > > - local device apn auth username password pincode delay mode pdptype ipv6 > $PROTO_DEFAULT_OPTIONS > - json_get_vars device apn auth username password pincode delay mode > pdptype ipv6 $PROTO_DEFAULT_OPTIONS > - > - if [ "$ipv6" = 0 ]; then > - ipv6="" > - else > - ipv6=1 > - fi > - > - [ -z "$pdptype" ] && { > - if [ -n "$ipv6" ]; then > - pdptype="IPV4V6" > - else > - pdptype="IP" > - fi > - } > + local device apn auth username password pincode delay mode pdptype > profile $PROTO_DEFAULT_OPTIONS > + json_get_vars device apn auth username password pincode delay mode > pdptype profile $PROTO_DEFAULT_OPTIONS > + > + [ "$metric" = "" ] && metric="0" > + > + [ -n "$profile" ] || profile=1 > + > + pdptype=`echo "$pdptype" | awk '{print toupper($0)}'` > + [ "$pdptype" = "IP" -o "$pdptype" = "IPV6" -o "$pdptype" = "IPV4V6" ] > || $pdptype="IP" > > [ -n "$ctl_device" ] && device=$ctl_device > > @@ -57,11 +50,6 @@ proto_ncm_setup() { > proto_set_available "$interface" 0 > return 1 > } > - [ -n "$apn" ] || { > - echo "No APN specified" > - proto_notify_error "$interface" NO_APN > - return 1 > - } > > devname="$(basename "$device")" > case "$devname" in > @@ -83,7 +71,7 @@ proto_ncm_setup() { > > [ -n "$delay" ] && sleep "$delay" > > - manufacturer=`gcom -d "$device" -s /etc/gcom/getcardinfo.gcom | awk > '/Manufacturer/ { print tolower($2) }'` > + manufacturer=`gcom -d "$device" -s /etc/gcom/getcardinfo.gcom | awk 'NF > { print tolower($1); exit; }'` > [ $? -ne 0 ] && { > echo "Failed to get modem information" > proto_notify_error "$interface" GETINFO_FAILED > @@ -126,6 +114,7 @@ proto_ncm_setup() { > json_select .. > } > > + echo "Starting network $interface" > json_get_vars connect > eval COMMAND="$connect" gcom -d "$device" -s /etc/gcom/runcommand.gcom > || { > echo "Failed to connect" > @@ -133,19 +122,21 @@ proto_ncm_setup() { > return 1 > } > > - echo "Connected, starting DHCP on $ifname" > + echo "Setting up $ifname" > > proto_init_update "$ifname" 1 > proto_send_update "$interface" > > - json_init > - json_add_string name "${interface}_4" > - json_add_string ifname "@$interface" > - json_add_string proto "dhcp" > - proto_add_dynamic_defaults > - ubus call network add_dynamic "$(json_dump)" > + [ "$pdptype" = "IP" -o "$pdptype" = "IPV4V6" ] && { > + json_init > + json_add_string name "${interface}_4" > + json_add_string ifname "@$interface" > + json_add_string proto "dhcp" > + proto_add_dynamic_defaults > + ubus call network add_dynamic "$(json_dump)" > + } > > - [ -n "$ipv6" ] && { > + [ "$pdptype" = "IPV6" -o "$pdptype" = "IPV4V6" ] && { > json_init > json_add_string name "${interface}_6" > json_add_string ifname "@$interface" > @@ -161,12 +152,14 @@ proto_ncm_teardown() { > > local manufacturer disconnect > > - local device > - json_get_vars device > + local device profile > + json_get_vars device profile > + > + [ -n "$profile" ] || profile=1 > > - echo "Stopping network" > + echo "Stopping network $interface" > > - manufacturer=`gcom -d "$device" -s /etc/gcom/getcardinfo.gcom | awk > '/Manufacturer/ { print tolower($2) }'` > + manufacturer=`gcom -d "$device" -s /etc/gcom/getcardinfo.gcom | awk 'NF > { print tolower($1); exit; }'` > [ $? -ne 0 ] && { > echo "Failed to get modem information" > proto_notify_error "$interface" GETINFO_FAILED > @@ -181,7 +174,7 @@ proto_ncm_teardown() { > } > > json_get_vars disconnect > - COMMAND="$disconnect" gcom -d "$device" -s /etc/gcom/runcommand.gcom || > { > + eval COMMAND="$disconnect" gcom -d "$device" -s > /etc/gcom/runcommand.gcom || { > echo "Failed to disconnect" > proto_notify_error "$interface" DISCONNECT_FAILED > return 1 > _______________________________________________ Lede-dev mailing list Lede-dev@lists.infradead.org http://lists.infradead.org/mailman/listinfo/lede-dev