9 proto_mbim_init_config
() {
12 proto_config_add_string
"device:device"
13 proto_config_add_string apn
14 proto_config_add_string pincode
15 proto_config_add_string delay
16 proto_config_add_string auth
17 proto_config_add_string username
18 proto_config_add_string password
26 local device apn pincode delay
27 json_get_vars device apn pincode delay auth username password
30 logger
-p daemon.err
-t "mbim[$$]" "No control device specified"
31 proto_notify_error
"$interface" NO_DEVICE
32 proto_block_restart
"$interface"
36 logger
-p daemon.err
-t "mbim[$$]" "The specified control device does not exist"
37 proto_notify_error
"$interface" NO_DEVICE
38 proto_block_restart
"$interface"
42 devname
="$(basename "$device")"
43 devpath
="$(readlink -f /sys/class/usbmisc/$devname/device/)"
44 ifname
="$( ls "$devpath"/net )"
47 logger
-p daemon.err
-t "mbim[$$]" "Failed to find matching interface"
48 proto_notify_error
"$interface" NO_IFNAME
49 proto_set_available
"$interface" 0
54 logger
-p daemon.err
-t "mbim[$$]" "No APN specified"
55 proto_notify_error
"$interface" NO_APN
56 proto_block_restart
"$interface"
60 [ -n "$delay" ] && sleep "$delay"
62 logger
-p daemon.info
-t "mbim[$$]" "Reading capabilities"
63 umbim
$DBG -n -d $device caps ||
{
64 logger
-p daemon.err
-t "mbim[$$]" "Failed to read modem caps"
65 proto_notify_error
"$interface" PIN_FAILED
66 proto_block_restart
"$interface"
72 logger
-p daemon.info
-t "mbim[$$]" "Sending pin"
73 umbim
$DBG -n -t $tid -d $device unlock
"$pincode" ||
{
74 logger
-p daemon.err
-t "mbim[$$]" "Unable to verify PIN"
75 proto_notify_error
"$interface" PIN_FAILED
76 proto_block_restart
"$interface"
82 logger
-p daemon.info
-t "mbim[$$]" "Checking pin"
83 umbim
$DBG -n -t $tid -d $device pinstate ||
{
84 logger
-p daemon.err
-t "mbim[$$]" "PIN required"
85 proto_notify_error
"$interface" PIN_FAILED
86 proto_block_restart
"$interface"
91 logger
-p daemon.info
-t "mbim[$$]" "Checking subscriber"
92 umbim
$DBG -n -t $tid -d $device subscriber ||
{
93 logger
-p daemon.err
-t "mbim[$$]" "Subscriber init failed"
94 proto_notify_error
"$interface" NO_SUBSCRIBER
95 proto_block_restart
"$interface"
100 logger
-p daemon.info
-t "mbim[$$]" "Register with network"
101 umbim
$DBG -n -t $tid -d $device registration ||
{
102 logger
-p daemon.err
-t "mbim[$$]" "Subscriber registration failed"
103 proto_notify_error
"$interface" NO_REGISTRATION
104 proto_block_restart
"$interface"
109 logger
-p daemon.info
-t "mbim[$$]" "Attach to network"
110 umbim
$DBG -n -t $tid -d $device attach ||
{
111 logger
-p daemon.err
-t "mbim[$$]" "Failed to attach to network"
112 proto_notify_error
"$interface" ATTACH_FAILED
113 proto_block_restart
"$interface"
118 logger
-p daemon.info
-t "mbim[$$]" "Connect to network"
119 while ! umbim
$DBG -n -t $tid -d $device connect
"$apn" "$auth" "$username" "$password"; do
125 uci_set_state network
$interface tid
"$tid"
127 logger
-p daemon.info
-t "mbim[$$]" "Connected, starting DHCP"
128 proto_init_update
"*" 1
129 proto_send_update
"$interface"
132 json_add_string name
"${interface}_dhcp"
133 json_add_string ifname
"$ifname"
134 json_add_string proto
"dhcp"
136 ubus call network add_dynamic
"$(json_dump)"
139 json_add_string name
"${interface}_dhcpv6"
140 json_add_string ifname
"$ifname"
141 json_add_string proto
"dhcpv6"
142 ubus call network add_dynamic
"$(json_dump)"
145 proto_mbim_teardown
() {
150 local tid
=$
(uci_get_state network
$interface tid
)
152 logger
-p daemon.info
-t "mbim[$$]" "Stopping network"
154 umbim
$DBG -t$tid -d "$device" disconnect
155 uci_revert_state network
$interface tid
158 proto_init_update
"*" 0
159 proto_send_update
"$interface"