Commit 96d566b6 authored by Markus Elfring's avatar Markus Elfring Committed by Steve French

smb3: Improve exception handling in allocate_mr_list()

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: default avatarMarkus Elfring <elfring@users.sourceforge.net>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 516eea97
...@@ -2136,7 +2136,7 @@ static int allocate_mr_list(struct smbd_connection *info) ...@@ -2136,7 +2136,7 @@ static int allocate_mr_list(struct smbd_connection *info)
for (i = 0; i < info->responder_resources * 2; i++) { for (i = 0; i < info->responder_resources * 2; i++) {
smbdirect_mr = kzalloc(sizeof(*smbdirect_mr), GFP_KERNEL); smbdirect_mr = kzalloc(sizeof(*smbdirect_mr), GFP_KERNEL);
if (!smbdirect_mr) if (!smbdirect_mr)
goto out; goto cleanup_entries;
smbdirect_mr->mr = ib_alloc_mr(info->pd, info->mr_type, smbdirect_mr->mr = ib_alloc_mr(info->pd, info->mr_type,
info->max_frmr_depth); info->max_frmr_depth);
if (IS_ERR(smbdirect_mr->mr)) { if (IS_ERR(smbdirect_mr->mr)) {
...@@ -2162,7 +2162,7 @@ static int allocate_mr_list(struct smbd_connection *info) ...@@ -2162,7 +2162,7 @@ static int allocate_mr_list(struct smbd_connection *info)
out: out:
kfree(smbdirect_mr); kfree(smbdirect_mr);
cleanup_entries:
list_for_each_entry_safe(smbdirect_mr, tmp, &info->mr_list, list) { list_for_each_entry_safe(smbdirect_mr, tmp, &info->mr_list, list) {
list_del(&smbdirect_mr->list); list_del(&smbdirect_mr->list);
ib_dereg_mr(smbdirect_mr->mr); ib_dereg_mr(smbdirect_mr->mr);
......
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