mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-15 15:04:27 +08:00
IB/uverbs: Fix possible oops with duplicate ioctl attributes
If the same attribute is listed twice by the user in the ioctl attribute list then error unwind can cause the kernel to deref garbage. This happens when an object with WRITE access is sent twice. The second parse properly fails but corrupts the state required for the error unwind it triggers. Fixing this by making duplicates in the attribute list invalid. This is not something we need to support. The ioctl interface is currently recommended to be disabled in kConfig. Signed-off-by: Matan Barak <matanb@mellanox.com> Signed-off-by: Leon Romanovsky <leon@kernel.org> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
This commit is contained in:
parent
9dfb2ff400
commit
4d39a959bc
@ -59,6 +59,9 @@ static int uverbs_process_attr(struct ib_device *ibdev,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (test_bit(attr_id, attr_bundle_h->valid_bitmap))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
spec = &attr_spec_bucket->attrs[attr_id];
|
spec = &attr_spec_bucket->attrs[attr_id];
|
||||||
e = &elements[attr_id];
|
e = &elements[attr_id];
|
||||||
e->uattr = uattr_ptr;
|
e->uattr = uattr_ptr;
|
||||||
|
Loading…
Reference in New Issue
Block a user