staging: lustre: llite: check reply status in ll_migrate()
authorNiu Yawei <yawei.niu@intel.com>
Sat, 11 Feb 2017 17:12:39 +0000 (12:12 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 12 Feb 2017 12:13:06 +0000 (13:13 +0100)
ll_migrate() should check reply status before trying to read
reply buffer, checking if request is NULL doesn't make sense.

Signed-off-by: Niu Yawei <yawei.niu@intel.com>
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-8807
Reviewed-on: https://review.whamcloud.com/23666
Reviewed-by: Andreas Dilger <andreas.dilger@intel.com>
Reviewed-by: Lai Siyao <lai.siyao@intel.com>
Reviewed-by: John L. Hammond <john.hammond@intel.com>
Reviewed-by: Oleg Drokin <oleg.drokin@intel.com>
Signed-off-by: James Simmons <jsimmons@infradead.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/lustre/lustre/llite/file.c

index 271608df91582c4bb1c61f8e0cd8f6deed5b2ac5..10adfcdd70354a9e14ca2c761a5d6e7d4e6ea02d 100644 (file)
@@ -2664,15 +2664,12 @@ again:
        op_data->op_cli_flags = CLI_MIGRATE;
        rc = md_rename(ll_i2sbi(parent)->ll_md_exp, op_data, name,
                       namelen, name, namelen, &request);
-       if (!rc)
+       if (!rc) {
+               LASSERT(request);
                ll_update_times(request, parent);
 
-       if (request) {
                body = req_capsule_server_get(&request->rq_pill, &RMF_MDT_BODY);
-               if (!body) {
-                       rc = -EPROTO;
-                       goto out_close;
-               }
+               LASSERT(body);
 
                /*
                 * If the server does release layout lock, then we cleanup
@@ -2686,14 +2683,17 @@ again:
                        kfree(och);
                        och = NULL;
                }
+       }
 
+       if (request) {
                ptlrpc_req_finished(request);
+               request = NULL;
        }
+
        /* Try again if the file layout has changed. */
-       if (rc == -EAGAIN && S_ISREG(child_inode->i_mode)) {
-               request = NULL;
+       if (rc == -EAGAIN && S_ISREG(child_inode->i_mode))
                goto again;
-       }
+
 out_close:
        if (och) /* close the file */
                ll_lease_close(och, child_inode, NULL);