[media] ivtv: Convert to get_user_pages_unlocked()
Convert ivtv_yuv_prep_user_dma() to use get_user_pages_unlocked() so that we don't unnecessarily leak knowledge about mm locking into drivers code. CC: Andy Walls <awalls@md.metrocast.net> Signed-off-by: Jan Kara <jack@suse.cz> Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
This commit is contained in:
parent
759b26a1d9
commit
520e82d44b
|
@ -75,15 +75,15 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
||||||
ivtv_udma_get_page_info (&uv_dma, (unsigned long)args->uv_source, 360 * uv_decode_height);
|
ivtv_udma_get_page_info (&uv_dma, (unsigned long)args->uv_source, 360 * uv_decode_height);
|
||||||
|
|
||||||
/* Get user pages for DMA Xfer */
|
/* Get user pages for DMA Xfer */
|
||||||
down_read(¤t->mm->mmap_sem);
|
y_pages = get_user_pages_unlocked(current, current->mm,
|
||||||
y_pages = get_user_pages(current, current->mm, y_dma.uaddr, y_dma.page_count, 0, 1, &dma->map[0], NULL);
|
y_dma.uaddr, y_dma.page_count, 0, 1,
|
||||||
|
&dma->map[0]);
|
||||||
uv_pages = 0; /* silence gcc. value is set and consumed only if: */
|
uv_pages = 0; /* silence gcc. value is set and consumed only if: */
|
||||||
if (y_pages == y_dma.page_count) {
|
if (y_pages == y_dma.page_count) {
|
||||||
uv_pages = get_user_pages(current, current->mm,
|
uv_pages = get_user_pages_unlocked(current, current->mm,
|
||||||
uv_dma.uaddr, uv_dma.page_count, 0, 1,
|
uv_dma.uaddr, uv_dma.page_count, 0, 1,
|
||||||
&dma->map[y_pages], NULL);
|
&dma->map[y_pages]);
|
||||||
}
|
}
|
||||||
up_read(¤t->mm->mmap_sem);
|
|
||||||
|
|
||||||
if (y_pages != y_dma.page_count || uv_pages != uv_dma.page_count) {
|
if (y_pages != y_dma.page_count || uv_pages != uv_dma.page_count) {
|
||||||
int rc = -EFAULT;
|
int rc = -EFAULT;
|
||||||
|
|
Loading…
Reference in New Issue