diff options
author | Roland Dreier <rolandd@cisco.com> | 2007-02-22 13:16:51 -0800 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2007-02-22 13:16:51 -0800 |
commit | aaf1aef55f50f53812871693692c7cbefcd57f39 (patch) | |
tree | 01a533c2f93dccda7176ce4bf3d68c3212a8c0b4 /drivers/infiniband/core/uverbs_cmd.c | |
parent | 658bcef619f50d9eb6028452ff9e1ad4a96c2af9 (diff) | |
download | lwn-aaf1aef55f50f53812871693692c7cbefcd57f39.tar.gz lwn-aaf1aef55f50f53812871693692c7cbefcd57f39.zip |
IB/uverbs: Return correct error for invalid PD in register MR
If no matching PD is found in ib_uverbs_reg_mr(), then the function
jumps to err_release without setting the return value ret. This means
that ret will hold the return value of the call to ib_umem_get() a few
lines earlier; if the function reaches the point where it looks for
the PD, we know that ib_umem_get() must have returned 0, so
ib_uverbs_reg_mr() ends up return 0 for a bad PD ID. Fix this by
setting ret to -EINVAL before jumping to the exit path when no PD is
found.
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband/core/uverbs_cmd.c')
-rw-r--r-- | drivers/infiniband/core/uverbs_cmd.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index df1efbc10882..4fd75afa6a3a 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -622,8 +622,10 @@ ssize_t ib_uverbs_reg_mr(struct ib_uverbs_file *file, obj->umem.virt_base = cmd.hca_va; pd = idr_read_pd(cmd.pd_handle, file->ucontext); - if (!pd) + if (!pd) { + ret = -EINVAL; goto err_release; + } mr = pd->device->reg_user_mr(pd, &obj->umem, cmd.access_flags, &udata); if (IS_ERR(mr)) { |