hso: consolidate PDP context activate/deactivate operations

And rename the function to make it clearer.  disable() wasn't using
the common activate/deactivate code so switch it to do so.
This commit is contained in:
Dan Williams
2009-11-24 00:19:27 -08:00
parent e5b5c83394
commit 9e92bceb07

View File

@@ -73,14 +73,14 @@ mm_modem_hso_new (const char *device,
} }
static void static void
hso_enable_done (MMSerialPort *port, hso_call_control_done (MMSerialPort *port,
GString *response, GString *response,
GError *error, GError *error,
gpointer user_data) gpointer user_data)
{ {
MMCallbackInfo *info = (MMCallbackInfo *) user_data; MMCallbackInfo *info = (MMCallbackInfo *) user_data;
if (error) if (error && !mm_callback_info_get_data (info, "ignore-errors"))
info->error = g_error_copy (error); info->error = g_error_copy (error);
mm_callback_info_schedule (info); mm_callback_info_schedule (info);
@@ -99,8 +99,9 @@ hso_get_cid (MMModemHso *self)
} }
static void static void
hso_enable (MMModemHso *self, hso_call_control (MMModemHso *self,
gboolean enabled, gboolean activate,
gboolean ignore_errors,
MMModemFn callback, MMModemFn callback,
gpointer user_data) gpointer user_data)
{ {
@@ -109,11 +110,12 @@ hso_enable (MMModemHso *self,
MMSerialPort *primary; MMSerialPort *primary;
info = mm_callback_info_new (MM_MODEM (self), callback, user_data); info = mm_callback_info_new (MM_MODEM (self), callback, user_data);
mm_callback_info_set_data (info, "ignore-error", GUINT_TO_POINTER (ignore_errors), NULL);
command = g_strdup_printf ("AT_OWANCALL=%d,%d,1", hso_get_cid (self), enabled ? 1 : 0); command = g_strdup_printf ("AT_OWANCALL=%d,%d,1", hso_get_cid (self), activate ? 1 : 0);
primary = mm_generic_gsm_get_port (MM_GENERIC_GSM (self), MM_PORT_TYPE_PRIMARY); primary = mm_generic_gsm_get_port (MM_GENERIC_GSM (self), MM_PORT_TYPE_PRIMARY);
g_assert (primary); g_assert (primary);
mm_serial_port_queue_command (primary, command, 3, hso_enable_done, info); mm_serial_port_queue_command (primary, command, 3, hso_call_control_done, info);
g_free (command); g_free (command);
} }
@@ -179,8 +181,10 @@ hso_disabled (MMModem *modem,
if (error) { if (error) {
info->error = g_error_copy (error); info->error = g_error_copy (error);
mm_callback_info_schedule (info); mm_callback_info_schedule (info);
} else } else {
hso_enable (MM_MODEM_HSO (modem), TRUE, hso_enabled, info); /* Success, activate the PDP context and start the data session */
hso_call_control (MM_MODEM_HSO (modem), TRUE, FALSE, hso_enabled, info);
}
} }
static void static void
@@ -197,7 +201,7 @@ auth_done (MMSerialPort *port,
mm_callback_info_schedule (info); mm_callback_info_schedule (info);
} else } else
/* success, kill any existing connections first */ /* success, kill any existing connections first */
hso_enable (self, FALSE, hso_disabled, info); hso_call_control (self, FALSE, FALSE, hso_disabled, info);
} }
void void
@@ -276,8 +280,7 @@ enable (MMModem *modem,
} }
static void static void
disable_done (MMSerialPort *port, disable_done (MMModem *modem,
GString *response,
GError *error, GError *error,
gpointer user_data) gpointer user_data)
{ {
@@ -295,28 +298,13 @@ disable (MMModem *modem,
gpointer user_data) gpointer user_data)
{ {
MMCallbackInfo *info; MMCallbackInfo *info;
MMSerialPort *primary;
char *cmd;
guint32 cid;
mm_generic_gsm_pending_registration_stop (MM_GENERIC_GSM (modem)); mm_generic_gsm_pending_registration_stop (MM_GENERIC_GSM (modem));
info = mm_callback_info_new (modem, callback, user_data); info = mm_callback_info_new (modem, callback, user_data);
/* Kill any existing connection */ /* Kill any existing connection */
primary = mm_generic_gsm_get_port (MM_GENERIC_GSM (modem), MM_PORT_TYPE_PRIMARY); hso_call_control (MM_MODEM_HSO (modem), FALSE, FALSE, disable_done, info);
g_assert (primary);
cid = mm_generic_gsm_get_cid (MM_GENERIC_GSM (modem));
mm_generic_gsm_set_cid (MM_GENERIC_GSM (modem), 0);
/* Disconnect the data session of the active connection, if any */
if (cid > 0) {
cmd = g_strdup_printf ("AT_OWANCALL=%u,0,0", cid);
mm_serial_port_queue_command (primary, cmd, 3, disable_done, info);
g_free (cmd);
} else
disable_done (primary, NULL, NULL, info);
} }
static void static void