aboutsummaryrefslogtreecommitdiff
path: root/src/mm-iface-modem.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2012-04-10 17:25:34 +0200
committerAleksander Morgado <aleksander@lanedo.com>2012-04-10 18:28:33 +0200
commit83afd3ddc9a81321233065d4ff17fa620faf8ca6 (patch)
tree61ef7ffd902b0a3129c3d05d40ea6551dfe36a26 /src/mm-iface-modem.c
parente89a8a42a9c382f9471f14a5016afef8fb5eae36 (diff)
iface-modem: new helpers to query supported modes
Diffstat (limited to 'src/mm-iface-modem.c')
-rw-r--r--src/mm-iface-modem.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/src/mm-iface-modem.c b/src/mm-iface-modem.c
index c094b578..49a18a59 100644
--- a/src/mm-iface-modem.c
+++ b/src/mm-iface-modem.c
@@ -3689,6 +3689,71 @@ mm_iface_modem_shutdown (MMIfaceModem *self)
/*****************************************************************************/
+MMModemMode
+mm_iface_modem_get_supported_modes (MMIfaceModem *self)
+{
+ MMModemMode supported = MM_MODEM_MODE_NONE;
+ MmGdbusModem *skeleton;
+
+ g_object_get (self,
+ MM_IFACE_MODEM_DBUS_SKELETON, &skeleton,
+ NULL);
+
+ if (skeleton) {
+ supported = mm_gdbus_modem_get_supported_modes (skeleton);
+ g_object_unref (skeleton);
+ }
+
+ return supported;
+}
+
+gboolean
+mm_iface_modem_is_2g (MMIfaceModem *self)
+{
+ return (mm_iface_modem_get_supported_modes (self) & MM_MODEM_MODE_2G);
+}
+
+gboolean
+mm_iface_modem_is_2g_only (MMIfaceModem *self)
+{
+ MMModemMode supported;
+
+ supported = mm_iface_modem_get_supported_modes (self);
+ return !((MM_MODEM_MODE_2G ^ supported) & supported);
+}
+
+gboolean
+mm_iface_modem_is_3g (MMIfaceModem *self)
+{
+ return (mm_iface_modem_get_supported_modes (self) & MM_MODEM_MODE_3G);
+}
+
+gboolean
+mm_iface_modem_is_3g_only (MMIfaceModem *self)
+{
+ MMModemMode supported;
+
+ supported = mm_iface_modem_get_supported_modes (self);
+ return !((MM_MODEM_MODE_3G ^ supported) & supported);
+}
+
+gboolean
+mm_iface_modem_is_4g (MMIfaceModem *self)
+{
+ return (mm_iface_modem_get_supported_modes (self) & MM_MODEM_MODE_4G);
+}
+
+gboolean
+mm_iface_modem_is_4g_only (MMIfaceModem *self)
+{
+ MMModemMode supported;
+
+ supported = mm_iface_modem_get_supported_modes (self);
+ return !((MM_MODEM_MODE_4G ^ supported) & supported);
+}
+
+/*****************************************************************************/
+
MMModemCapability
mm_iface_modem_get_current_capabilities (MMIfaceModem *self)
{