Commit 3c92a0bf authored by Amir Shehata's avatar Amir Shehata Committed by Greg Kroah-Hartman

staging/lustre/ptlrpc: Fix a crash when dereferencing NULL pointer

When a system runs out of memory and the function
ptlrpc_register_bulk() is called from ptl_send_rpc() the call to
LNetMEAttach() fails due to failure to allocate memory.  This forces
the code into an error path, which most probably previously went
untested.  The error path:
if (rc != 0) {
        CERROR("%s: LNetMEAttach failed x"LPU64"/%d: rc = %dn",
                desc->bd_export->exp_obd->obd_name, xid,
                posted_md, rc);
        break;
}
This print assumes that desc->bd_export is not NULL.  However, it is.
In fact it is expected to be NULL.  desc->bd_import is the correct
structure to access in this case.

Lustre-change: http://review.whamcloud.com/7121
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-3585
Cc: stable <stable@vger.kernel.org> # 3.12
Signed-off-by: default avatarAmir Shehata <amir.shehata@intel.com>
Reviewed-by: default avatarLiang Zhen <liang.zhen@intel.com>
Reviewed-by: default avatarDoug Oucharek <doug.s.oucharek@intel.com>
Reviewed-by: default avatarOleg Drokin <oleg.drokin@intel.com>
Signed-off-by: default avatarPeng Tao <bergwolf@gmail.com>
Signed-off-by: default avatarAndreas Dilger <andreas.dilger@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 56dba8cd
...@@ -180,7 +180,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req) ...@@ -180,7 +180,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req)
LNET_UNLINK, LNET_INS_AFTER, &me_h); LNET_UNLINK, LNET_INS_AFTER, &me_h);
if (rc != 0) { if (rc != 0) {
CERROR("%s: LNetMEAttach failed x"LPU64"/%d: rc = %d\n", CERROR("%s: LNetMEAttach failed x"LPU64"/%d: rc = %d\n",
desc->bd_export->exp_obd->obd_name, xid, desc->bd_import->imp_obd->obd_name, xid,
posted_md, rc); posted_md, rc);
break; break;
} }
...@@ -190,7 +190,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req) ...@@ -190,7 +190,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req)
&desc->bd_mds[posted_md]); &desc->bd_mds[posted_md]);
if (rc != 0) { if (rc != 0) {
CERROR("%s: LNetMDAttach failed x"LPU64"/%d: rc = %d\n", CERROR("%s: LNetMDAttach failed x"LPU64"/%d: rc = %d\n",
desc->bd_export->exp_obd->obd_name, xid, desc->bd_import->imp_obd->obd_name, xid,
posted_md, rc); posted_md, rc);
rc2 = LNetMEUnlink(me_h); rc2 = LNetMEUnlink(me_h);
LASSERT(rc2 == 0); LASSERT(rc2 == 0);
...@@ -220,7 +220,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req) ...@@ -220,7 +220,7 @@ int ptlrpc_register_bulk(struct ptlrpc_request *req)
/* Holler if peer manages to touch buffers before he knows the xid */ /* Holler if peer manages to touch buffers before he knows the xid */
if (desc->bd_md_count != total_md) if (desc->bd_md_count != total_md)
CWARN("%s: Peer %s touched %d buffers while I registered\n", CWARN("%s: Peer %s touched %d buffers while I registered\n",
desc->bd_export->exp_obd->obd_name, libcfs_id2str(peer), desc->bd_import->imp_obd->obd_name, libcfs_id2str(peer),
total_md - desc->bd_md_count); total_md - desc->bd_md_count);
spin_unlock(&desc->bd_lock); spin_unlock(&desc->bd_lock);
......
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