[PATCH 1/3] sim-mbim: prevent potential leak when loading operator idenitifier and name
Ben Chan
benchan at chromium.org
Mon Dec 9 15:07:25 PST 2013
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 at lanedo.com>
---
src/mm-sim-mbim.c | 26 ++++++++++++++++----------
1 file changed, 16 insertions(+), 10 deletions(-)
diff --git a/src/mm-sim-mbim.c b/src/mm-sim-mbim.c
index 77e83ea..c083997 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)
--
1.8.5.1
More information about the ModemManager-devel
mailing list