From: Antti Seppälä Date: Sat, 10 May 2025 10:54:56 +0000 (+0300) Subject: qmi: increase SIM power-cycle timeouts X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F18772%2Fhead;p=thirdparty%2Fopenwrt.git qmi: increase SIM power-cycle timeouts Some modems and SIM cards take a bit longer to initialize after UIM has been powered off. Waiting too little time can cause the qmi protocol to end up in a loop repeatedly power-cycling the SIM card. Avoid that by a) increasing the time we unconditionally sleep after --uim-power-on b) increasing the time we allow uqmi to wait for response for --uim-get-sim-state Signed-off-by: Antti Seppälä Link: https://github.com/openwrt/openwrt/pull/18772 Signed-off-by: Hauke Mehrtens --- diff --git a/package/network/utils/uqmi/files/lib/netifd/proto/qmi.sh b/package/network/utils/uqmi/files/lib/netifd/proto/qmi.sh index b08b2251048..a6a3fdaa693 100755 --- a/package/network/utils/uqmi/files/lib/netifd/proto/qmi.sh +++ b/package/network/utils/uqmi/files/lib/netifd/proto/qmi.sh @@ -107,7 +107,7 @@ proto_qmi_setup() { # Check if UIM application is stuck in illegal state local uim_state_timeout=0 while true; do - json_load "$(uqmi -s -d "$device" -t 1000 --uim-get-sim-state)" + json_load "$(uqmi -s -d "$device" -t 2000 --uim-get-sim-state)" json_get_var card_application_state card_application_state # SIM card is either completely absent or state is labeled as illegal @@ -122,7 +122,7 @@ proto_qmi_setup() { if [ "$uim_state_timeout" -lt "$timeout" ] || [ "$timeout" = "0" ]; then let uim_state_timeout++ - sleep 1 + sleep 5 continue fi