IB/uverbs: Fix ordering of ucontext check in ib_uverbs_write
During disassociation the ucontext will become NULL, however due to how
the SRCU locking works the ucontext must only be examined after looking
at the ib_dev, which governs the RCU control flow.
With the wrong ordering userspace will see EINVAL instead of EIO for a
disassociated uverbs FD, which breaks rdma-core.
Cc: stable@vger.kernel.org
Fixes: 491d5c6a30
("RDMA/uverbs: Move uncontext check before SRCU read lock")
Reported-by: Mark Bloch <markb@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Reviewed-by: Leon Romanovsky <leonro@mellanox.com>
This commit is contained in:
parent
3dc7c7badb
commit
1eb9364ce8
|
@ -736,10 +736,6 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
if (!file->ucontext &&
|
|
||||||
(command != IB_USER_VERBS_CMD_GET_CONTEXT || extended))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
if (extended) {
|
if (extended) {
|
||||||
if (count < (sizeof(hdr) + sizeof(ex_hdr)))
|
if (count < (sizeof(hdr) + sizeof(ex_hdr)))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -759,6 +755,16 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Must be after the ib_dev check, as once the RCU clears ib_dev ==
|
||||||
|
* NULL means ucontext == NULL
|
||||||
|
*/
|
||||||
|
if (!file->ucontext &&
|
||||||
|
(command != IB_USER_VERBS_CMD_GET_CONTEXT || extended)) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (!verify_command_mask(ib_dev, command, extended)) {
|
if (!verify_command_mask(ib_dev, command, extended)) {
|
||||||
ret = -EOPNOTSUPP;
|
ret = -EOPNOTSUPP;
|
||||||
goto out;
|
goto out;
|
||||||
|
|
Loading…
Reference in New Issue