NFC: st21nfca: Fix potential memory leak
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Sun, 19 Feb 2017 09:58:47 +0000 (10:58 +0100)
committerSamuel Ortiz <sameo@linux.intel.com>
Sat, 1 Apr 2017 22:18:35 +0000 (00:18 +0200)
If all bits of 'dev_mask' are already set, there is a memory leak because
'info' should be freed before returning.

While fixing it, 'return -ENOMEM' directly if the first kzalloc fails.
This makes the code more readable.

Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
drivers/nfc/st21nfca/core.c

index dacb916..50be3b7 100644 (file)
@@ -959,10 +959,8 @@ int st21nfca_hci_probe(void *phy_id, struct nfc_phy_ops *phy_ops,
        unsigned long quirks = 0;
 
        info = kzalloc(sizeof(struct st21nfca_hci_info), GFP_KERNEL);
-       if (!info) {
-               r = -ENOMEM;
-               goto err_alloc_hdev;
-       }
+       if (!info)
+               return -ENOMEM;
 
        info->phy_ops = phy_ops;
        info->phy_id = phy_id;
@@ -978,8 +976,10 @@ int st21nfca_hci_probe(void *phy_id, struct nfc_phy_ops *phy_ops,
         * persistent info to discriminate 2 identical chips
         */
        dev_num = find_first_zero_bit(dev_mask, ST21NFCA_NUM_DEVICES);
-       if (dev_num >= ST21NFCA_NUM_DEVICES)
-               return -ENODEV;
+       if (dev_num >= ST21NFCA_NUM_DEVICES) {
+               r = -ENODEV;
+               goto err_alloc_hdev;
+       }
 
        set_bit(dev_num, dev_mask);