4G modem (wwan0) on debian11 not working

Thank you very much for support

sudo mmcli -m 0

  Status   |                   lock: sim-puk2
           |         unlock retries: sim-puk2 (10)
           |                  state: disabled
           |            power state: low
  ----------------------------------
  Modes    |              supported: allowed: 3g, 4g; preferred: none
           |                current: allowed: 3g, 4g; preferred: none
  ----------------------------------
  IP       |              supported: ipv4, ipv6, ipv4v6
  ----------------------------------
  3GPP     |                 
           |          enabled locks: fixed-dialing
           |   packet service state: detached
  ----------------------------------
  3GPP EPS |   ue mode of operation: csps-2
           | initial bearer ip type: ipv4v6
  ----------------------------------
  SIM      |       primary sim path: /org/freedesktop/ModemManager1/SIM/0
           |         sim slot paths: slot 1: /org/freedesktop/ModemManager1/SIM/0 (active)
           |                         slot 2: /org/freedesktop/ModemManager1/SIM/1

AT+CREG?


+CREG: 0,0

OK

sim state: disabled

AT+CSQ

+CSQ: 99,99

OK

sudo mmcli -m 0 --enable

error: couldn't enable the modem: 'GDBus.Error:org.freedesktop.ModemManager1.Error.Core.Retry: Invalid transition'

You’ve made great progress. After disabling SIM detection, ModemManager now correctly reads the SIM, and the “SIM missing” error is gone, which is great news.

Just to make sure the new issue isn’t FCC lock, try the following:

  1. Open minicom and send the following command:

    AT+QCFG="fcc_enable",0
    
  2. Then, manually restart the BPi-R4.

  3. Try enabling the modem again:

    sudo mmcli -m 0 --enable
    
  4. Check the modem status with:

    sudo mmcli -m 0
    

Post the output here so we can take a look.

Edit: The more I think about it, the more convinced I am that your modem has the FCC lock. I suggest you take a look at the Modem Manager documentation (removed but still accessible through the internet cache) at the following link:

Modem Manager FCC Unlock Documentation (Archived)

The response from your modem to the AT command AT+CFUN=1,1 closely matches the behavior described for devices with the FCC lock and same goes for the response to sudo mmcli -m 0 --enable with an Invalid transition

from commands provided minicom


+CMTI: "ME",0

+CMTI: ,3

OK

OK

OK

OK

OK

+CCLK: "80/01/06,20:53:32"

OK
root@:# sudo mmcli -m 0 --enable
successfully enabled the modem
root@:# ping -I wwan0 google.com
ping: Warning: source address might be selected on device other than: wwan0
PING  (142.250.180.142) from 192.168.115.200 wwan0: 56(84) bytes of data.
^C
---  ping statistics ---
21 packets transmitted, 0 received, 100% packet loss, time 20485ms


the interface wwan0 not getting IP address after enable And ping 0 received, 100% packet loss,

From Network Mananger cdc-wdm0 gsm disconnected

root@:~# nmcli device
DEVICE         TYPE      STATE                   CONNECTION
lan0           ethernet  connected               Wired connection 4
wlan0          wifi      connected               wlan0
lo             loopback  connected (externally)  lo
eth0           ethernet  connected               Wired connection 1
lan1           ethernet  connected (externally)  lan1
ISP_Mikrotik   iptunnel  connected (externally)  ISP_Mikrotik
ipip_Mikrotik  iptunnel  connected (externally)  ipip_Mikrotik
cdc-wdm0       gsm       disconnected            --
p2p-dev-wlan0  wifi-p2p  disconnected            --
eth1           ethernet  unavailable             --
eth2           ethernet  unavailable             --
lan2           ethernet  unavailable             --
lan3           ethernet  unavailable             --
bond0          bond      unmanaged               --
erspan0        erspan    unmanaged               --
gre0           iptunnel  unmanaged               --
gre2           iptunnel  unmanaged               --
gretap0        iptunnel  unmanaged               --
tunl0          iptunnel  unmanaged               --
vlan18         vlan      unmanaged               --
wlan1          wifi      unmanaged               --
root@almaos:~#

Edited By using nmcli

root@almaos:~# sudo nmcli connection add type gsm ifname “*” con-name “4G Connection” apn “APN” sudo nmcli connection up “4G Connection” Connection ‘4G Connection’ successfully added. Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/10)

But ping not working

 ping -I wwan0 8.8.8.8
PING 8.8.8.8 (8.8.8.8) from 10.141.239.243 wwan0: 56(84) bytes of data.
^C
--- 8.8.8.8 ping statistics ---
62 packets transmitted, 0 received, 100% packet loss, time 62469ms

Last time you tried to enable the modem with:

sudo mmcli -m 0 --enable

You got this error:

error: couldn't enable the modem: 'GDBus.Error:org.freedesktop.ModemManager1.Error.Core.Retry: Invalid transition'

Now, after disabling the FCC lock, the response is:

successfully enabled the modem

That’s great! Now you were able to activate the modem.

Just to make sure everything is working correctly up to this point, please provide the output of:

sudo mmcli -m 0

This will help us easily compare with previous responses and see what has changed.

At this stage, I believe you only need to configure the APN, but I’d still like to check the Modem Manager’s response to sudo mmcli -m 0 to confirm.

root@:~# sudo mmcli -m 0
  ----------------------------------
  General  |                   path: /org/freedesktop/ModemManager1/Modem/0
           |              
  ----------------------------------
  Hardware |           manufacturer: Quectel
           |                  model: Quectel EM05-G
           |      firmware revision: EM05GFAR07A07M1G
           |           h/w revision: QUECTEL Mobile Broadband Modul
           |              supported: gsm-umts, lte
           |                current: gsm-umts, lte
           |          
  ----------------------------------
  System   |                 device: /sys/devices/platform/11200000.xhci/usb1/1-1/1-1.1
           |                drivers: option, cdc_mbim
           |                 plugin: quectel
           |           primary port: cdc-wdm0
           |                  ports: cdc-wdm0 (mbim), ttyUSB0 (at), wwan0 (net)
  ----------------------------------
  Numbers  |                    own: 
  ----------------------------------
  Status   |                   lock: sim-puk2
           |         unlock retries: sim-puk2 (10)
           |                  state: connected
           |            power state: on
           |            access tech: lte
           |         signal quality: 70% (recent)
  ----------------------------------
  Modes    |              supported: allowed: 3g, 4g; preferred: none
           |                current: allowed: 3g, 4g; preferred: none
  ----------------------------------
  IP       |              supported: ipv4, ipv6, ipv4v6
  ----------------------------------
  3GPP     |                   
           |          enabled locks: fixed-dialing
           |           
           |          operator name: 
           |           registration: home
           |   packet service state: attached
  ----------------------------------
  3GPP EPS |   ue mode of operation: csps-2
           |    initial bearer path: /org/freedesktop/ModemManager1/Bearer/0
           | initial bearer ip type: ipv4v6
  ----------------------------------
  SIM      |       primary sim path: /org/freedesktop/ModemManager1/SIM/0
           |         sim slot paths: slot 1: /org/freedesktop/ModemManager1/SIM/0 (active)
           |                         slot 2: /org/freedesktop/ModemManager1/SIM/1
  ----------------------------------
  Bearer   |                  paths: /org/freedesktop/ModemManager1/Bearer/1
root@almaos:~#

Well, so far so good, everything seems fine with the modem being activated without issues.

At this point, I believe you’re not receiving data because the operator’s settings might not be configured correctly. I noticed that you created a connection and only set the APN as “APN”. Is just “APN” your apn data, don´t also need to include a username and/or password?

Could you please share the complete carrier information? Not the ones you’re using right now, but the official ones your carrier provides to customers for internet connectivity.

The opertator is Ilaid


root@:~# sudo mmcli -m 0
  ----------------------------------
  General  |                   path: /org/freedesktop/ModemManager1/Modem/0
           |              device id: fbb3545aa050654a3ccd0132e3460f27f636e384
  ----------------------------------
  Hardware |           manufacturer: Quectel
           |                  model: Quectel EM05-G
           |      firmware revision: EM05GFAR07A07M1G
           |           h/w revision: QUECTEL Mobile Broadband Modul
           |              supported: gsm-umts, lte
           |                current: gsm-umts, lte
           |           equipment id: 869****************
  ----------------------------------
  System   |                 device: /sys/devices/platform/11200000.xhci/usb1/1-1/1-1.1
           |                drivers: option, cdc_mbim
           |                 plugin: quectel
           |           primary port: cdc-wdm0
           |                  ports: cdc-wdm0 (mbim), ttyUSB0 (at), wwan0 (net)
  ----------------------------------
  Numbers  |                    own: +3**************
  ----------------------------------
  Status   |                   lock: sim-puk2
           |         unlock retries: sim-puk2 (10)
           |                  state: connected
           |            power state: on
           |            access tech: lte
           |         signal quality: 70% (recent)
  ----------------------------------
  Modes    |              supported: allowed: 3g, 4g; preferred: none
           |                current: allowed: 3g, 4g; preferred: none
  ----------------------------------
  IP       |              supported: ipv4, ipv6, ipv4v6
  ----------------------------------
  3GPP     |                   imei: 869***********
           |          enabled locks: fixed-dialing
           |            operator id: 22***
           |          operator name: Iliad
           |           registration: home
           |   packet service state: attached
  ----------------------------------
  3GPP EPS |   ue mode of operation: csps-2
           |    initial bearer path: /org/freedesktop/ModemManager1/Bearer/0
           | initial bearer ip type: ipv4v6
  ----------------------------------
  SIM      |       primary sim path: /org/freedesktop/ModemManager1/SIM/0
           |         sim slot paths: slot 1: /org/freedesktop/ModemManager1/SIM/0 (active)
           |                         slot 2: /org/freedesktop/ModemManager1/SIM/1
  ----------------------------------
  Bearer   |                  paths: /org/freedesktop/ModemManager1/Bearer/1

For user name and password are not needed

I’m not familiar with that carrier, but after searching online, I found that if your carrier is Iliad Italy, the APN you entered is definitely wrong. It should be “iliad” instead of “APN.” It’s also recommended to include a number to dial.

You can modify both the APN and the phone number in a single command using nmcli.

sudo nmcli connection modify "4G Connection" gsm.apn "Iliad" gsm.number "*99#"

After modifying the connection, restart it to apply the new settings:

sudo nmcli connection down "4G Connection"
sudo nmcli connection up "4G Connection"

To check if the changes were applied correctly, use:

nmcli connection show "4G Connection"

This will display the current configuration, including the APN and phone number.

Edit: I just edited it because apparently the APN is Iliad, with the first “I” in uppercase. If it’s not working, try both uppercase and lowercase.

I modified with uppercase and lowercase of “i” and wrote phone numebr correctly but the same I interface wwan0 not reciving data from internet

    RX packets 0  bytes 0 (0.0 B)
    RX errors 0  dropped 0  overruns 0  frame 0
    TX packets 267  bytes 24112 (23.5 KiB)
    TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

even ping not working

Could you share the output of:

sudo nmcli connection show "4G Connection"

For the phone number, are you entering your own number? you don’t need to enter your actual number, just use the generic *99# which is the same for all countries.

Modify that please:

sudo nmcli connection modify "4G Connection" gsm.number "*99#"

then restart the connection:

sudo nmcli connection down "4G Connection"
sudo nmcli connection up "4G Connection"

Yes I tried in begaining using sudo nmcli connection modify “4G Connection” gsm.number “*99#”

but it the same

I will delet connection and try from the very new step maybe somthing missed in routing and firewall rules

Do that. At this point, you’re very close to getting it to work.

I’d bet the issue now is with the carrier settings, everything else seems to be fine.

1 Like

Thank you very much for support

1 Like

I have similar issues with a Quectel RM520N-GL on OpenWRT latest release w/ModemManager 1.22:

  • Using the OSS wwan and mhi_wwan_mbim kernel modules, not the Quectel ones
  • /dev/wwan0mbim0 was the device I had to use via qmbimat (had to build it myself) in order to send commands
  • Inverted SIM detection as above to bypass it, SIM now detected successfully
  • Used AT+QMBNCFG="list" to validate that an MBN for my network was available on-SIM and used AT+QMBNCFG="AutoSel",1 to enable autoselection of it. Now IP and route is assigned to the interface setup with ModemManager.
  • I can’t establish any connectivity through the created interface, mhi_hwip0 (ping -I mhi_hwip0 1.1.1.1 for example increments TX without any RX and nor can I ping the default route). This looks exactly like the issue you have.
  • That said, AT+QPING=4,"1.1.1.1" responds OK for me. I wonder if instructing the modem to ping would work for you?

That’s as far as I’ve got so far. It’s enough to validate, I think, that connectivity is working on the modem side so something else is misbehaving - I hope that you manage to get it working and can report back on how you managed it!

Ref. Banana Pi BPI-R4 4G/5G Module sim card missing in modem manager - #42 by pkern as it looks like a similar issue.

I have the same issue of ping -I wwan0 8.8.8.8 it get IP address and gate way but it not receive echo reply so the connection to internet not established, I tried hard to find out why but not found yet, I checked firewall and Debian forwarding and NAT all correct , I hope find out why asap

other problem is when insert sim card , device not found but I have to take it a little bit out and keep checking to device find it

I’ve got it working with the Quectel drivers now I’ve had a few hours to play with it, I gave up on pure OSS MBIM.

First step was to make sure the bands were selected correctly on the modem, I just want 5G or LTE so I set ./qmbimat -d /dev/wwan0mbim0 -a AT+QNWPREFCFG=\"mode_pref\",NR5G:LTE

The packages I have installed are:

luci-proto-modemmanager
mbim-utils
modemmanager
modemmanager-rpcd
kmod-mhi-wwan-ctrl
kmod-mtk-t7xx
kmod-usb-acm
kmod-usb-atm
kmod-usb-atm-cxacru
kmod-usb-atm-speedtouch
kmod-usb-atm-ueagle
kmod-usb-net-kalmia
kmod-usb-net-qmi-wwan
kmod-usb-serial-option
kmod-usb-serial-wwan
kmod-mhi-wwan-ctrl
kmod-mhi-wwan-mbim
kmod-usb-net-qmi-wwan
kmod-usb-serial-wwan
kmod-wwan
wwan
kmod-qcom-qmi-helpers
kmod-usb-net-qmi-wwan
libqmi
luci-proto-qmi
qmi-utils
uqmi
kmod-mhi-bus
kmod-mhi-net
kmod-mhi-pci-generic
kmod-mhi-wwan-ctrl
kmod-mhi-wwan-mbim
kmod-qrtr-mhi

I’m not sure that all are needed, but at least some of these are.

I had to build the Quectel kernel module and utility, but first the OpenWRT release I’m using:

git clone [email protected]:openwrt/openwrt.git
cd openwrt
git checkout 6df0e3d # hash suffix from release build ID
wget https://downloads.openwrt.org/releases/24.10.0/targets/mediatek/filogic/config.buildinfo -O .config
wget https://downloads.openwrt.org/releases/24.10.0/targets/mediatek/filogic/feeds.buildinfo -O feeds.conf
./scripts/feeds update -a
./scripts/feeds install -a
make -j $(($(nproc)+1)) toolchain/install
make -j $(($(nproc)+1)) target/linux/compile

Then I built the Quectel driver and QConnectManager using the replicated kernel build, it has to be the exact same version of the kernel you’re using. You can obtain these from Quectel (or, I’m sure, somewhere else but I’m not sure what the redist license is for them)

unzip Quectel_Linux_PCIE_MHI_Driver_V1.3.7.zip -d package/kernel/
unzip Quectel_QConnectManager_Linux_V1.6.7.zip -d package/utils/
make package/utils/quectel-CM-5G/{clean,compile} V=sc
make package/kernel/pcie_mhi/{clean,compile} V=sc

Once it’s built, you need to copy it over to your development board and install the packages:

scp -O bin/targets/mediatek/filogic/packages/kmod-pcie_mhi_*.ipk user@router:/tmp
scp -O bin/packages/aarch64_cortex-a53/base/quectel-CM-5G_*.ipk user@router:/tmp
ssh user@router
cd /tmp; opkg install *.ipk

After that, I disabled all existing ModemManager interfaces and the service if it was running then powered off the router and modem with poweroff and physically removing the adapter to ‘reset’ them. I made sure that the kernel module was loaded after booting up again and that I had screen, tmux or similar and ran eg.

lsmod | grep pcie_mhi
# pcie_mhi              151552  0
screen -S modem
quectel-CM
# detach with Ctrl-A D

I was then able to achieve full internet connectivity via the newly generated interface:

ping 1.1.1.1 -c 4 -I rmnet_mhi0.1
# PING 1.1.1.1 (1.1.1.1): 56 data bytes
# 64 bytes from 1.1.1.1: seq=0 ttl=57 time=201.485 ms
# 64 bytes from 1.1.1.1: seq=1 ttl=57 time=28.409 ms
# 64 bytes from 1.1.1.1: seq=2 ttl=57 time=45.255 ms
# 64 bytes from 1.1.1.1: seq=3 ttl=57 time=45.153 ms
#
# --- 1.1.1.1 ping statistics ---
# 4 packets transmitted, 4 packets received, 0% packet loss
# round-trip min/avg/max = 28.409/80.075/201.485 ms

Hope that helps! From here, it should be as easy as making quectel-CM run on boot by creating an init or systemd service.

Edit: as a bit of Debian specific info you may find How to build out of tree Kernel Module on Debian · GitHub to be useful to guide the process of building an individual kernel module, you can of course ignore all the OpenWRT related stuff and adapt the process for your own OS

2 Likes

Great job! Congratulations on getting it up and running.

I have my RM520-GL on the way, if customs doesn’t delay it, it should arrive this week. Hopefully, everything works out of the box, but we’ll see!

Thanks for sharing such a detailed explanation, it’ll definitely be helpful.

Congratulations

Thank you very much for post the solution I will try it