]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
RDMA/uverbs: Don't fail in creation of multiple flows
authorLeon Romanovsky <leonro@mellanox.com>
Sun, 1 Jul 2018 12:31:54 +0000 (15:31 +0300)
committerJason Gunthorpe <jgg@mellanox.com>
Tue, 3 Jul 2018 20:08:00 +0000 (14:08 -0600)
The conversion from offsetof() calculations to sizeof()
wrongly behaved for missed exact size and in scenario with
more than one flow.

In such scenario we got "create flow failed, flow 10: 8 bytes
left from uverb cmd" error, which is wrong because the size of
kern_spec is exactly 8 bytes, and we were not supposed to fail.

Cc: <stable@vger.kernel.org> # 3.12
Fixes: 4fae7f170416 ("RDMA/uverbs: Fix slab-out-of-bounds in ib_uverbs_ex_create_flow")
Reported-by: Ran Rozenstein <ranro@mellanox.com>
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/core/uverbs_cmd.c

index 87ffeebc0b28474edd4946c77dffc52fe3902b4a..cc06e8404e9bf07c6d0acccd81490a0ba78a94f7 100644 (file)
@@ -3586,7 +3586,7 @@ int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file,
        kern_spec = kern_flow_attr->flow_specs;
        ib_spec = flow_attr + 1;
        for (i = 0; i < flow_attr->num_of_specs &&
-                       cmd.flow_attr.size > sizeof(*kern_spec) &&
+                       cmd.flow_attr.size >= sizeof(*kern_spec) &&
                        cmd.flow_attr.size >= kern_spec->size;
             i++) {
                err = kern_spec_to_ib_spec(