mirror of
https://github.com/tbsdtv/media_build.git
synced 2025-07-23 04:13:02 +02:00
172 lines
6.2 KiB
Diff
172 lines
6.2 KiB
Diff
diff --git a/drivers/media/common/videobuf2/frame_vector.c b/drivers/media/common/videobuf2/frame_vector.c
|
|
index 0f430ddc1f67..9ebeff9b094e 100644
|
|
--- a/drivers/media/common/videobuf2/frame_vector.c
|
|
+++ b/drivers/media/common/videobuf2/frame_vector.c
|
|
@@ -50,7 +50,7 @@ int get_vaddr_frames(unsigned long start, unsigned int nr_frames, bool write,
|
|
if (write)
|
|
gup_flags |= FOLL_WRITE;
|
|
|
|
- ret = pin_user_pages_fast(start, nr_frames, gup_flags,
|
|
+ ret = get_user_pages_fast(start, nr_frames, gup_flags,
|
|
(struct page **)(vec->ptrs));
|
|
vec->got_ref = true;
|
|
vec->is_pfns = false;
|
|
@@ -78,6 +78,7 @@ EXPORT_SYMBOL(get_vaddr_frames);
|
|
void put_vaddr_frames(struct frame_vector *vec)
|
|
{
|
|
struct page **pages;
|
|
+ int i;
|
|
|
|
if (!vec->got_ref)
|
|
goto out;
|
|
@@ -90,7 +91,8 @@ void put_vaddr_frames(struct frame_vector *vec)
|
|
if (WARN_ON(IS_ERR(pages)))
|
|
goto out;
|
|
|
|
- unpin_user_pages(pages, vec->nr_frames);
|
|
+ for (i = 0; i < vec->nr_frames; i++)
|
|
+ put_page(pages[i]);
|
|
vec->got_ref = false;
|
|
out:
|
|
vec->nr_frames = 0;
|
|
diff --git a/drivers/media/pci/ivtv/ivtv-udma.c b/drivers/media/pci/ivtv/ivtv-udma.c
|
|
index 99b9f55ca829..81ad6bd035d9 100644
|
|
--- a/drivers/media/pci/ivtv/ivtv-udma.c
|
|
+++ b/drivers/media/pci/ivtv/ivtv-udma.c
|
|
@@ -94,7 +94,7 @@ int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr,
|
|
{
|
|
struct ivtv_dma_page_info user_dma;
|
|
struct ivtv_user_dma *dma = &itv->udma;
|
|
- int err;
|
|
+ int i, err;
|
|
|
|
IVTV_DEBUG_DMA("ivtv_udma_setup, dst: 0x%08x\n", (unsigned int)ivtv_dest_addr);
|
|
|
|
@@ -113,15 +113,16 @@ int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr,
|
|
return -EINVAL;
|
|
}
|
|
|
|
- /* Pin user pages for DMA Xfer */
|
|
- err = pin_user_pages_unlocked(user_dma.uaddr, user_dma.page_count,
|
|
+ /* Get user pages for DMA Xfer */
|
|
+ err = get_user_pages_unlocked(user_dma.uaddr, user_dma.page_count,
|
|
dma->map, 0);
|
|
|
|
if (user_dma.page_count != err) {
|
|
IVTV_DEBUG_WARN("failed to map user pages, returned %d instead of %d\n",
|
|
err, user_dma.page_count);
|
|
if (err >= 0) {
|
|
- unpin_user_pages(dma->map, err);
|
|
+ for (i = 0; i < err; i++)
|
|
+ put_page(dma->map[i]);
|
|
return -EINVAL;
|
|
}
|
|
return err;
|
|
@@ -131,7 +132,9 @@ int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr,
|
|
|
|
/* Fill SG List with new values */
|
|
if (ivtv_udma_fill_sg_list(dma, &user_dma, 0) < 0) {
|
|
- unpin_user_pages(dma->map, dma->page_count);
|
|
+ for (i = 0; i < dma->page_count; i++) {
|
|
+ put_page(dma->map[i]);
|
|
+ }
|
|
dma->page_count = 0;
|
|
return -ENOMEM;
|
|
}
|
|
@@ -153,6 +156,7 @@ int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr,
|
|
void ivtv_udma_unmap(struct ivtv *itv)
|
|
{
|
|
struct ivtv_user_dma *dma = &itv->udma;
|
|
+ int i;
|
|
|
|
IVTV_DEBUG_INFO("ivtv_unmap_user_dma\n");
|
|
|
|
@@ -169,7 +173,10 @@ void ivtv_udma_unmap(struct ivtv *itv)
|
|
/* sync DMA */
|
|
ivtv_udma_sync_for_cpu(itv);
|
|
|
|
- unpin_user_pages(dma->map, dma->page_count);
|
|
+ /* Release User Pages */
|
|
+ for (i = 0; i < dma->page_count; i++) {
|
|
+ put_page(dma->map[i]);
|
|
+ }
|
|
dma->page_count = 0;
|
|
}
|
|
|
|
diff --git a/drivers/media/pci/ivtv/ivtv-yuv.c b/drivers/media/pci/ivtv/ivtv-yuv.c
|
|
index 582146f8d70d..2907ebdd1a98 100644
|
|
--- a/drivers/media/pci/ivtv/ivtv-yuv.c
|
|
+++ b/drivers/media/pci/ivtv/ivtv-yuv.c
|
|
@@ -30,6 +30,7 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
|
struct yuv_playback_info *yi = &itv->yuv_info;
|
|
u8 frame = yi->draw_frame;
|
|
struct yuv_frame_info *f = &yi->new_frame_info[frame];
|
|
+ int i;
|
|
int y_pages, uv_pages;
|
|
unsigned long y_buffer_offset, uv_buffer_offset;
|
|
int y_decode_height, uv_decode_height, y_size;
|
|
@@ -61,12 +62,12 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
|
ivtv_udma_get_page_info (&y_dma, (unsigned long)args->y_source, 720 * y_decode_height);
|
|
ivtv_udma_get_page_info (&uv_dma, (unsigned long)args->uv_source, 360 * uv_decode_height);
|
|
|
|
- /* Pin user pages for DMA Xfer */
|
|
- y_pages = pin_user_pages_unlocked(y_dma.uaddr,
|
|
+ /* Get user pages for DMA Xfer */
|
|
+ y_pages = get_user_pages_unlocked(y_dma.uaddr,
|
|
y_dma.page_count, &dma->map[0], 0);
|
|
uv_pages = 0; /* silence gcc. value is set and consumed only if: */
|
|
if (y_pages == y_dma.page_count) {
|
|
- uv_pages = pin_user_pages_unlocked(uv_dma.uaddr,
|
|
+ uv_pages = get_user_pages_unlocked(uv_dma.uaddr,
|
|
uv_dma.page_count, &dma->map[y_pages], 0);
|
|
}
|
|
|
|
@@ -79,7 +80,8 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
|
uv_pages, uv_dma.page_count);
|
|
|
|
if (uv_pages >= 0) {
|
|
- unpin_user_pages(&dma->map[y_pages], uv_pages);
|
|
+ for (i = 0; i < uv_pages; i++)
|
|
+ put_page(dma->map[y_pages + i]);
|
|
rc = -EFAULT;
|
|
} else {
|
|
rc = uv_pages;
|
|
@@ -90,7 +92,8 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
|
y_pages, y_dma.page_count);
|
|
}
|
|
if (y_pages >= 0) {
|
|
- unpin_user_pages(dma->map, y_pages);
|
|
+ for (i = 0; i < y_pages; i++)
|
|
+ put_page(dma->map[i]);
|
|
/*
|
|
* Inherit the -EFAULT from rc's
|
|
* initialization, but allow it to be
|
|
@@ -108,7 +111,9 @@ static int ivtv_yuv_prep_user_dma(struct ivtv *itv, struct ivtv_user_dma *dma,
|
|
/* Fill & map SG List */
|
|
if (ivtv_udma_fill_sg_list (dma, &uv_dma, ivtv_udma_fill_sg_list (dma, &y_dma, 0)) < 0) {
|
|
IVTV_DEBUG_WARN("could not allocate bounce buffers for highmem userspace buffers\n");
|
|
- unpin_user_pages(dma->map, dma->page_count);
|
|
+ for (i = 0; i < dma->page_count; i++) {
|
|
+ put_page(dma->map[i]);
|
|
+ }
|
|
dma->page_count = 0;
|
|
return -ENOMEM;
|
|
}
|
|
diff --git a/drivers/media/pci/ivtv/ivtvfb.c b/drivers/media/pci/ivtv/ivtvfb.c
|
|
index 00ac94d4ab19..4e3962c3f1da 100644
|
|
--- a/drivers/media/pci/ivtv/ivtvfb.c
|
|
+++ b/drivers/media/pci/ivtv/ivtvfb.c
|
|
@@ -281,10 +281,10 @@ static int ivtvfb_prep_dec_dma_to_device(struct ivtv *itv,
|
|
/* Map User DMA */
|
|
if (ivtv_udma_setup(itv, ivtv_dest_addr, userbuf, size_in_bytes) <= 0) {
|
|
mutex_unlock(&itv->udma.lock);
|
|
- IVTVFB_WARN("ivtvfb_prep_dec_dma_to_device, Error with pin_user_pages: %d bytes, %d pages returned\n",
|
|
+ IVTVFB_WARN("ivtvfb_prep_dec_dma_to_device, Error with get_user_pages: %d bytes, %d pages returned\n",
|
|
size_in_bytes, itv->udma.page_count);
|
|
|
|
- /* pin_user_pages must have failed completely */
|
|
+ /* get_user_pages must have failed completely */
|
|
return -EIO;
|
|
}
|
|
|