aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2011-12-31 12:57:10 +0100
committerAleksander Morgado <aleksander@lanedo.com>2012-03-15 14:14:42 +0100
commitf4acff17daf158071e9a0e965e80131dfc91b2c5 (patch)
tree7042f08dfba8ea1cafefa9d0aa793b0d4dfe1e69 /src
parentbda0d0c1d4e5bf06cd1296c140e4f03ecba6836c (diff)
broadband-modem: skip SIM creation in CDMA-only modems
Diffstat (limited to 'src')
-rw-r--r--src/mm-broadband-modem.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c
index 939abe31..acabff51 100644
--- a/src/mm-broadband-modem.c
+++ b/src/mm-broadband-modem.c
@@ -169,10 +169,13 @@ modem_create_sim_finish (MMIfaceModem *self,
GAsyncResult *res,
GError **error)
{
+ MMSim *sim;
+
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
return NULL;
- return (g_object_ref (g_simple_async_result_get_op_res_gpointer (
- G_SIMPLE_ASYNC_RESULT (res))));
+
+ sim = g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
+ return (sim ? g_object_ref (sim) : NULL);
}
static void
@@ -211,6 +214,15 @@ modem_create_sim (MMIfaceModem *self,
user_data,
modem_create_sim);
+ /* CDMA-only modems don't need this */
+ if (mm_iface_modem_is_cdma_only (self)) {
+ mm_dbg ("Skipping SIM creation in CDMA-only modem...");
+ g_simple_async_result_set_op_res_gpointer (result, NULL, NULL);
+ g_simple_async_result_complete_in_idle (result);
+ g_object_unref (result);
+ return;
+ }
+
/* New generic SIM */
mm_sim_new (MM_BASE_MODEM (self),
NULL, /* cancellable */