smb3: Improve exception handling in allocate_mr_list()
authorSteve French <stfrench@microsoft.com>
Sun, 28 Jan 2024 22:31:00 +0000 (16:31 -0600)
committerSteve French <stfrench@microsoft.com>
Sun, 28 Jan 2024 22:31:00 +0000 (16:31 -0600)
The kfree() function was called in one case by
the allocate_mr_list() function during error handling
even if the passed variable contained a null pointer.
This issue was detected by using the Coccinelle software.

Thus use another label.

Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/cifs/smbdirect.c

index 9e37325e3781cc0c43dadd82d427b0023262c65f..563bcfad5734dd0c7e9d8387f03fbce2c1c3fd1d 100644 (file)
@@ -2226,7 +2226,7 @@ static int allocate_mr_list(struct smbd_connection *info)
        for (i = 0; i < info->responder_resources * 2; i++) {
                smbdirect_mr = kzalloc(sizeof(*smbdirect_mr), GFP_KERNEL);
                if (!smbdirect_mr)
-                       goto out;
+                       goto cleanup_entries;
                smbdirect_mr->mr = ib_alloc_mr(info->pd, info->mr_type,
                                        info->max_frmr_depth);
                if (IS_ERR(smbdirect_mr->mr)) {
@@ -2253,7 +2253,7 @@ static int allocate_mr_list(struct smbd_connection *info)
 
 out:
        kfree(smbdirect_mr);
-
+cleanup_entries:
        list_for_each_entry_safe(smbdirect_mr, tmp, &info->mr_list, list) {
                list_del(&smbdirect_mr->list);
                ib_dereg_mr(smbdirect_mr->mr);