<div dir="ltr">New enough QMI and MBIM modems have messages to gather all the data for each connected SIM. It's possible that the message is simply not supported by your modem, since 1.18.2 should be new enough such that the MBIM implementation of load_sim_slots, etc. is available.<br><div><br></div><div>-Eric</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Nov 17, 2021 at 12:59 PM Bushman, Jeff <<a href="mailto:jbushman@ciena.com">jbushman@ciena.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">





<div lang="EN-US" style="overflow-wrap: break-word;">
<div class="gmail-m_5831335130693069640WordSection1">
<p class="MsoNormal">I used gdbus to introspect what was published, and It appears that ModemManager just doesn’t have this information – is that because of the particular modem I have, or the mode the modem is in?<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">diag@de-01:/opt/open-src/ModemManager$ gdbus introspect --system --dest org.freedesktop.ModemManager1 --object-path /org/freedesktop/ModemManager1/Modem/0<u></u><u></u></p>
<p class="MsoNormal">node /org/freedesktop/ModemManager1/Modem/0 {<u></u><u></u></p>
<p class="MsoNormal">…<u></u><u></u></p>
<p class="MsoNormal">  interface org.freedesktop.ModemManager1.Modem {<u></u><u></u></p>
<p class="MsoNormal">  …<u></u><u></u></p>
<p class="MsoNormal">    properties:<u></u><u></u></p>
<p class="MsoNormal">      readonly o Sim = '/org/freedesktop/ModemManager1/SIM/0';<u></u><u></u></p>
<p class="MsoNormal">      readonly ao SimSlots = [];<u></u><u></u></p>
<p class="MsoNormal">      readonly u PrimarySimSlot = 0;<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div style="border-right:none;border-bottom:none;border-left:none;border-top:1pt solid rgb(225,225,225);padding:3pt 0in 0in">
<p class="MsoNormal"><b>From:</b> Bushman, Jeff <<a href="mailto:jbushman@ciena.com" target="_blank">jbushman@ciena.com</a>> <br>
<b>Sent:</b> Tuesday, November 16, 2021 11:23 AM<br>
<b>To:</b> Aleksander Morgado <<a href="mailto:aleksander@aleksander.es" target="_blank">aleksander@aleksander.es</a>><br>
<b>Cc:</b> <a href="mailto:modemmanager-devel@lists.freedesktop.org" target="_blank">modemmanager-devel@lists.freedesktop.org</a><br>
<b>Subject:</b> Re: No SIM Slot Paths<u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Thanks for the reply Aleksander. The calls are made before I start the main loop. I used the synchronous code path from mmcli as an example, along with the main loop call from the sms-c-sync.c. Below is my demo code and program output.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">#define _GNU_SOURCE<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">#include <stdlib.h><u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">#define G_LOG_USE_STRUCTURED<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">#include <libmm-glib.h><u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">static gboolean<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">loop_is_idle(GMainLoop *loop)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">{<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_print("exiting main loop\n");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_main_loop_quit(loop);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    return G_SOURCE_REMOVE;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">}<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">static void dump_modem_info(gpointer obj, gpointer unused)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">{<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    /* get the modem interface */<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    MMObject *modem = (MMObject *)obj;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    MMModem *modem_if = mm_object_peek_modem(modem);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    if (!modem_if)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_printerr("error: modem-interface not found");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        return;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    const gchar *sim_path = mm_modem_get_sim_path(modem_if);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_print("Primary SIM path: %s\n", sim_path ? sim_path : "empty");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    const gchar * const * sim_paths = mm_modem_get_sim_slot_paths(modem_if);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_print("SIM Paths:\n");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    gint i;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    for (i = 0; sim_paths[i]; ++i)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_print("    [%d] %s\n", i, sim_paths[i]);
<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    if (i == 0)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_print("    No SIM paths found\n");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_print("Primary SIM slot: %u\n", mm_modem_get_primary_sim_slot(modem_if));<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_autoptr(GError) error = NULL;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_autoptr(GPtrArray) sims = mm_modem_list_sim_slots_sync(modem_if, NULL, &error);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    if (error)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">       g_printerr("error: couldn't get SIM list: %s\n", error->message);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">       g_clear_error(&error);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_print("SIMS array has %u elements\n", sims->len);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">}<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">static void<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">list_current_modems(MMManager *mm_mgr)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">{<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    GList *modems = g_dbus_object_manager_get_objects(G_DBUS_OBJECT_MANAGER(mm_mgr));<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_list_foreach(modems, dump_modem_info, NULL);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_list_free_full(modems, g_object_unref);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">}<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">gint<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">main(gint argc, gchar **argv)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">{<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_autoptr(GError) error = NULL;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_autoptr(GDBusConnection) dbus_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    if (!dbus_conn)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_printerr("error: couldn't connect to D-Bus: %s\n",<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">                   error ? error->message : "unknown");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        exit(EXIT_FAILURE);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    g_autoptr(MMManager) mm_mgr = mm_manager_new_sync(dbus_conn,<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">                                    G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_DO_NOT_AUTO_START,<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">                                    NULL,<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">                                    &error);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    if (!mm_mgr)<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_printerr("error: couldn't manager: %s\n",<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">                   error ? error->message : "unknown");<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        exit(EXIT_FAILURE);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    list_current_modems(mm_mgr);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    /* Run the main loop to clean up any lingering async tasks */<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    {<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_autoptr(GMainLoop) loop = g_main_loop_new(NULL, FALSE);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_idle_add((GSourceFunc)loop_is_idle, loop);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">        g_main_loop_run(loop);<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    }<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u></u> <u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">    return EXIT_SUCCESS;<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">}<u></u><u></u></span></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">Primary SIM path: /org/freedesktop/ModemManager1/SIM/0<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">SIM Paths:<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">    No SIM paths found<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">Primary SIM slot: 0<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">SIMS array has 0 elements<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New"">exiting main loop<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-family:"Courier New""><u></u> <u></u></span></p>
<div style="border-right:none;border-bottom:none;border-left:none;border-top:1pt solid rgb(225,225,225);padding:3pt 0in 0in">
<p class="MsoNormal"><b>From:</b> Aleksander Morgado <<a href="mailto:aleksander@aleksander.es" target="_blank">aleksander@aleksander.es</a>>
<br>
<b>Sent:</b> Tuesday, November 16, 2021 12:16 AM<br>
<b>To:</b> Bushman, Jeff <<a href="mailto:jbushman@ciena.com" target="_blank">jbushman@ciena.com</a>><br>
<b>Cc:</b> <a href="mailto:modemmanager-devel@lists.freedesktop.org" target="_blank">modemmanager-devel@lists.freedesktop.org</a><br>
<b>Subject:</b> [**EXTERNAL**] Re: No SIM Slot Paths<u></u><u></u></p>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div>
<div>
<p class="MsoNormal"><span style="font-family:"Courier New"">Hey,<u></u><u></u></span></p>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div>
<p class="MsoNormal">On Tue, Nov 16, 2021 at 12:08 AM Bushman, Jeff <<a href="mailto:jbushman@ciena.com" target="_blank">jbushman@ciena.com</a>> wrote:<u></u><u></u></p>
</div>
<blockquote style="border-top:none;border-right:none;border-bottom:none;border-left:1pt solid rgb(204,204,204);padding:0in 0in 0in 6pt;margin:5pt 0in 5pt 4.8pt">
<div>
<div>
<p class="MsoNormal">I’m just getting started with interfacing with the ModemManager via mm-glib. I am experimenting with the synchronous SIM slot APIs, and they don’t seem to work.<u></u><u></u></p>
<p class="MsoNormal">I am running ModemManager 1.18.2 on Ubuntu 20.04 with a Sierra Wireless MC7455-based USB modem running in MBIM mode and an AT&T SIM.<u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal">If I call mm_modem_get_sim_path() I do get the primary (only) SIM path back.<u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal">If I call mm_modem_get_sim_slot_paths(), I get an empty array back (the first element is NULL).<u></u><u></u></p>
<p class="MsoNormal">If I call mm_modem_get_primary_sim_slot(), I get an answer of 0, although the documentation implies the answer should be [1..N]<u></u><u></u></p>
<p class="MsoNormal">If I call mm_modem_list_sim_slots_sync(), I get an empty (len = 0) array back with no error message.<u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal">Should I expect these APIs to work? I’m very new to glib and D-Bus programming, so debugging tips are very welcome.<u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"><span class="gmail-m_5831335130693069640gmaildefault"><span style="font-family:"Courier New"">Are you running a GLib main loop in some way when using the sync APIs? Maybe these properties are not getting properly populated due to the lack of main loop. An example
 snippet of what you're doing would help.</span></span> <u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"><br>
-- <u></u><u></u></p>
<div>
<p class="MsoNormal">Aleksander<br>
<a href="https://urldefense.com/v3/__https:/aleksander.es__;!!OSsGDw!ckmQxfB3rnRMfXfZpbMUj00O-0rX0wz8qAVZm9buCMT-GPtp-orsXrkp_SDOGQ$" target="_blank">https://aleksander.es [aleksander.es]</a><u></u><u></u></p>
</div>
</div>
</div>
</div>

</blockquote></div>