aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2011-11-23 10:35:45 +0100
committerAleksander Morgado <aleksander@lanedo.com>2012-03-15 14:14:24 +0100
commit90ba94056b6f8f5969bddb20f35b9c2eeb919dc6 (patch)
tree75560529c03e42e9c1658eaba7fbb8d050a026bf
parent63163835a3c12f64ce991961bb6b8a0409535918 (diff)
broadband-modem: implement Model loading
-rw-r--r--src/mm-broadband-modem.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c
index 27de4172..d01d157a 100644
--- a/src/mm-broadband-modem.c
+++ b/src/mm-broadband-modem.c
@@ -300,6 +300,50 @@ load_manufacturer (MMIfaceModem *self,
}
/*****************************************************************************/
+/* MODEL */
+
+static gchar *
+load_model_finish (MMIfaceModem *self,
+ GAsyncResult *res,
+ GError **error)
+{
+ GVariant *result;
+ gchar *model;
+
+ result = mm_at_sequence_finish (G_OBJECT (self), res, error);
+ if (!result)
+ return NULL;
+
+ model = g_variant_dup_string (result, NULL);
+ mm_dbg ("loaded model: %s", model);
+ g_variant_unref (result);
+ return model;
+}
+
+static const MMAtCommand models[] = {
+ { "+CGMM", 3, (MMAtResponseProcessor)common_parse_string_reply },
+ { "+GMM", 3, (MMAtResponseProcessor)common_parse_string_reply },
+ { NULL }
+};
+
+static void
+load_model (MMIfaceModem *self,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ mm_dbg ("loading model...");
+ mm_at_sequence (G_OBJECT (self),
+ mm_base_modem_get_port_primary (MM_BASE_MODEM (self)),
+ (MMAtCommand *)models,
+ NULL, /* response_processor_context */
+ FALSE,
+ "s",
+ NULL, /* TODO: cancellable */
+ callback,
+ user_data);
+}
+
+/*****************************************************************************/
static void
enable (MMBaseModem *self,
@@ -517,6 +561,8 @@ iface_modem_init (MMIfaceModem *iface)
iface->load_modem_capabilities_finish = load_modem_capabilities_finish;
iface->load_manufacturer = load_manufacturer;
iface->load_manufacturer_finish = load_manufacturer_finish;
+ iface->load_model = load_model;
+ iface->load_model_finish = load_model_finish;
}
static void