On 06/11/14 17:49, Thierry Reding wrote: > From: Thierry Reding <treding at nvidia.com> > > When creating a dumb buffer object using the DRM_IOCTL_MODE_CREATE_DUMB > IOCTL, only the width, height, bpp and flags fields are inputs. The > caller is not guaranteed to zero out or set handle, pitch and size. > Drivers must not treat these values as possible inputs, otherwise they > may use uninitialized memory during the computation of the framebuffer > size. > > The OMAP driver uses the pitch field passed in by userspace as a minimum > and only override it if the driver-computed pitch is larger than what > userspace provided. To prevent this from causing overallocation, fix the > minimum pitch to 0 to enforce the driver-computed pitch. > > Cc: Tomi Valkeinen <tomi.valkeinen at ti.com> > Reviewed-by: Daniel Vetter <daniel.vetter at ffwll.ch> > Signed-off-by: Thierry Reding <treding at nvidia.com> > --- > drivers/gpu/drm/omapdrm/omap_gem.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/omapdrm/omap_gem.c > b/drivers/gpu/drm/omapdrm/omap_gem.c > index e4849413ee80..bff60b73995b 100644 > --- a/drivers/gpu/drm/omapdrm/omap_gem.c > +++ b/drivers/gpu/drm/omapdrm/omap_gem.c > @@ -613,7 +613,7 @@ int omap_gem_dumb_create(struct drm_file *file, struct > drm_device *dev, > union omap_gem_size gsize; > > /* in case someone tries to feed us a completely bogus stride: */
This comment could also be removed, as it doesn't make sense after this change. > - args->pitch = align_pitch(args->pitch, args->width, args->bpp); > + args->pitch = align_pitch(0, args->width, args->bpp); > args->size = PAGE_ALIGN(args->pitch * args->height); > > gsize = (union omap_gem_size){ Acked-by: Tomi Valkeinen <tomi.valkeinen at ti.com> Tomi -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 819 bytes Desc: OpenPGP digital signature URL: <http://lists.freedesktop.org/archives/dri-devel/attachments/20141107/dd3b91a0/attachment.sig>