From: Markus Elfring <[email protected]>
Date: Sat, 7 Jan 2017 08:43:50 +0100

The functions "kmalloc" and "kzalloc" were called in two cases by the
function "msb_ftl_initialize" without checking immediately
if they succeded.
This issue was detected by using the Coccinelle software.

Split a condition check for memory allocation failures so that
the corresponding exception handling will be improved a bit.

Signed-off-by: Markus Elfring <[email protected]>
---
 drivers/memstick/core/ms_block.c | 21 +++++++++++++--------
 1 file changed, 13 insertions(+), 8 deletions(-)

diff --git a/drivers/memstick/core/ms_block.c b/drivers/memstick/core/ms_block.c
index f3512404bc52..fd8b1697a5a2 100644
--- a/drivers/memstick/core/ms_block.c
+++ b/drivers/memstick/core/ms_block.c
@@ -1339,17 +1339,17 @@ static int msb_ftl_initialize(struct msb_data *msb)
        msb->logical_block_count = msb->zone_count * 496 - 2;
 
        msb->used_blocks_bitmap = kzalloc(msb->block_count / 8, GFP_KERNEL);
+       if (!msb->used_blocks_bitmap)
+               return -ENOMEM;
+
        msb->erased_blocks_bitmap = kzalloc(msb->block_count / 8, GFP_KERNEL);
+       if (!msb->erased_blocks_bitmap)
+               goto free_used_bitmap;
+
        msb->lba_to_pba_table =
                kmalloc(msb->logical_block_count * sizeof(u16), GFP_KERNEL);
-
-       if (!msb->used_blocks_bitmap || !msb->lba_to_pba_table ||
-                                               !msb->erased_blocks_bitmap) {
-               kfree(msb->used_blocks_bitmap);
-               kfree(msb->lba_to_pba_table);
-               kfree(msb->erased_blocks_bitmap);
-               return -ENOMEM;
-       }
+       if (!msb->lba_to_pba_table)
+               goto free_erased_bitmap;
 
        for (i = 0; i < msb->zone_count; i++)
                msb->free_block_count[i] = MS_BLOCKS_IN_ZONE;
@@ -1362,6 +1362,11 @@ static int msb_ftl_initialize(struct msb_data *msb)
 
        msb->ftl_initialized = true;
        return 0;
+free_erased_bitmap:
+       kfree(msb->erased_blocks_bitmap);
+free_used_bitmap:
+       kfree(msb->used_blocks_bitmap);
+       return -ENOMEM;
 }
 
 static int msb_ftl_scan(struct msb_data *msb)
-- 
2.11.0

Reply via email to