Commit cd40c442 authored by Joe Thornber's avatar Joe Thornber Committed by Greg Kroah-Hartman

dm thin: fix memory leak in process_prepared_mapping error paths

commit 905386f8 upstream.

Fix memory leak in process_prepared_mapping by always freeing
the dm_thin_new_mapping structs from the mapping_pool mempool on
the error paths.
Signed-off-by: default avatarJoe Thornber <ejt@redhat.com>
Signed-off-by: default avatarMike Snitzer <snitzer@redhat.com>
Signed-off-by: default avatarAlasdair G Kergon <agk@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ac9d9e65
...@@ -859,7 +859,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m) ...@@ -859,7 +859,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m)
if (m->err) { if (m->err) {
cell_error(m->cell); cell_error(m->cell);
return; goto out;
} }
/* /*
...@@ -871,7 +871,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m) ...@@ -871,7 +871,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m)
if (r) { if (r) {
DMERR("dm_thin_insert_block() failed"); DMERR("dm_thin_insert_block() failed");
cell_error(m->cell); cell_error(m->cell);
return; goto out;
} }
/* /*
...@@ -886,6 +886,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m) ...@@ -886,6 +886,7 @@ static void process_prepared_mapping(struct dm_thin_new_mapping *m)
} else } else
cell_defer(tc, m->cell, m->data_block); cell_defer(tc, m->cell, m->data_block);
out:
list_del(&m->list); list_del(&m->list);
mempool_free(m, tc->pool->mapping_pool); mempool_free(m, tc->pool->mapping_pool);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment