]> git.ipfire.org Git - thirdparty/kernel/stable.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)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 20 Feb 2019 09:25:49 +0000 (10:25 +0100)
commit3312e0ae2faf4336e9549f13ec0671ec263f4b40
treee211379df989297572a3ba7ec9774f74292bb018
parent029a38f8211fb966a6902e32a31967451aa0e9c5
drm: Use array_size() when creating lease

commit 69ef943dbc14b21987c79f8399ffea08f9a1b446 upstream.

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: 62884cd386b8 ("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>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/gpu/drm/drm_lease.c