Watching for available SIMs on D-Bus
Aleksander Morgado
aleksander at aleksander.es
Sun Jul 21 20:08:40 UTC 2019
Hey,
> > > I need to collect informations about modems (for IMEI) and SIM cards
> > > (for IMSI) available to system over D-Bus.
> > >
> > > While listening to signal InterfacesAdded on interface
> > > org.freedesktop.DBus.ObjectManager does work as mentioned in
> > > documentation, ie. returning properties on newly discovered modem,
> > > I cannot get this work for SIm cards. Here listening to
> > > PropertiesChanged for both Modem or SIM interface does not
> > > return anything. Current "solution" is to look at SIM object
> > > path after while, which gets SIM a chance to be discovered,
> > > but I would prefer to know how to implement it "the right
> > > way" (tm).
> > >
> >
> > The "manager" object in ModemManager implements
> > org.freedesktop.DBus.ObjectManager but ONLY for modem objects. This
> > means that the ObjectManager interface only notifies about
> > added/removed interfaces in modem objects.
> >
> > Once you have the path for an existing modem object with a
> > "org.freedesktop.ModemManager1.Modem" interface, you should then
> > monitor the "Sim" property in that interface, which will give you the
> > DBus path to the SIM object available in the modem.
>
> Well, perhaps I didn't make above clear. I'm waiting for Modem object
> to appear on the bus, which works reliably. Once it appears I'm hooking
> "PropertiesChanged" on it which also works as you indicated above.
> Here "Sim" property is also available and object it points to does not
> emit changes [*]. So once new modem appears on the bus, its Sim
> property contains valid path to Sim object, but Imsi property of that
> object is empty at that time. However, asking again after some time gives
> expected result.
I'm not sure why you're seeing this. The SIM object creation involves
loading IMSI/ICCID as part of the creation, and only once all have
been loaded (or failed to load) then we export the SIM object in DBus,
with the properties already set. There is no "reloading" after the SIM
object has already been exposed in DBus. I have never seen this issue
when using libmm-glib, truth be told, I think you'll have to debug it
further I'm afraid, or otherwise share a simple tester program that
reproduces the issue.
>
> > It is "guaranteed" by the implementation that the SIM path does NOT
> > change in the same modem object, though. If for any reason the SIM is
> > ejected and changed, the actual modem object will be completely
> > re-created and the modem object path will also change.
>
> A side question: Once ModemManager is restarted all the hooks to
> "PropertiesChanged" has to be destroyed using "NameOwnerChanged"
> onInterface "org.freedesktop.DBus" and then created again using
> "InterfacesAdded" of "org.freedesktop.DBus.ObjectManager" to get
> internal application state into sync with ModemManger. Is that
> correct or does some more elegant shortcut exist?
>
Once ModemManager is restarted, all the objects exposed by the old and
the new MM processes are completely different, and MM itself has a
different bus address. So, whenever MM goes away, you need to cleanup
all the stuff that you were monitoring. The main issue you're having
here is that you're doing all this low-level stuff yourself, I assume
because you cannot use libmm-glib or ModemManagerQt, right?
> [*] debug on "PropertiesChanged" of "Modem" gives:
> Property UnlockRequired at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem.Modem3gpp.Ussd changed
> Property Enabled at org.freedesktop.ModemManager1.Modem.Location changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property RegistrationState at org.freedesktop.ModemManager1.Modem.Modem3gpp changed
> Property OperatorCode at org.freedesktop.ModemManager1.Modem.Modem3gpp changed
> Property OperatorName at org.freedesktop.ModemManager1.Modem.Modem3gpp changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property RegistrationState at org.freedesktop.ModemManager1.Modem.Modem3gpp changed
> Property Bearers at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem changed
> Property SignalQuality at org.freedesktop.ModemManager1.Modem changed
> Property State at org.freedesktop.ModemManager1.Modem changed
>
> As you can see there is no change on org.freedesktop.ModemManager1.Sim
> which is probably okay, per what you wrote before, but that leaves me
> with no nice solution. Suggestions?
>
Wait, you won't see a property update on the
"org.freedesktop.ModemManager1.Sim" interface by monitoring the
PropertiesUpdated of the modem object. How about you monitor
PropertiesUpdated on the SIM object instead?
--
Aleksander
https://aleksander.es
More information about the ModemManager-devel
mailing list