Commit 57ac5348 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

media: vivid: use vzalloc for dev->bitmap_out

When vivid is unloaded it used vfree to free dev->bitmap_out,
but it was actually allocated using kmalloc. Use vzalloc
instead, conform what vivid-vid-cap.c does.
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Reviewed-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 13deaec4
...@@ -798,7 +798,7 @@ int vivid_vid_out_s_selection(struct file *file, void *fh, struct v4l2_selection ...@@ -798,7 +798,7 @@ int vivid_vid_out_s_selection(struct file *file, void *fh, struct v4l2_selection
s->r.height *= factor; s->r.height *= factor;
if (dev->bitmap_out && (compose->width != s->r.width || if (dev->bitmap_out && (compose->width != s->r.width ||
compose->height != s->r.height)) { compose->height != s->r.height)) {
kfree(dev->bitmap_out); vfree(dev->bitmap_out);
dev->bitmap_out = NULL; dev->bitmap_out = NULL;
} }
*compose = s->r; *compose = s->r;
...@@ -941,15 +941,19 @@ int vidioc_s_fmt_vid_out_overlay(struct file *file, void *priv, ...@@ -941,15 +941,19 @@ int vidioc_s_fmt_vid_out_overlay(struct file *file, void *priv,
return ret; return ret;
if (win->bitmap) { if (win->bitmap) {
new_bitmap = memdup_user(win->bitmap, bitmap_size); new_bitmap = vzalloc(bitmap_size);
if (IS_ERR(new_bitmap)) if (!new_bitmap)
return PTR_ERR(new_bitmap); return -ENOMEM;
if (copy_from_user(new_bitmap, win->bitmap, bitmap_size)) {
vfree(new_bitmap);
return -EFAULT;
}
} }
dev->overlay_out_top = win->w.top; dev->overlay_out_top = win->w.top;
dev->overlay_out_left = win->w.left; dev->overlay_out_left = win->w.left;
kfree(dev->bitmap_out); vfree(dev->bitmap_out);
dev->bitmap_out = new_bitmap; dev->bitmap_out = new_bitmap;
dev->clipcount_out = win->clipcount; dev->clipcount_out = win->clipcount;
if (dev->clipcount_out) if (dev->clipcount_out)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment