aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2011-12-30 15:39:59 +0100
committerAleksander Morgado <aleksander@lanedo.com>2012-03-15 14:14:41 +0100
commitaae179463b6dab0a8e7cc25af94f67ac65b9628f (patch)
treef795547b754248061d309781103da5faad44bf6a /src
parent148025c3818b4f4f64361314056470e49a9ff2f6 (diff)
broadband-modem: implement default supported mode loading
Try to guess the supported modes, based on the current capabilities.
Diffstat (limited to 'src')
-rw-r--r--src/mm-broadband-modem.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c
index d4023f73..ba5b09b6 100644
--- a/src/mm-broadband-modem.c
+++ b/src/mm-broadband-modem.c
@@ -655,6 +655,59 @@ load_unlock_required (MMIfaceModem *self,
user_data);
}
+/*****************************************************************************/
+/* SUPPORTED MODES */
+
+static MMModemMode
+load_supported_modes_finish (MMIfaceModem *self,
+ GAsyncResult *res,
+ GError **error)
+{
+ if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
+ return 0;
+
+ return (MMModemMode)GPOINTER_TO_UINT (g_simple_async_result_get_op_res_gpointer (
+ G_SIMPLE_ASYNC_RESULT (res)));
+}
+
+static void
+load_supported_modes (MMIfaceModem *self,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ MMBroadbandModem *broadband = MM_BROADBAND_MODEM (self);
+ GSimpleAsyncResult *result;
+ MMModemMode mode;
+
+ mm_dbg ("loading supported modes...");
+ result = g_simple_async_result_new (G_OBJECT (self),
+ callback,
+ user_data,
+ load_supported_modes);
+
+ mode = MM_MODEM_MODE_NONE;
+
+ /* If the modem has +GSM caps, assume it does CS, 2G and 3G */
+ if (broadband->priv->modem_current_capabilities & MM_MODEM_CAPABILITY_GSM_UMTS) {
+ mode |= (MM_MODEM_MODE_CS | MM_MODEM_MODE_2G | MM_MODEM_MODE_3G);
+ }
+ /* If the modem has CDMA caps, assume it does 3G */
+ else if (broadband->priv->modem_current_capabilities & MM_MODEM_CAPABILITY_CDMA_EVDO) {
+ mode |= MM_MODEM_MODE_3G;
+ }
+
+ /* If the modem has LTE caps, it does 4G */
+ if (broadband->priv->modem_current_capabilities & MM_MODEM_CAPABILITY_LTE ||
+ broadband->priv->modem_current_capabilities & MM_MODEM_CAPABILITY_LTE_ADVANCED) {
+ mode |= MM_MODEM_MODE_4G;
+ }
+
+ g_simple_async_result_set_op_res_gpointer (result,
+ GUINT_TO_POINTER (mode),
+ NULL);
+ g_simple_async_result_complete_in_idle (result);
+ g_object_unref (result);
+}
/*****************************************************************************/
/* SIGNAL QUALITY */
@@ -3141,6 +3194,8 @@ iface_modem_init (MMIfaceModem *iface)
iface->load_device_identifier_finish = load_device_identifier_finish;
iface->load_unlock_required = load_unlock_required;
iface->load_unlock_required_finish = load_unlock_required_finish;
+ iface->load_supported_modes = load_supported_modes;
+ iface->load_supported_modes_finish = load_supported_modes_finish;
iface->load_signal_quality = load_signal_quality;
iface->load_signal_quality_finish = load_signal_quality_finish;