aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2013-12-09 15:07:25 -0800
committerAleksander Morgado <aleksander@lanedo.com>2013-12-10 10:24:52 +0100
commitebadb6786a4a398c0110c8e794922427081f10ee (patch)
treec5ca96274dbc1c8d87228ac65f41d52d271199a6 /src
parentfc42b2df8c0c68425f79dae17f6fac988f69f6f5 (diff)
sim-mbim: prevent potential leak when loading operator idenitifier and name
This patch addresses a potential memory leak when load_operator_identifier or load_operator_name in MMSimMbim is called but the caller does not provide a GAsyncReadyCallback. Reported by Aleksander Morgado <aleksander@lanedo.com>
Diffstat (limited to 'src')
-rw-r--r--src/mm-sim-mbim.c26
1 files changed, 16 insertions, 10 deletions
diff --git a/src/mm-sim-mbim.c b/src/mm-sim-mbim.c
index 77e83ea0..c0839976 100644
--- a/src/mm-sim-mbim.c
+++ b/src/mm-sim-mbim.c
@@ -207,9 +207,13 @@ load_operator_identifier_finish (MMSim *self,
GAsyncResult *res,
GError **error)
{
+ MbimProvider *provider;
+
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
return NULL;
- return (gchar *)g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
+
+ provider = (MbimProvider *)g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
+ return g_strdup (provider->provider_id);
}
static void
@@ -227,10 +231,9 @@ load_operator_identifier_ready (MbimDevice *device,
mbim_message_home_provider_response_parse (
response,
&provider,
- &error)) {
- g_simple_async_result_set_op_res_gpointer (simple, g_strdup (provider->provider_id), NULL);
- mbim_provider_free (provider);
- } else
+ &error))
+ g_simple_async_result_set_op_res_gpointer (simple, provider, (GDestroyNotify)mbim_provider_free);
+ else
g_simple_async_result_take_error (simple, error);
if (response)
@@ -271,9 +274,13 @@ load_operator_name_finish (MMSim *self,
GAsyncResult *res,
GError **error)
{
+ MbimProvider *provider;
+
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
return NULL;
- return (gchar *)g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
+
+ provider = (MbimProvider *)g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
+ return g_strdup (provider->provider_name);
}
static void
@@ -291,10 +298,9 @@ load_operator_name_ready (MbimDevice *device,
mbim_message_home_provider_response_parse (
response,
&provider,
- &error)) {
- g_simple_async_result_set_op_res_gpointer (simple, g_strdup (provider->provider_name), NULL);
- mbim_provider_free (provider);
- } else
+ &error))
+ g_simple_async_result_set_op_res_gpointer (simple, provider, (GDestroyNotify)mbim_provider_free);
+ else
g_simple_async_result_take_error (simple, error);
if (response)