]> git.baikalelectronics.ru Git - kernel.git/commit
drm: Use array_size() when creating lease
authorMatthew Wilcox <willy@infradead.org>
Thu, 14 Feb 2019 19:03:48 +0000 (11:03 -0800)
committerDave Airlie <airlied@redhat.com>
Fri, 15 Feb 2019 03:08:08 +0000 (13:08 +1000)
commit50417a7a31cc169214819913482833f45f04e6e3
tree2e231c985a2670be1966b1f81c92004641ba3736
parent516119548348b9b7c5c4be8d29b24d364c6dcd1d
drm: Use array_size() when creating lease

Passing an object_count of sufficient size will make
object_count * 4 wrap around to be very small, then a later function
will happily iterate off the end of the object_ids array.  Using
array_size() will saturate at SIZE_MAX, the kmalloc() will fail and
we'll return an -ENOMEM to the norty userspace.

Fixes: bba0f602c30a ("drm: Add four ioctls for managing drm mode object leases [v7]")
Signed-off-by: Matthew Wilcox <willy@infradead.org>
Acked-by: Kees Cook <keescook@chromium.org>
Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: <stable@vger.kernel.org> # v4.15+
Signed-off-by: Dave Airlie <airlied@redhat.com>
drivers/gpu/drm/drm_lease.c