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"