aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2012-08-23 16:31:34 +0200
committerAleksander Morgado <aleksander@lanedo.com>2012-08-23 18:56:23 +0200
commit6c6cbb33e7bfd1709e57f677ec265b65e4e5c1ef (patch)
treee5763354d919a63ffe82277879e7014ba0e5e863
parent2a06d1ed08addd97578f71d671cdaf87d8a71515 (diff)
mbm: implement custom initialization commands
-rw-r--r--plugins/mbm/mm-broadband-modem-mbm.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/plugins/mbm/mm-broadband-modem-mbm.c b/plugins/mbm/mm-broadband-modem-mbm.c
index f5c2f35a..2a2e80e8 100644
--- a/plugins/mbm/mm-broadband-modem-mbm.c
+++ b/plugins/mbm/mm-broadband-modem-mbm.c
@@ -238,6 +238,40 @@ set_allowed_modes (MMIfaceModem *_self,
}
/*****************************************************************************/
+/* Initializing the modem (Modem interface) */
+
+static gboolean
+modem_init_finish (MMIfaceModem *self,
+ GAsyncResult *res,
+ GError **error)
+{
+ /* Ignore errors */
+ mm_base_modem_at_sequence_finish (MM_BASE_MODEM (self), res, NULL, NULL);
+ return TRUE;
+}
+
+static const MMBaseModemAtCommand modem_init_sequence[] = {
+ /* Init command */
+ { "&F E0 V1 X4 &C1 +CMEE=1", 3, FALSE, NULL },
+ /* Ensure disconnected */
+ { "*ENAP=0", 3, FALSE, NULL },
+ { NULL }
+};
+
+static void
+modem_init (MMIfaceModem *self,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ mm_base_modem_at_sequence (MM_BASE_MODEM (self),
+ modem_init_sequence,
+ NULL, /* response_processor_context */
+ NULL, /* response_processor_context_free */
+ callback,
+ user_data);
+}
+
+/*****************************************************************************/
/* Powering up the modem (Modem interface) */
static gboolean
@@ -443,6 +477,8 @@ iface_modem_init (MMIfaceModem *iface)
iface->load_allowed_modes_finish = load_allowed_modes_finish;
iface->set_allowed_modes = set_allowed_modes;
iface->set_allowed_modes_finish = set_allowed_modes_finish;
+ iface->modem_init = modem_init;
+ iface->modem_init_finish = modem_init_finish;
iface->modem_power_up = modem_power_up;
iface->modem_power_up_finish = modem_power_up_finish;
}